*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f6f6f3;--fg:#18181b;--muted:#71717a;--dim:#a1a1aa;--line:rgba(24,24,27,.08);--accent:244,114,182;--card:#fff}
html,body{background:var(--bg);color:var(--fg);font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55;touch-action:pan-x pan-y;-webkit-text-size-adjust:100%}
body{min-height:100vh}
a{color:var(--fg);text-decoration:none}
a:hover{color:rgb(var(--accent))}

.topbar{position:sticky;top:0;z-index:10;background:rgba(246,246,243,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.topbar .wrap{max-width:880px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand-link{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.02em;font-size:17px}
.brand-link .logo-mini{position:relative;width:32px;height:32px;flex:0 0 32px;line-height:0}
.brand-link .logo-mini img{width:100%;height:100%;object-fit:contain;display:block}
.brand-link .logo-mini .dot{position:absolute;left:3px;bottom:3px;width:6px;height:6px;border-radius:50%;background:rgb(var(--accent));box-shadow:0 0 0 1.5px var(--bg),0 0 6px rgba(var(--accent),.7)}
.brand-link .logo-mini .dot::after{content:"";position:absolute;inset:-1.5px;border-radius:50%;background:rgb(var(--accent));opacity:.45;animation:ldotPulse 2.2s ease-in-out infinite}
@keyframes ldotPulse{0%,100%{transform:scale(1);opacity:.45}50%{transform:scale(2.4);opacity:0}}
.topbar nav{display:flex;gap:18px;font-size:13px;color:var(--muted);font-weight:500}
.topbar nav a:hover{color:var(--fg)}

main.page{max-width:880px;margin:0 auto;padding:40px 24px 80px}

.hero{padding:28px 0 28px;border-bottom:1px solid var(--line);margin-bottom:32px}
.hero h1{font-size:clamp(28px,4.5vw,44px);font-weight:800;letter-spacing:-.03em;line-height:1.05}
.hero p{margin-top:10px;color:var(--muted);font-size:15px;max-width:620px}
.hero .rss{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:12.5px;font-weight:600;color:rgb(var(--accent));padding:6px 10px;border:1px solid rgba(var(--accent),.3);border-radius:999px;background:transparent;cursor:pointer;font-family:inherit}
.hero .rss:hover{background:rgba(var(--accent),.08)}
.hero .rss[disabled]{opacity:.5;cursor:not-allowed}
.hero-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.hero-actions .rss{margin-top:0}
.install-note{margin-top:10px;font-size:12.5px;color:var(--muted)}
.install-help{margin-top:14px;padding:18px;background:linear-gradient(180deg,rgba(var(--accent),.09),rgba(var(--accent),.03));border:1px solid rgba(var(--accent),.22);border-radius:18px;font-size:14px;line-height:1.55;color:var(--fg);max-width:560px}
.install-help-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.install-help-head .device{flex:0 0 38px;width:38px;height:38px;border-radius:11px;background:rgba(var(--accent),.16);border:1px solid rgba(var(--accent),.28);color:rgb(var(--accent));display:flex;align-items:center;justify-content:center}
.install-help-head .device svg{width:20px;height:20px}
.install-help-head .ttl-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.install-help-head .ttl{font-weight:700;font-size:14.5px;letter-spacing:-.01em;line-height:1.15;color:var(--fg)}
.install-help-head .ttl-sub{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.install-help-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.install-help-steps li{display:flex;gap:12px;align-items:center;padding:10px 12px;background:var(--card);border:1px solid var(--line);border-radius:12px}
.install-help-steps .num{flex:0 0 22px;width:22px;height:22px;border-radius:50%;background:rgb(var(--accent));color:#fff;font-weight:700;font-size:11.5px;display:flex;align-items:center;justify-content:center;line-height:1}
.install-help-steps .body{flex:1;min-width:0;font-size:13.5px;color:var(--fg)}
.install-help-steps .body strong{font-weight:700}
.install-help-steps .chip{display:inline-flex;align-items:center;gap:4px;padding:1px 8px 1px 4px;border-radius:8px;background:rgba(var(--accent),.14);color:rgb(var(--accent));border:1px solid rgba(var(--accent),.24);font-weight:600;font-size:12.5px;vertical-align:-3px;margin:0 1px;white-space:nowrap}
.install-help-steps .chip .ico{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}
.install-help-steps .chip .ico svg{width:13px;height:13px}
.install-help-tip{margin-top:12px;display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:12.5px;color:var(--muted);background:var(--line);border-radius:10px;line-height:1.4}
.install-help-tip .ico{flex:0 0 16px;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:rgb(var(--accent))}
.install-help-tip .ico svg{width:14px;height:14px}
html.is-standalone .install-only{display:none!important}
html.is-standalone .topbar nav{display:none!important}

.hero-banner{display:block;max-width:520px;margin:8px auto 32px;border-radius:20px;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s;box-shadow:0 1px 2px rgba(24,24,27,.05),0 12px 32px -16px rgba(24,24,27,.18)}
.hero-banner:hover,.hero-banner:focus-visible{transform:translateY(-3px);box-shadow:0 4px 8px rgba(24,24,27,.06),0 24px 48px -20px rgba(244,114,182,.35)}
.hero-banner img{display:block;width:100%;height:auto}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:540px){.hero-banner{max-width:100%;border-radius:16px;margin-bottom:24px}}
@media (prefers-reduced-motion:reduce){.hero-banner{transition:none}.hero-banner:hover{transform:none}}

.filters{margin:20px 0 28px;display:flex;flex-direction:column;gap:12px}
.filters-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filters-search{position:relative;display:flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:999px;padding:0 16px;transition:border-color .18s,box-shadow .18s;flex:1;min-width:200px;height:40px}
.filters-search:focus-within{border-color:rgba(var(--accent),.5);box-shadow:0 0 0 4px rgba(var(--accent),.1)}
.filters-search svg{width:15px;height:15px;color:var(--dim);flex-shrink:0}
.filters-search input{flex:1;border:none;outline:none;background:transparent;padding:0 10px;font:inherit;font-size:14px;color:var(--fg);min-width:0;height:100%}
.filters-search input::placeholder{color:var(--dim)}
.filters-clear{border:none;background:rgba(24,24,27,.06);color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:0 14px;height:40px;border-radius:999px;cursor:pointer;transition:background .18s,color .18s}
.filters-clear:hover{background:var(--fg);color:#fff}
.filters-status{font-size:12px;color:var(--muted);font-weight:500}

.tags-dropdown{position:relative}
.tags-toggle{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font:inherit;font-size:13px;font-weight:600;color:var(--fg);cursor:pointer;transition:border-color .15s,background .15s}
.tags-toggle:hover{border-color:rgba(var(--accent),.4)}
.tags-toggle svg{width:14px;height:14px;color:var(--dim);transition:transform .2s}
.tags-toggle.open svg{transform:rotate(180deg)}
.tags-toggle.has-active{border-color:var(--fg)}
.tags-toggle-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:rgb(var(--accent));color:#fff;font-size:11px;font-weight:700}
.tags-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:20;min-width:280px;max-width:min(420px,90vw);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 32px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.04);padding:12px;display:flex;flex-direction:column;gap:10px;animation:tagsPanelIn .15s ease-out}
.tags-panel[hidden]{display:none}
.active-chips[hidden],.filters-clear[hidden],.filters-status[hidden],.tags-toggle-count[hidden]{display:none}
@keyframes tagsPanelIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.tag-search{width:100%;border:1px solid var(--line);outline:none;background:var(--bg);border-radius:8px;padding:8px 12px;font:inherit;font-size:13px;color:var(--fg)}
.tag-search:focus{border-color:rgba(var(--accent),.5);background:#fff}
.tag-search::placeholder{color:var(--dim)}
.tag-list{display:flex;flex-wrap:wrap;gap:6px;max-height:280px;overflow-y:auto;padding:2px}
.tag-list button{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:var(--bg);border:1px solid var(--line);font:inherit;font-size:12.5px;color:var(--muted);font-weight:500;cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.tag-list button:hover{border-color:rgba(var(--accent),.4);color:rgb(var(--accent))}
.tag-list button.active{background:var(--fg);color:#fff;border-color:var(--fg)}
.tag-list .count{opacity:.55;font-size:11px}
.tag-list button.active .count{opacity:.7}
.tag-empty{font-size:12.5px;color:var(--muted);padding:12px;text-align:center;width:100%}

.active-chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:rgba(var(--accent),.1);border:1px solid rgba(var(--accent),.25);font:inherit;font-size:12.5px;color:rgb(var(--accent));font-weight:500;cursor:pointer;transition:background .15s}
.chip:hover{background:rgba(var(--accent),.18)}
.chip span{font-size:14px;line-height:1;opacity:.7}

@media (max-width:560px){
  .filters-row{gap:8px}
  .filters-search{flex:1 1 100%;min-width:0;order:1}
  .tags-dropdown{order:2;flex:1 1 auto;min-width:0}
  .tags-toggle{width:100%;justify-content:space-between}
  .filters-clear{order:3;flex:0 0 auto}
  .filters-search input,.tag-search{font-size:16px}
  .tags-panel{left:0;right:0;min-width:0;max-width:none}
  .tag-list{max-height:40vh}
}

.post-list{display:flex;flex-direction:column;gap:4px}
.post-item{display:block;padding:22px 0;border-bottom:1px solid var(--line);transition:transform .2s}
.post-item:hover{transform:translateX(4px)}
.post-item .meta{display:flex;gap:12px;font-size:12px;color:var(--dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-weight:600}
.post-item .meta .draft{color:#f59e0b}
.post-item .meta .author{color:var(--muted);text-transform:none;letter-spacing:0;font-weight:500}
.post-item .meta .author-link{cursor:pointer;border-radius:6px;padding:1px 4px;margin:-1px -4px;transition:color .15s,background .15s}
.post-item .meta .author-link:hover,.post-item .meta .author-link:focus-visible{color:rgb(var(--accent));background:rgba(var(--accent),.08);outline:none}
.post-head .kicker .author-chip{cursor:pointer;border-radius:8px;padding:2px 6px;margin:-2px -6px;transition:color .15s,background .15s}
.post-head .kicker .author-chip:hover,.post-head .kicker .author-chip:focus-visible{color:rgb(var(--accent));background:rgba(var(--accent),.08);outline:none}
.post-item .meta .like-meta{display:inline-flex;align-items:center;gap:4px;color:var(--dim);text-transform:none;letter-spacing:0;font-weight:600;margin-left:auto}
.post-item .meta .like-meta svg{width:12px;height:12px;fill:currentColor}
.post-item .meta .like-meta.has-likes{color:rgb(var(--accent))}
.post-item h2{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.post-item:hover h2{color:rgb(var(--accent))}
.post-item .excerpt{margin-top:6px;color:var(--muted);font-size:14.5px}
.post-item .tags{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}
.post-item .tags span{font-size:11px;color:var(--dim);background:rgba(24,24,27,.05);padding:3px 8px;border-radius:999px}

.empty{padding:60px 0;text-align:center;color:var(--muted)}

/* single post */
.post-head{padding:20px 0 32px;border-bottom:1px solid var(--line);margin-bottom:36px}
.post-head .kicker{display:flex;gap:10px;align-items:center;font-size:12px;color:var(--dim);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:14px}
.post-head .kicker .author-chip{display:inline-flex;align-items:center;gap:7px;color:var(--muted);text-transform:none;letter-spacing:0;font-weight:500;font-size:13px}
.post-head .kicker .author-ava{width:22px;height:22px;border-radius:50%;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;background:rgba(24,24,27,.08);color:var(--text);font-size:11px;font-weight:700}
.post-head .kicker .author-ava-letter{background:rgba(var(--accent),.15);color:rgb(var(--accent))}
.post-head h1{font-size:clamp(28px,5vw,46px);font-weight:800;letter-spacing:-.03em;line-height:1.08}
.post-head .tags{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.post-head .tags a{font-size:12px;color:var(--muted);background:rgba(24,24,27,.05);padding:4px 10px;border-radius:999px;white-space:nowrap}
.post-head .tags a:hover{background:rgba(var(--accent),.12);color:rgb(var(--accent))}

.post-head .tags.is-carousel{display:block;position:relative}
.post-head .tags.is-carousel .tags-viewport{overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,#000 28px,#000 calc(100% - 28px),transparent);mask-image:linear-gradient(to right,transparent,#000 28px,#000 calc(100% - 28px),transparent)}
.post-head .tags.is-carousel .tags-track{display:inline-flex;gap:8px;cursor:grab;touch-action:pan-y;will-change:transform;user-select:none;padding:2px 0}
.post-head .tags.is-carousel.is-dragging .tags-track{cursor:grabbing}
.post-head .tags.is-carousel .tags-track a{flex:0 0 auto;-webkit-user-drag:none}
.post-head .tags.is-carousel .tags-expand{display:inline-block;margin-top:10px;background:none;border:none;color:var(--muted);font:inherit;font-size:12px;font-weight:500;cursor:pointer;padding:2px 0;letter-spacing:.02em}
.post-head .tags.is-carousel .tags-expand:hover{color:rgb(var(--accent))}
.post-head .tags.is-carousel.is-expanded .tags-viewport{-webkit-mask-image:none;mask-image:none;overflow:visible}
.post-head .tags.is-carousel.is-expanded .tags-track{display:flex;flex-wrap:wrap;cursor:default;transform:none!important}
.post-head .tags.is-carousel.is-locked .tags-track a{pointer-events:none}

.prose{font-size:17px;line-height:1.75;color:#27272a;overflow-wrap:break-word;min-width:0}
.prose a,.prose code{overflow-wrap:anywhere;word-break:break-word}
.prose>*+*{margin-top:1em}
.prose h1,.prose h2,.prose h3,.prose h4{font-weight:700;letter-spacing:-.02em;line-height:1.25;color:var(--fg);margin-top:1.8em}
.prose h1{font-size:1.9em}.prose h2{font-size:1.5em}.prose h3{font-size:1.25em}.prose h4{font-size:1.08em}
.prose p{margin:1em 0}
.prose a{color:rgb(var(--accent));text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.prose strong{font-weight:700;color:var(--fg)}
.prose em{font-style:italic}
.prose ul,.prose ol{padding-left:1.6em;margin:1em 0}
.prose li{margin:.4em 0}
.prose blockquote{border-left:3px solid rgb(var(--accent));padding:4px 0 4px 18px;color:var(--muted);font-style:italic;margin:1.4em 0}
.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:rgba(24,24,27,.06);padding:2px 6px;border-radius:5px;cursor:pointer;transition:background .18s ease;position:relative}
.prose :not(pre)>code:hover{background:rgba(var(--accent),.14);color:rgb(var(--accent))}
.prose :not(pre)>code::after{content:"Kopiuj";position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%,4px);background:var(--fg);color:#fff;font-family:'Inter',system-ui,sans-serif;font-size:11px;font-weight:600;letter-spacing:.02em;padding:4px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;box-shadow:0 4px 14px rgba(0,0,0,.15);z-index:5}
.prose :not(pre)>code::before{content:"";position:absolute;left:50%;bottom:calc(100% + 2px);transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--fg);opacity:0;transition:opacity .18s ease;z-index:5}
.prose :not(pre)>code:hover::after,.prose :not(pre)>code:hover::before{opacity:1;transform:translate(-50%,0)}
.prose :not(pre)>code:hover::before{transform:translateX(-50%)}
.prose code.copied{animation:codeFlash .9s ease}
.prose code.copied::after{content:"Skopiowano!";opacity:1;transform:translate(-50%,0);background:rgb(var(--accent))}
.prose code.copied::before{opacity:1;border-top-color:rgb(var(--accent))}
@keyframes codeFlash{0%{background:rgba(var(--accent),.35)}100%{background:rgba(24,24,27,.06)}}
.prose pre code{cursor:auto}
.prose pre code::after,.prose pre code::before{display:none}
.prose pre{background:#18181b;color:#f4f4f5;padding:18px 20px;border-radius:12px;overflow-x:auto;font-size:13.5px;line-height:1.6;margin:1.4em 0}
.prose pre code{background:none;padding:0;color:inherit;font-size:inherit}
.prose img{max-width:100%;height:auto;border-radius:12px;margin:1.4em 0}
.prose hr{border:none;border-top:1px solid var(--line);margin:2em 0}
.prose .table-wrap{margin:1.2em 0;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:8px;max-width:100%}
.prose .table-wrap>table{margin:0;border:none}
.prose .table-wrap>table th,.prose .table-wrap>table td{border-top:none;border-bottom:1px solid var(--line)}
.prose .table-wrap>table tr:last-child td{border-bottom:none}
.prose table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:15px}
.prose th,.prose td{border:1px solid var(--line);padding:8px 12px;text-align:left}
.prose th{background:rgba(24,24,27,.04);font-weight:600}
@media (max-width:640px){
  .prose .table-wrap{font-size:14px}
  .prose th,.prose td{padding:6px 10px;white-space:nowrap}
}

footer.page-foot{max-width:880px;margin:40px auto 60px;padding:30px 24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;color:var(--dim);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
footer.page-foot a{color:var(--muted)}

/* admin */
.admin-wrap{max-width:1200px;margin:0 auto;padding:24px}
.admin-grid{display:grid;grid-template-columns:320px 1fr;gap:24px;align-items:start}
@media (max-width:900px){.admin-grid{grid-template-columns:1fr}}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px}
.panel h3{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.post-entry{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:10px;cursor:pointer;gap:8px;border:1px solid transparent}
.post-entry:hover{background:rgba(24,24,27,.04)}
.post-entry.active{background:rgba(var(--accent),.08);border-color:rgba(var(--accent),.25)}
.post-entry .t{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}
.post-entry .st{font-size:10.5px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:rgba(24,24,27,.08);color:var(--muted);letter-spacing:.04em}
.post-entry .st.pub{background:rgba(34,197,94,.12);color:#16a34a}
.post-entry .st.draft{background:rgba(245,158,11,.14);color:#b45309}

.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.form-row input[type=text],.form-row textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:15px;background:#fff;color:var(--fg)}
.form-row input[type=text]:focus,.form-row textarea:focus{outline:none;border-color:rgb(var(--accent));box-shadow:0 0 0 3px rgba(var(--accent),.15)}
.form-row textarea{resize:vertical;min-height:80px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row>*{flex:1;min-width:160px}

.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;font-family:inherit;font-size:13.5px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all .2s;background:#fff;color:var(--fg)}
.btn.primary{background:var(--fg);color:#fff}
.btn.primary:hover{background:#27272a}
.btn.accent{background:rgb(var(--accent));color:#fff;border-color:rgb(var(--accent))}
.btn.ghost{background:transparent;border-color:var(--line);color:var(--muted)}
.btn.ghost:hover{border-color:var(--fg);color:var(--fg)}
.btn.danger{color:#dc2626;border-color:rgba(220,38,38,.3)}
.btn.danger:hover{background:rgba(220,38,38,.08)}
.btn:disabled{opacity:.5;cursor:not-allowed}

.toolbar{display:flex;gap:8px;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.check{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);cursor:pointer}
.check input{width:16px;height:16px}

.login-box{max-width:380px;margin:80px auto;padding:32px;background:#fff;border:1px solid var(--line);border-radius:16px}
.login-box h2{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.login-box p{color:var(--muted);font-size:13.5px;margin-bottom:20px}
.login-box .err{color:#dc2626;font-size:13px;margin-top:10px;min-height:18px}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--fg);color:#fff;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:500;box-shadow:0 10px 30px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:100}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.err{background:#dc2626}

.rss-modal{position:fixed;inset:0;z-index:200;display:none;align-items:flex-end;justify-content:center;padding:0}
.rss-modal.open{display:flex}
@media (min-width:640px){.rss-modal{align-items:center;padding:20px}}
.rss-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(6px);animation:rssFade .2s ease-out}
.rss-modal-box{position:relative;width:100%;max-width:460px;background:#fff;border-radius:22px 22px 0 0;padding:26px 22px 22px;box-shadow:0 -20px 60px -10px rgba(0,0,0,.3);animation:rssUp .28s cubic-bezier(.2,.8,.2,1)}
@media (min-width:640px){.rss-modal-box{border-radius:22px}}
.rss-modal-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;background:rgba(24,24,27,.05);border-radius:50%;font-size:20px;line-height:1;cursor:pointer;color:var(--muted)}
.rss-modal-close:hover{background:rgba(24,24,27,.1);color:var(--fg)}
.rss-modal-box h3{font-size:19px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.rss-modal-box>p{font-size:13.5px;color:var(--muted);margin-bottom:18px}
.rss-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.rss-opt{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fafafa;color:var(--fg);text-decoration:none;transition:border-color .15s,background .15s,transform .15s}
.rss-opt:hover{border-color:rgb(var(--accent));background:#fff;transform:translateY(-1px)}
.rss-opt.primary{background:rgb(var(--accent));border-color:rgb(var(--accent));color:#fff}
.rss-opt.primary:hover{background:rgb(var(--accent));color:#fff;filter:brightness(1.05)}
.rss-opt .ic{font-size:22px;flex:0 0 34px;height:34px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.65);border-radius:10px}
.rss-opt.primary .ic{background:rgba(255,255,255,.22)}
.rss-opt .tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.rss-opt .tx b{font-size:14.5px;font-weight:700}
.rss-opt .tx small{font-size:12px;opacity:.75;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rss-copy{display:flex;gap:6px}
.rss-copy input{flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:12.5px;background:#fafafa;color:var(--muted);min-width:0}
.rss-copy button{padding:9px 14px;border:1px solid var(--fg);background:var(--fg);color:#fff;border-radius:10px;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap}
.rss-copy button:hover{background:#27272a}
@keyframes rssFade{from{opacity:0}to{opacity:1}}
@keyframes rssUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ===== Skeleton loading ===== */
.skel{position:relative;display:block;background:var(--line);border-radius:6px;overflow:hidden}
.skel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(var(--accent),.18) 50%,transparent 100%);transform:translateX(-100%);animation:skelShim 1.5s ease-in-out infinite}
@keyframes skelShim{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@media (prefers-reduced-motion:reduce){.skel::after{animation:none}}

.post-skel{padding:22px 0;border-bottom:1px solid var(--line)}
.post-skel .skel-meta{display:flex;gap:12px;margin-bottom:12px}
.post-skel .skel-meta .skel{height:10px;width:90px;border-radius:4px}
.post-skel .skel-meta .skel:nth-child(2){width:60px}
.post-skel .skel-title{height:22px;width:75%;border-radius:8px;margin-bottom:10px}
.post-skel .skel-line{height:14px;width:100%;border-radius:5px;margin-bottom:6px}
.post-skel .skel-line.short{width:55%}
.post-skel .skel-tags{margin-top:14px;display:flex;gap:6px}
.post-skel .skel-tags .skel{height:18px;width:54px;border-radius:999px}
.post-skel .skel-tags .skel:nth-child(2){width:72px}
.post-skel .skel-tags .skel:nth-child(3){width:46px}
.post-skel:nth-child(2) .skel-title{width:65%}
.post-skel:nth-child(3) .skel-title{width:80%}
.post-skel:nth-child(4) .skel-title{width:60%}

.post-skel-single{padding-top:6px}
.post-skel-single .skel-meta{display:flex;gap:14px;margin-bottom:18px}
.post-skel-single .skel-meta .skel{height:11px;width:120px;border-radius:4px}
.post-skel-single .skel-meta .skel:nth-child(2){width:90px}
.post-skel-single .skel-h1{height:38px;width:80%;border-radius:10px;margin-bottom:10px}
.post-skel-single .skel-h1.short{width:55%;margin-bottom:18px}
.post-skel-single .skel-tags{display:flex;gap:6px;margin-bottom:36px}
.post-skel-single .skel-tags .skel{height:20px;width:60px;border-radius:999px}
.post-skel-single .skel-tags .skel:nth-child(2){width:78px}
.post-skel-single .skel-prose .skel-line{height:14px;width:100%;border-radius:5px;margin-bottom:8px}
.post-skel-single .skel-prose .skel-line.short{width:60%;margin-bottom:24px}

.prose .img-skel{position:relative;display:block;width:100%;min-height:220px;border-radius:12px;overflow:hidden;background:var(--line);margin:18px 0}
.prose .img-skel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(var(--accent),.18) 50%,transparent 100%);transform:translateX(-100%);animation:skelShim 1.5s ease-in-out infinite}
.prose .img-skel img{display:block;width:100%;height:auto;opacity:0;transition:opacity .35s ease}
.prose .img-skel.loaded{background:transparent;min-height:0}
.prose .img-skel.loaded::after{display:none}
.prose .img-skel.loaded img{opacity:1;position:relative}
.prose .img-skel.failed{min-height:120px;background:var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted)}
.prose .img-skel.failed::after{display:none}
.prose .img-skel.failed img{display:none}
.prose .img-skel.failed::before{content:"";display:block;width:36px;height:36px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='1' y1='1' x2='23' y2='23'/><path d='M16.72 11.06A10.94 10.94 0 0 1 19 12.55'/><path d='M5 12.55a10.94 10.94 0 0 1 5.17-2.39'/><path d='M10.71 5.05A16 16 0 0 1 22.58 9'/><path d='M1.42 9a15.91 15.91 0 0 1 4.7-2.88'/><path d='M8.53 16.11a6 6 0 0 1 6.95 0'/><line x1='12' y1='20' x2='12.01' y2='20'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='1' y1='1' x2='23' y2='23'/><path d='M16.72 11.06A10.94 10.94 0 0 1 19 12.55'/><path d='M5 12.55a10.94 10.94 0 0 1 5.17-2.39'/><path d='M10.71 5.05A16 16 0 0 1 22.58 9'/><path d='M1.42 9a15.91 15.91 0 0 1 4.7-2.88'/><path d='M8.53 16.11a6 6 0 0 1 6.95 0'/><line x1='12' y1='20' x2='12.01' y2='20'/></svg>") center/contain no-repeat;opacity:.55}

.offline-state{padding:80px 0;text-align:center;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:14px}
.offline-state .ico{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--line);color:var(--fg)}
.offline-state .ico svg{width:32px;height:32px}
.offline-state h2{font-size:20px;font-weight:700;color:var(--fg);margin:6px 0 0;letter-spacing:-.01em}
.offline-state p{font-size:14px;max-width:320px;margin:0;line-height:1.5}
.offline-state .retry{margin-top:6px;padding:9px 18px;border-radius:999px;background:rgb(var(--accent));color:#fff;border:0;font:inherit;font-weight:600;font-size:13.5px;cursor:pointer;letter-spacing:.01em}
.offline-state .retry:hover{filter:brightness(1.05)}
