:root{--spc-orange:#f79c00;--spc-orange-ink:#b96f00;--spc-orange-soft:#fff1dc;--spc-green:#27df11;--spc-green-ink:#1a8b0c;--spc-green-soft:#e2fadf;--spc-red:#ea0710;--spc-red-ink:#c00610;--spc-red-soft:#fde3e4;--spc-amber:#ffc000;--spc-amber-ink:#a87c00;--spc-amber-soft:#fff4d1;--spc-magenta:#e5007f;--spc-magenta-ink:#b30063;--spc-magenta-soft:#ffe3f1;--spc-blue:#0247db;--spc-blue-ink:#0239ad;--spc-blue-soft:#dee8ff;--spectrum:var(--spc-orange),var(--spc-green),var(--spc-red),var(--spc-amber),var(--spc-magenta),var(--spc-blue);--spectrum-gradient:linear-gradient(90deg,var(--spc-orange) 0%,var(--spc-green) 20%,var(--spc-red) 40%,var(--spc-amber) 60%,var(--spc-magenta) 80%,var(--spc-blue) 100%);--font-display:var(--font-space-grotesk),"Segoe UI",system-ui,-apple-system,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;--font-body:var(--font-hanken),system-ui,-apple-system,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;--font-mono:var(--font-jetbrains),"SFMono-Regular",Menlo,Consolas,"Fira Code","PingFang SC","Hiragino Sans GB","Microsoft YaHei",monospace;--fs-display:clamp(2.6rem,1.6rem + 4vw,4rem);--fs-h1:clamp(2.1rem,1.5rem + 2.4vw,3rem);--fs-h2:clamp(1.6rem,1.25rem + 1.4vw,2.1rem);--fs-h3:1.45rem;--fs-h4:1.2rem;--fs-body:1.1875rem;--fs-small:0.9375rem;--fs-micro:0.8125rem;--fs-code:0.9375rem;--lh-tight:1.12;--lh-heading:1.22;--lh-body:1.72;--ls-display:-0.02em;--ls-eyebrow:0.14em;--r-xs:6px;--r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-pill:999px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:24px;--sp-6:32px;--sp-7:48px;--sp-8:64px;--sp-9:96px;--measure:68ch;--page-max:1180px;--ease:cubic-bezier(0.22,0.61,0.36,1);--ease-out:cubic-bezier(0.16,1,0.3,1);--dur-fast:130ms;--dur:220ms;--dur-slow:420ms;--feed-gap:var(--sp-5);--card-pad:var(--sp-5);--shell-padding-x:var(--sp-5)}:root,:root[data-theme=light]{color-scheme:light;--bg:#fffcfd;--bg-wash:radial-gradient(1100px 620px at 12% -8%,#ffe9f2 0%,transparent 60%),radial-gradient(900px 520px at 100% 0%,#fff1e4 0%,transparent 55%),#fffbfc;--bg-pink:#ffedf4;--surface-1:hsla(0,0%,100%,.62);--surface-2:hsla(0,0%,100%,.8);--surface-solid:#fff;--surface-sunken:rgba(232,218,226,.34);--fg-1:#1c151b;--fg-2:#5e5560;--fg-3:#8c8290;--fg-on-accent:#fff;--accent:#d6006f;--accent-hover:#b30063;--accent-soft:rgba(229,0,127,.1);--accent-ring:rgba(229,0,127,.3);--link:#c00670;--border:transparent;--border-hair:rgba(28,21,27,.06);--divider:rgba(28,21,27,.08);--shadow-sm:0 1px 2px rgba(120,30,70,.06);--shadow-md:0 6px 22px -8px rgba(150,40,90,.16),0 2px 6px rgba(120,30,70,.05);--shadow-lg:0 22px 60px -18px rgba(150,40,90,.24),0 6px 18px rgba(120,30,70,.07);--selection:rgba(229,0,127,.16);--background:var(--bg);--surface:var(--surface-1);--foreground:var(--fg-1);--muted:var(--fg-2);--accent-2:var(--spc-magenta);--tag-bg:var(--accent-soft);--tag-fg:var(--accent-hover)}:root[data-theme=dark]{color-scheme:dark;--bg:#07090f;--bg-wash:radial-gradient(1100px 640px at 10% -10%,#0e2244 0%,transparent 60%),radial-gradient(900px 520px at 100% 0%,#11183a 0%,transparent 55%),#07090f;--bg-pink:#0e1a33;--surface-1:rgba(124,170,255,.055);--surface-2:rgba(132,176,255,.1);--surface-solid:#0e131f;--surface-sunken:rgba(8,12,22,.55);--fg-1:#e9f0ff;--fg-2:#a6b4ce;--fg-3:#6f7c96;--fg-on-accent:#061226;--accent:#5b9dff;--accent-hover:#82b4ff;--accent-soft:rgba(91,157,255,.14);--accent-ring:rgba(91,157,255,.36);--link:#76abff;--border:transparent;--border-hair:rgba(160,190,255,.08);--divider:rgba(160,190,255,.1);--shadow-sm:0 1px 2px rgba(0,0,0,.5);--shadow-md:0 8px 28px -10px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 28px 70px -20px rgba(0,0,0,.7),0 8px 22px rgba(0,0,0,.5);--spc-green-ink:#5be84a;--spc-blue-ink:#76abff;--spc-red-ink:#ff6168;--spc-orange-soft:rgba(247,156,0,.16);--spc-green-soft:rgba(39,223,17,.14);--spc-red-soft:rgba(255,97,104,.16);--spc-amber-soft:rgba(255,192,0,.15);--spc-magenta-soft:rgba(229,0,127,.18);--spc-blue-soft:rgba(91,157,255,.16);--selection:rgba(91,157,255,.24);--background:var(--bg);--surface:var(--surface-1);--foreground:var(--fg-1);--muted:var(--fg-2);--accent-2:var(--spc-blue);--tag-bg:var(--accent-soft);--tag-fg:var(--accent-hover)}@media (prefers-color-scheme:dark){:root:not([data-theme]){color-scheme:dark;--bg:#07090f;--bg-wash:radial-gradient(1100px 640px at 10% -10%,#0e2244 0%,transparent 60%),radial-gradient(900px 520px at 100% 0%,#11183a 0%,transparent 55%),#07090f;--bg-pink:#0e1a33;--surface-1:rgba(124,170,255,.055);--surface-2:rgba(132,176,255,.1);--surface-solid:#0e131f;--surface-sunken:rgba(8,12,22,.55);--fg-1:#e9f0ff;--fg-2:#a6b4ce;--fg-3:#6f7c96;--fg-on-accent:#061226;--accent:#5b9dff;--accent-hover:#82b4ff;--accent-soft:rgba(91,157,255,.14);--accent-ring:rgba(91,157,255,.36);--link:#76abff;--border:transparent;--border-hair:rgba(160,190,255,.08);--divider:rgba(160,190,255,.1);--shadow-sm:0 1px 2px rgba(0,0,0,.5);--shadow-md:0 8px 28px -10px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 28px 70px -20px rgba(0,0,0,.7),0 8px 22px rgba(0,0,0,.5);--spc-green-ink:#5be84a;--spc-blue-ink:#76abff;--spc-red-ink:#ff6168;--spc-orange-soft:rgba(247,156,0,.16);--spc-green-soft:rgba(39,223,17,.14);--spc-red-soft:rgba(255,97,104,.16);--spc-amber-soft:rgba(255,192,0,.15);--spc-magenta-soft:rgba(229,0,127,.18);--spc-blue-soft:rgba(91,157,255,.16);--selection:rgba(91,157,255,.24);--background:var(--bg);--surface:var(--surface-1);--foreground:var(--fg-1);--muted:var(--fg-2);--accent-2:var(--spc-blue);--tag-bg:var(--accent-soft);--tag-fg:var(--accent-hover)}}*{box-sizing:border-box}body,html{margin:0;padding:0}:is(button,a,[role=button],summary):focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}body{background:var(--bg-wash);background-attachment:fixed;color:var(--fg-1);font-family:var(--font-body);font-size:16px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"palt" 1;position:relative}img{max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:var(--ls-display)}a{color:var(--link);text-decoration:none;transition:color var(--dur) var(--ease)}a:hover{color:var(--accent-hover)}::-moz-selection{background:var(--selection)}::selection{background:var(--selection)}button{font-family:var(--font-display);cursor:pointer;border:none;background:none}.hdr{position:sticky;top:0;z-index:50;padding:var(--sp-3) var(--sp-5);background:var(--surface-2);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);box-shadow:var(--shadow-sm)}.hdr,.hdr-inner{display:flex;align-items:center}.hdr-inner{width:100%;max-width:var(--page-max);margin:0 auto;gap:var(--sp-5)}.hdr-logo{height:34px;width:auto;cursor:pointer;display:block}.hdr-nav{display:flex;align-items:center;gap:var(--sp-2);margin-left:var(--sp-4)}.hdr-spacer{flex:1}.hdr-actions{display:flex;align-items:center;gap:var(--sp-2)}.nav-link{font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--fg-2);padding:8px 14px;border-radius:var(--r-pill);background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-position:50% 100%;background-size:calc(100% - 28px) 2px;transition:color var(--dur) var(--ease),background-color var(--dur) var(--ease),background-size var(--dur) var(--ease)}.nav-link:hover{color:var(--fg-1);background-color:var(--surface-1);text-decoration:none}.nav-link.active{color:var(--accent)}.icon-btn{width:40px;height:40px;transition:all var(--dur) var(--ease)}.icon-btn:active{transform:scale(.94)}@media (max-width:640px){.hdr-nav{display:none}}.site-shell{min-height:100vh;display:flex;flex-direction:column}.main-container{max-width:var(--page-max);width:100%;margin:0 auto;padding:var(--sp-7) var(--sp-5) var(--sp-9);flex:1}.site-hero{position:relative;width:100%;margin:0;height:clamp(300px,34vw,440px);overflow:hidden;box-shadow:var(--shadow-md);display:flex;align-items:flex-end;justify-content:flex-start;text-align:left}.site-hero.compact{height:clamp(180px,20vw,240px)}.site-hero-img{position:absolute;inset:0;background-size:cover;background-position:center 38%}.site-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,9,22,.28),rgba(14,9,22,.3) 45%,rgba(14,9,22,.58))}.site-hero-edge{position:absolute;top:0;left:0;right:0;height:4px;z-index:2;background:var(--accent)}.site-hero-text{position:relative;z-index:3;color:#fff;width:100%;max-width:var(--page-max);margin:0 auto;padding:var(--sp-7) var(--sp-5)}.site-hero-text h1{font-family:var(--font-display);font-weight:700;color:#fff;margin:0;font-size:clamp(2.8rem,1.8rem + 4vw,4.6rem);letter-spacing:-.03em;line-height:1}.site-hero-text .lede{font-family:var(--font-body);color:hsla(0,0%,100%,.92);font-size:clamp(1rem,.85rem + .6vw,1.3rem);margin:var(--sp-4) 0 0;line-height:1.5}.site-hero.compact .site-hero-text h1{font-size:clamp(2rem,1.4rem + 2.4vw,3rem)}.site-hero.compact .site-hero-text .lede{display:none}@media (max-width:640px){.site-hero{height:clamp(240px,52vw,320px)}.site-hero.compact{height:clamp(150px,34vw,200px)}.site-hero-text{padding:var(--sp-5)}}.section-heading{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-5)}.section-heading h1{font-size:var(--fs-h1);margin:0;font-weight:700;color:var(--fg-1)}.section-heading h2{font-size:var(--fs-h2);margin:0;font-weight:600;color:var(--fg-1)}.section-heading .meta,.section-heading .sub{font-family:var(--font-mono);font-size:13px;color:var(--fg-3)}.section-heading .spacer{flex:1}.space-y-6>*+*{margin-top:var(--sp-5)}.list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--feed-gap)}.list-view{gap:var(--feed-gap)}.feed-card,.list-view{display:flex;flex-direction:column}.feed-card{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;border:1px solid var(--border);transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.feed-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.feed-card .banner{display:block;height:170px;position:relative;overflow:hidden}.feed-card .banner .art,.feed-card .banner img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.feed-card .body{padding:var(--card-pad);display:flex;flex-direction:column;gap:var(--sp-2);flex:1}.feed-card h3{margin:2px 0 0;font-size:1.3rem;line-height:1.25;color:var(--fg-1)}.feed-card h3 a{color:inherit}.feed-card h3 a:hover{color:var(--accent)}.feed-card .excerpt{margin:0;color:var(--fg-2);font-size:16px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.feed-card .meta{font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.feed-card .read-more{margin-top:auto;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--accent)}.feed-card .read-more a{color:inherit}.list-row{display:grid;grid-template-columns:160px 1fr;gap:var(--sp-5);align-items:stretch;background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.list-row:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.list-row .banner{display:block;position:relative;overflow:hidden;min-height:120px}.list-row .banner .art,.list-row .banner img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.list-row .body{padding:var(--card-pad) var(--card-pad) var(--card-pad) 0;display:flex;flex-direction:column;gap:var(--sp-2)}.list-row h3{margin:0;font-size:1.25rem;color:var(--fg-1)}.list-row h3 a{color:inherit}.list-row h3 a:hover{color:var(--accent)}.list-row .excerpt{margin:0;color:var(--fg-2);font-size:15px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.list-row .meta{font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}@media (max-width:540px){.list-row{grid-template-columns:1fr}.list-row .banner{height:150px}.list-row .body{padding:0 var(--card-pad) var(--card-pad)}}.list-row.no-banner{grid-template-columns:1fr}.list-row.no-banner .body{padding:var(--card-pad)}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{font-family:var(--font-mono);font-size:12px;color:var(--fg-2);background:var(--surface-2);padding:4px 11px;border-radius:var(--r-pill);cursor:pointer;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.tag-chip:hover{color:var(--accent);background:var(--accent-soft);text-decoration:none}.tag-chip.active{background:var(--accent);color:var(--fg-on-accent)}.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--fg-2);background:var(--surface-2);padding:4px 11px;border-radius:var(--r-pill);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.pill.clickable{cursor:pointer}.pill.clickable:hover{color:var(--accent);background:var(--accent-soft);text-decoration:none}.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.seg{background:var(--surface-2);padding:3px;gap:2px}.seg,.seg button{display:inline-flex;border-radius:var(--r-pill)}.seg button{padding:6px 13px;color:var(--fg-2);background:none;border:none;font-family:var(--font-display);font-weight:500;font-size:13px;align-items:center;gap:6px;transition:all var(--dur) var(--ease)}.button,.seg button.active{background:var(--accent);color:var(--fg-on-accent);box-shadow:var(--shadow-sm)}.button{font-family:var(--font-display);font-weight:600;font-size:14px;padding:9px 16px;border-radius:var(--r-sm);border:none;white-space:nowrap;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:transform var(--dur-fast) var(--ease),filter var(--dur) var(--ease),background var(--dur) var(--ease)}.button:hover{filter:brightness(1.06);transform:translateY(-1px);text-decoration:none}.button:active{transform:scale(.98)}.button.primary{background:var(--accent);color:var(--fg-on-accent)}.button.ghost{background:var(--surface-2);color:var(--fg-1);box-shadow:none}.button.ghost:hover{background:var(--surface-1);color:var(--accent);filter:none}.button.danger{background:var(--spc-red-soft);color:var(--spc-red-ink);box-shadow:none}.button.danger:hover{filter:brightness(.97)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--sp-4)}.field label,.field>span{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--fg-2)}.input{width:100%;font-family:var(--font-body);font-size:15px;color:var(--fg-1);background:var(--surface-sunken);border:1px solid transparent;border-radius:var(--r-sm);padding:11px 14px;outline:none;transition:box-shadow var(--dur) var(--ease)}.input:focus{box-shadow:0 0 0 3px var(--accent-ring)}textarea.input{resize:vertical;line-height:1.6}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--sp-4);margin-top:var(--sp-4)}.form-grid label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-display);font-weight:500;font-size:13px;color:var(--fg-2)}.full-width{grid-column:1/-1}.card{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-6);border:1px solid var(--border);position:relative}.card+.card{margin-top:var(--sp-5)}.meta{color:var(--fg-3);font-family:var(--font-mono);font-size:.85rem;line-height:1.5}.notice{padding:var(--sp-4);border-radius:var(--r-md);background:var(--accent-soft);color:var(--fg-1);font-family:var(--font-body)}.empty-note{color:var(--fg-3);font-family:var(--font-mono)}.page-narrow{max-width:820px;margin:0 auto}.spacer-row{display:flex;gap:var(--sp-3);flex-wrap:wrap;align-items:center}.banner{width:100%;border-radius:var(--r-lg);margin-bottom:var(--sp-4);display:block}.banner,.banner-preview{box-shadow:var(--shadow-sm)}.banner-preview{border-radius:var(--r-md);overflow:hidden;background:var(--surface-sunken)}.banner-preview img{display:block;width:100%;height:auto}.archive{max-width:820px;margin:0 auto}.archive-year{font-family:var(--font-display);font-weight:700;font-size:var(--fs-h2);color:var(--fg-3);margin:var(--sp-7) 0 var(--sp-3);display:flex;align-items:baseline;gap:var(--sp-3)}.archive-year .count{font-family:var(--font-mono);font-size:13px;color:var(--fg-3);font-weight:400}.archive-row{display:grid;grid-template-columns:96px 1fr auto;gap:var(--sp-4);align-items:baseline;padding:var(--sp-3);border-radius:var(--r-sm);cursor:pointer;transition:background var(--dur) var(--ease)}.archive-row:hover{background:var(--surface-1)}.archive-row+.archive-row{border-top:1px solid var(--divider)}.archive-row .date{font-family:var(--font-mono);font-size:13px;color:var(--fg-3)}.archive-row .title{font-family:var(--font-display);font-weight:500;font-size:1.1rem;color:var(--fg-1)}.archive-row .title a{color:inherit}.archive-row:hover .title,.archive-row:hover .title a{color:var(--accent)}.archive-row .views{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);white-space:nowrap}.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--sp-4)}.cat-card{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-5);cursor:pointer;position:relative;overflow:hidden;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.cat-card .count{font-family:var(--font-display);font-weight:700;font-size:2.4rem;color:var(--accent);line-height:1}.cat-card .name{font-family:var(--font-mono);font-size:14px;color:var(--fg-1);margin-top:var(--sp-2)}.cat-card .unit{font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.friend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--feed-gap)}.friend-card{display:flex;align-items:center;gap:var(--sp-4);background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--card-pad);cursor:pointer;overflow:hidden;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.friend-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);text-decoration:none}.friend-avatar{flex:none;width:52px;height:52px;border-radius:var(--r-pill);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);font-family:var(--font-display);font-weight:700;font-size:22px}.friend-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.friend-body{min-width:0}.friend-name{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--fg-1)}.friend-card:hover .friend-name{color:var(--accent)}.friend-desc{margin:2px 0 0;color:var(--fg-2);font-size:14px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.song-list{list-style:none;margin:0;display:flex;flex-direction:column;gap:0;background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-2)}.song-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);border-radius:var(--r-md);padding:var(--sp-4);transition:background var(--dur) var(--ease)}.song-row:hover{background:var(--surface-sunken)}.song-main{display:flex;align-items:center;gap:var(--sp-4);min-width:0}.song-num{flex:none;min-width:2ch;font-family:var(--font-mono);font-size:var(--fs-micro);color:var(--fg-3);text-align:right;transition:color var(--dur) var(--ease)}.song-row:hover .song-num{color:var(--accent)}.song-info{min-width:0}.song-title{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--fg-1)}.song-meta{margin-top:2px;color:var(--fg-2);font-size:14px;display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.song-sep{color:var(--fg-3)}.song-play{flex:none;display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent);font-size:14px;font-weight:600;white-space:nowrap;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.song-play:hover{background:var(--accent);color:#fff;text-decoration:none}.song-sort-bar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--surface-sunken)}.song-sort-bar+.song-list{border-radius:0 0 var(--r-lg) var(--r-lg)}.song-sort-label{font-size:13px;color:var(--fg-3)}.song-sort-btn{border:none;background:transparent;cursor:pointer;padding:4px 12px;border-radius:var(--r-pill);font-size:14px;font-weight:600;color:var(--fg-2);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.song-sort-btn:hover{background:var(--surface-sunken);color:var(--fg-1)}.song-sort-btn.active{background:var(--accent-soft);color:var(--accent)}.song-sort-btn.reset{margin-left:auto;font-weight:500;color:var(--fg-3)}.song-link{background:none;padding:0;cursor:pointer;font:inherit;color:inherit;border:none;border-bottom:1px dashed transparent;transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease)}.song-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.song-detail-overlay{position:fixed;inset:0;z-index:200;background:color-mix(in srgb,var(--bg) 65%,transparent);backdrop-filter:blur(8px);display:flex;align-items:stretch;justify-content:center;padding:var(--sp-4);animation:fade-in .18s var(--ease)}.song-detail-card{width:min(720px,100%);background:var(--surface-1);backdrop-filter:blur(20px);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--sp-6);overflow-y:auto;display:flex;flex-direction:column;gap:var(--sp-4)}.song-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4)}.song-detail-kind{margin:0;font-size:var(--fs-micro);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.song-detail-title{margin:4px 0 0;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--fg-1)}.song-detail-count{margin:4px 0 0;font-size:14px;color:var(--fg-3)}.song-detail-close{flex:none;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;background:var(--surface-sunken);color:var(--fg-2);font-size:16px;line-height:1;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.song-detail-close:hover{background:var(--accent);color:#fff}.song-detail-note{margin:0;padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);background:var(--accent-soft);color:var(--fg-2);font-size:13.5px;line-height:1.6}.song-detail-list{box-shadow:none;background:var(--surface-sunken)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.quote-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--feed-gap)}.quote-card{position:relative;background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:0;margin:0;border:none;overflow:hidden;display:flex;flex-direction:column;border-top:3px solid var(--quote-accent,var(--accent));transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.quote-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.quote-card{cursor:pointer}.quote-card-image{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;display:block;border-radius:var(--r-lg) var(--r-lg) 0 0}.quote-body{padding:var(--card-pad) var(--card-pad) calc(var(--card-pad) * .75);display:flex;flex-direction:column;gap:var(--sp-3);flex:1}.quote-mark{display:block;font-family:var(--font-display);font-weight:700;font-size:4.25rem;line-height:.78;color:var(--quote-accent,var(--accent));opacity:.2;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.quote-content-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;padding:0;margin:0;text-align:left;cursor:pointer;width:100%;display:block;position:relative}.quote-content{margin:0;font-size:var(--fs-body);line-height:var(--lh-body);color:var(--fg-1);white-space:pre-wrap;overflow-wrap:break-word;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:6;overflow:hidden;max-height:calc(var(--lh-body) * 6em)}.quote-expand-hint{display:none;margin-top:var(--sp-2);font-family:var(--font-mono);font-size:var(--fs-micro);line-height:1;color:var(--quote-accent,var(--accent))}.quote-content-button.is-clamped .quote-expand-hint{display:inline-block}.quote-content-button:hover .quote-expand-hint{text-decoration:underline}.quote-footer{margin-top:auto;display:flex;flex-direction:column;gap:2px;font-family:var(--font-mono);font-size:var(--fs-micro);color:var(--fg-3);line-height:1.4}.quote-source{color:var(--fg-2)}.quote-tagbar{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-5)}.quote-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;background:var(--surface-2);color:var(--fg-2);font-size:var(--fs-micro);line-height:1;padding:7px 14px;border-radius:var(--r-pill);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.quote-chip:hover{color:var(--fg-1);box-shadow:var(--shadow-sm)}.quote-chip.active{background:var(--accent);border-color:transparent;color:var(--fg-on-accent);box-shadow:0 0 0 3px var(--accent-ring)}.chip-dot{display:inline-block;width:8px;height:8px;border-radius:var(--r-pill);background:var(--chip-hue,var(--accent));flex:none}.quote-chip.active .chip-dot{background:var(--fg-on-accent)}.quote-tags{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.quote-tag{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;font-family:var(--font-mono);font-size:var(--fs-micro);line-height:1;color:var(--accent);background:var(--accent-soft);padding:4px 10px;border-radius:var(--r-pill);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.quote-tag:hover{background:var(--accent);color:var(--fg-on-accent)}.quote-card[data-quote-color=orange],.quote-modal-card[data-quote-color=orange]{--quote-accent:var(--spc-orange-ink);--quote-accent-soft:var(--spc-orange-soft)}.quote-card[data-quote-color=green],.quote-modal-card[data-quote-color=green]{--quote-accent:var(--spc-green-ink);--quote-accent-soft:var(--spc-green-soft)}.quote-card[data-quote-color=red],.quote-modal-card[data-quote-color=red]{--quote-accent:var(--spc-red-ink);--quote-accent-soft:var(--spc-red-soft)}.quote-card[data-quote-color=amber],.quote-modal-card[data-quote-color=amber]{--quote-accent:var(--spc-amber-ink);--quote-accent-soft:var(--spc-amber-soft)}.quote-card[data-quote-color=magenta],.quote-modal-card[data-quote-color=magenta]{--quote-accent:var(--spc-magenta-ink);--quote-accent-soft:var(--spc-magenta-soft)}.quote-card[data-quote-color=blue],.quote-modal-card[data-quote-color=blue]{--quote-accent:var(--spc-blue-ink);--quote-accent-soft:var(--spc-blue-soft)}.quote-card .quote-tag,.quote-modal-card .quote-tag{color:var(--quote-accent,var(--accent));background:var(--quote-accent-soft,var(--accent-soft))}.quote-card .quote-tag:hover,.quote-modal-card .quote-tag:hover{background:var(--quote-accent,var(--accent));color:#fff}.quote-modal-overlay{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:var(--sp-5);background:rgba(10,8,14,.55);backdrop-filter:blur(6px);animation:quote-modal-fade var(--dur) var(--ease)}.quote-modal-card{position:relative;width:min(720px,100%);max-height:min(86vh,900px);overflow-y:auto;margin:0;border:none;background:var(--surface-solid);border-radius:var(--r-xl);border-top:4px solid var(--quote-accent,var(--accent));box-shadow:var(--shadow-lg);animation:quote-modal-pop var(--dur) var(--ease-out)}.quote-modal-close{position:absolute;top:var(--sp-3);right:var(--sp-3);z-index:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;color:var(--fg-1);background:var(--surface-solid);box-shadow:var(--shadow-md);transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}.quote-modal-close:hover{color:var(--accent);background:var(--surface-solid)}.quote-modal-image{width:100%;max-height:420px;height:auto;-o-object-fit:contain;object-fit:contain;display:block;background:var(--surface-sunken);border-radius:var(--r-xl) var(--r-xl) 0 0}.quote-modal-body{padding:var(--sp-6) var(--card-pad);display:flex;flex-direction:column;gap:var(--sp-3)}.quote-modal-content{margin:0;font-size:var(--fs-body);line-height:var(--lh-body);color:var(--fg-1);white-space:pre-wrap;overflow-wrap:break-word}@keyframes quote-modal-fade{0%{opacity:0}to{opacity:1}}@keyframes quote-modal-pop{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:540px){.quote-grid{grid-template-columns:1fr}}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-4)}.gallery-tile{position:relative;display:block;padding:0;border:none;cursor:zoom-in;background:var(--surface-1);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:1/1;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease)}.gallery-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.gallery-tile:focus-visible{box-shadow:0 0 0 3px var(--accent-ring),var(--shadow-md)}.gallery-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.gallery-tile-cap{position:absolute;left:0;right:0;bottom:0;padding:22px 12px 10px;font-family:var(--font-mono);font-size:var(--fs-micro);color:#fff;text-align:left;background:linear-gradient(180deg,transparent,rgba(0,0,0,.66));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;transition:opacity var(--dur) var(--ease)}.gallery-tile:hover .gallery-tile-cap{opacity:1}@media (hover:none){.gallery-tile-cap{opacity:1}}@media (max-width:540px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--sp-2)}}.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,10,18,.92);backdrop-filter:blur(6px);justify-content:center;padding:var(--sp-6);animation:fadeUp var(--dur) var(--ease-out) both}.lightbox,.lightbox-figure{display:flex;align-items:center}.lightbox-figure{margin:0;max-width:min(92vw,1100px);max-height:88vh;flex-direction:column}.lightbox-figure img{max-width:100%;max-height:80vh;-o-object-fit:contain;object-fit:contain;border-radius:var(--r-md);box-shadow:var(--shadow-lg);background:#000}.lightbox-cap{margin-top:var(--sp-3);text-align:center;color:#fff;display:flex;flex-direction:column;gap:4px;max-width:70ch}.lightbox-cap strong{font-family:var(--font-display);font-size:1.05rem}.lightbox-cap span{font-family:var(--font-body);font-size:14px;color:hsla(0,0%,100%,.78)}.lightbox-close{position:fixed;top:18px;right:22px;width:44px;height:44px;border:none;border-radius:var(--r-pill);cursor:pointer;background:hsla(0,0%,100%,.12);color:#fff;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease)}.lightbox-close:hover{background:hsla(0,0%,100%,.24)}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:52px;height:52px;border:none;border-radius:var(--r-pill);cursor:pointer;background:hsla(0,0%,100%,.12);color:#fff;font-size:34px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease)}.lightbox-nav:hover{background:hsla(0,0%,100%,.24)}.lightbox-nav.prev{left:18px}.lightbox-nav.next{right:18px}@media (max-width:540px){.lightbox-nav{width:42px;height:42px;font-size:26px}.lightbox-nav.prev{left:6px}.lightbox-nav.next{right:6px}}.search-wrap{max-width:720px;margin:0 auto}.search-field{display:flex;align-items:center;gap:var(--sp-3);background:var(--surface-2);backdrop-filter:blur(10px);border-radius:var(--r-pill);padding:var(--sp-3) var(--sp-5);box-shadow:var(--shadow-sm)}.search-field input{flex:1;min-width:0;border:none;background:none;outline:none;font-family:var(--font-body);font-size:1.15rem;color:var(--fg-1)}.search-results{margin-top:var(--sp-5);display:flex;flex-direction:column;gap:4px}.search-result{padding:var(--sp-4);border-radius:var(--r-md);cursor:pointer;transition:background var(--dur) var(--ease)}.search-result:hover{background:var(--surface-1)}.search-result h4{margin:0 0 4px;font-size:1.1rem;color:var(--fg-1)}.search-result h4 a{color:inherit}.search-result p{margin:0;font-size:15px;color:var(--fg-2)}.search-result .meta{margin-top:6px}.search-empty{text-align:center;color:var(--fg-3);font-family:var(--font-mono);padding:var(--sp-7) 0}mark{background:var(--accent-soft);color:var(--accent-hover);padding:0 2px;border-radius:3px}.search-form{display:flex;align-items:center;gap:var(--sp-3)}.search-buttons{display:flex;gap:var(--sp-2);flex-shrink:0}.post-page{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:var(--sp-7);align-items:start}.post-body{max-width:100%;min-width:0}.post-content{min-width:0;overflow-wrap:anywhere}.post-banner{border-radius:var(--r-lg);overflow:hidden;height:320px;position:relative;margin:0 0 var(--sp-6);box-shadow:var(--shadow-md)}.post-banner .art,.post-banner img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.post-banner .fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--fg-3)}.post-aside{position:sticky;top:100px}.post-meta{font-size:13px;color:var(--fg-3);display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:var(--sp-3) 0 var(--sp-2)}.post-meta,.post-meta .tag{font-family:var(--font-mono)}.post-meta .tag{color:var(--fg-2);background:var(--surface-2);padding:2px 9px;border-radius:var(--r-pill);cursor:pointer}.post-meta .tag:hover{color:var(--accent);background:var(--accent-soft)}.article-title{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;font-size:clamp(2.1rem,1.5rem + 2.2vw,3rem);line-height:1.08;margin:var(--sp-3) 0;text-wrap:balance}.back-btn,.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--fg-2);margin-bottom:var(--sp-5);transition:color var(--dur) var(--ease)}.back-btn:hover,.back-link:hover{color:var(--accent);text-decoration:none}@media (max-width:1000px){.post-page{grid-template-columns:1fr}.post-aside{display:none}}.tag{display:inline-block;font-family:var(--font-mono);font-size:.8rem;color:var(--fg-2);background:var(--surface-2);padding:3px 10px;border-radius:var(--r-pill);margin-right:6px;margin-top:6px;transition:all var(--dur) var(--ease)}.tag:hover{color:var(--accent);background:var(--accent-soft);text-decoration:none}.toc{position:sticky;top:100px;font-family:var(--font-display)}.toc h3{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);margin:0 0 var(--sp-3);font-weight:600}.toc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.toc li{font-size:14px;color:var(--fg-2);border-left:2px solid var(--divider)}.toc li a{display:block;color:inherit;padding:6px 0 6px 12px;transition:color var(--dur) var(--ease)}.toc li a:hover{color:var(--fg-1);text-decoration:none}.toc li.toc-active{border-left-color:var(--accent)}.toc li.toc-active>a{color:var(--accent)}.toc li.level-3 a{padding-left:24px}.toc li.level-4 a{padding-left:36px}.toc li.level-5 a{padding-left:48px}.toc li.level-6 a{padding-left:60px}.back-to-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;padding:0;border-radius:var(--r-pill);border:none;background:var(--surface-2);backdrop-filter:blur(12px);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;color:var(--fg-2);z-index:60;transition:color var(--dur) var(--ease),transform var(--dur) var(--ease)}.back-to-top:hover{color:var(--accent);transform:translateY(-2px);text-decoration:none}.preview-body,.prose,article.card{font-family:var(--font-body);background:none;box-shadow:none;backdrop-filter:none;border:none;padding:0;line-height:var(--lh-body);color:var(--fg-1)}.preview-body h1,.prose h1,article.card h1{font-family:var(--font-display);font-size:var(--fs-h1);font-weight:700;line-height:var(--lh-heading);margin:var(--sp-7) 0 var(--sp-4);color:var(--fg-1)}article.card h1:first-child{margin-top:0}.preview-body h2,.prose h2,article.card h2{font-size:var(--fs-h2);letter-spacing:-.015em;margin:var(--sp-7) 0 var(--sp-4)}.preview-body h2,.preview-body h3,.prose h2,.prose h3,article.card h2,article.card h3{font-family:var(--font-display);font-weight:600;scroll-margin-top:90px;color:var(--fg-1)}.preview-body h3,.prose h3,article.card h3{font-size:var(--fs-h3);margin:var(--sp-6) 0 var(--sp-3)}.preview-body h4,.prose h4,article.card h4{font-family:var(--font-display);font-size:var(--fs-h4);font-weight:500;margin:var(--sp-5) 0 var(--sp-2);color:var(--fg-1)}.preview-body p,.prose p,article.card p{font-size:var(--fs-body);line-height:var(--lh-body);margin:0 0 var(--sp-5);color:var(--fg-1);max-width:var(--measure)}.preview-body ol,.preview-body ul,.prose ol,.prose ul,article.card ol,article.card ul{font-size:var(--fs-body);line-height:1.6;color:var(--fg-1);padding-left:1.3em;max-width:var(--measure)}.preview-body li,.prose li,article.card li{margin:0 0 8px}.preview-body img,.prose img,article.card img{border-radius:var(--r-lg);box-shadow:var(--shadow-md);margin:var(--sp-5) auto;display:block;max-width:100%;height:auto}.preview-body blockquote,.prose blockquote,article.card blockquote{margin:var(--sp-5) 0;padding:var(--sp-2) var(--sp-5);border-left:3px solid var(--accent);background:none;color:var(--fg-2);font-style:normal;font-size:1.25rem;max-width:var(--measure)}.preview-body blockquote p,.prose blockquote p,article.card blockquote p{margin:.4rem 0;font-size:inherit}.preview-body hr,.prose hr,article.card hr{border:none;height:3px;margin:var(--sp-7) 0;max-width:var(--measure);background:var(--accent);border-radius:var(--r-pill);opacity:.85}.preview-body table,.prose table,article.card table{width:100%;border-collapse:collapse;font-size:var(--fs-small);margin:var(--sp-5) 0}.preview-body td,.preview-body th,.prose td,.prose th,article.card td,article.card th{padding:var(--sp-3) var(--sp-4);text-align:left;border:none}.preview-body thead th,.prose thead th,article.card thead th{font-family:var(--font-display);color:var(--fg-2);font-weight:600;border-bottom:2px solid var(--divider)}.preview-body tbody tr+tr td,.prose tbody tr+tr td,article.card tbody tr+tr td{border-top:1px solid var(--divider)}code{font-family:var(--font-mono);font-size:var(--fs-code)}.preview-body :not(pre)>code,.prose :not(pre)>code,article.card :not(pre)>code{background:var(--accent-soft);color:var(--accent-hover);padding:.12em .42em;border-radius:var(--r-xs);font-size:.9em}pre{font-family:var(--font-mono);font-size:var(--fs-code);line-height:1.6;background:var(--surface-sunken);color:var(--fg-1);padding:var(--sp-5);border-radius:var(--r-md);overflow-x:auto;margin:var(--sp-5) 0;border:none;box-shadow:none;max-width:100%}pre code{background:none;color:inherit;padding:0;font-size:inherit}kbd{font-family:var(--font-mono);font-size:.85em;background:var(--surface-2);color:var(--fg-1);padding:.18em .5em;border-radius:var(--r-xs);box-shadow:var(--shadow-sm)}.code-block-wrapper{position:relative;margin:var(--sp-5) 0;border-radius:var(--r-md);overflow:hidden;background:var(--surface-sunken)}.code-block-wrapper pre{margin:0;border-radius:0}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:var(--surface-sunken);border-bottom:1px solid var(--border-hair)}.code-language{text-transform:uppercase;letter-spacing:.05em;color:var(--fg-3);font-weight:600}.code-copy-button,.code-language{font-family:var(--font-mono);font-size:11px}.code-copy-button{padding:4px 10px;border-radius:var(--r-xs);background:var(--accent-soft);color:var(--accent-hover);border:none;cursor:pointer;transition:filter var(--dur) var(--ease)}.code-copy-button:hover{filter:brightness(1.05)}.code-copy-button:active{transform:scale(.95)}.hljs{background:transparent;color:var(--fg-1)}.hljs-comment,.hljs-quote{color:var(--fg-3);font-style:italic}.hljs-keyword,.hljs-link,.hljs-literal,.hljs-section,.hljs-selector-tag{color:var(--spc-magenta-ink)}.hljs-addition,.hljs-attr,.hljs-string,.hljs-template-tag{color:var(--spc-green-ink)}.hljs-bullet,.hljs-meta,.hljs-number,.hljs-symbol{color:var(--spc-orange-ink)}.hljs-class .hljs-title,.hljs-name,.hljs-title{color:var(--spc-blue-ink)}.hljs-built_in,.hljs-params,.hljs-type{color:var(--spc-amber-ink)}.mermaid-container,.mermaid-wrap{display:flex;justify-content:center;margin:var(--sp-5) 0;padding:var(--sp-5);background:var(--surface-sunken);border-radius:var(--r-md);overflow-x:auto;max-width:100%}.mermaid-container svg,.mermaid-wrap svg{max-width:100%;height:auto}.mermaid-container svg a,.mermaid-container svg li,.mermaid-container svg p,.mermaid-container svg span,.mermaid-wrap svg a,.mermaid-wrap svg li,.mermaid-wrap svg p,.mermaid-wrap svg span{font-size:inherit;line-height:inherit;letter-spacing:normal;margin:0;padding:0;max-width:none}h1[id],h2[id],h3[id],h4[id],h5[id],h6[id]{scroll-margin-top:90px}h1[id]>a,h2[id]>a,h3[id]>a,h4[id]>a,h5[id]>a,h6[id]>a{color:inherit}.about-wrap{max-width:760px;margin:0 auto}.about-card{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-6);margin-bottom:var(--sp-6)}.about-card h2{margin:0 0 6px;color:var(--fg-1)}.about-card p{margin:0;color:var(--fg-2);font-size:16px}.footer{width:100%;margin:var(--sp-9) 0 0;padding:0;position:relative;border:none}.footer-inner{max-width:var(--page-max);margin:0 auto;padding:var(--sp-7) var(--sp-5);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-5);flex-wrap:wrap}.footer .edge{width:100%;height:3px;background:var(--accent);border-radius:var(--r-pill);opacity:.7}.footer img{height:30px;width:auto;display:block}.footer p{margin:0;font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.foot-links,.footer-links{display:flex;gap:var(--sp-4);flex-wrap:wrap}.foot-links a,.footer-links a{font-family:var(--font-display);font-size:14px;color:var(--fg-2)}.foot-links a:hover,.footer-links a:hover{color:var(--accent);text-decoration:none}.table{width:100%;border-collapse:collapse;font-size:var(--fs-small)}.table td,.table th{padding:var(--sp-3) var(--sp-4);text-align:left;border:none;vertical-align:middle}.table thead th{font-family:var(--font-display);color:var(--fg-2);font-weight:600;border-bottom:2px solid var(--divider)}.table td .post-cell-title{font-family:var(--font-display);font-weight:500;color:var(--fg-1)}.table tbody tr{transition:background var(--dur) var(--ease)}.table tbody tr:hover{background:var(--surface-sunken)}.table tbody td:first-child{border-radius:var(--r-sm) 0 0 var(--r-sm)}.table tbody td:last-child{border-radius:0 var(--r-sm) var(--r-sm) 0}.table-wrapper{overflow-x:auto}.table-wrapper .table{min-width:720px}.table-actions{display:flex;gap:8px;flex-wrap:nowrap}.table-action{padding:5px 11px;font-size:12px}.cell-tags{display:flex;gap:6px;flex-wrap:wrap}.row-del{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;padding:5px 11px;font-size:12px;background:none;color:var(--fg-3);border:none;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:600;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.row-del:hover{background:var(--spc-red-soft);color:var(--spc-red-ink)}.status-badge{font-family:var(--font-mono);font-size:11px;padding:3px 9px;border-radius:var(--r-pill);display:inline-block;white-space:nowrap}.status-published{background:var(--spc-green-soft);color:var(--spc-green-ink)}.status-draft{background:var(--surface-2);color:var(--fg-3)}.status-pending{background:var(--spc-amber-soft);color:var(--spc-amber-ink)}.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:var(--bg-wash);background-attachment:fixed}.admin-sidebar{position:sticky;top:0;align-self:flex-start;min-height:100vh;padding:var(--sp-6) var(--sp-5);background:var(--surface-1);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:var(--sp-5)}.admin-brand{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--fg-1);display:flex;align-items:center;gap:10px}.admin-brand img{height:28px;width:auto}.admin-intro{margin:0;color:var(--fg-3);font-family:var(--font-mono);font-size:13px;line-height:1.6}.admin-nav{display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:500;font-size:14px;color:var(--fg-2);background:none;border:none;transition:all var(--dur) var(--ease)}.admin-nav-item:hover{background:var(--surface-2);color:var(--fg-1);text-decoration:none}.admin-nav-item.active{background:var(--accent-soft);color:var(--accent)}.admin-nav-item svg{width:17px;height:17px;flex:none}.admin-meta{font-family:var(--font-mono);font-size:13px;color:var(--fg-3);display:flex;flex-direction:column;gap:6px;margin-top:auto}.admin-back-link{color:var(--accent)}.admin-content{display:flex;flex-direction:column;min-height:100vh}.admin-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-6);box-shadow:var(--shadow-sm);background:var(--surface-2);backdrop-filter:blur(12px)}.admin-topbar-title{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--fg-1)}.admin-topbar-sub{font-family:var(--font-mono);color:var(--fg-3);font-size:13px}.admin-main{padding:var(--sp-6);max-width:1200px;width:100%}@media (max-width:820px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{position:relative;min-height:auto;box-shadow:var(--shadow-sm)}.admin-nav{flex-direction:row;flex-wrap:wrap}.admin-content{min-height:auto}}.login-wrap{min-height:72vh;display:flex;align-items:center;justify-content:center;padding:var(--sp-7) var(--sp-5)}.login-card{width:400px;max-width:92vw;background:var(--surface-1);backdrop-filter:blur(14px);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--sp-7)}.login-card .logo-row{display:flex;justify-content:center;margin-bottom:var(--sp-5)}.login-card .logo-row img{height:40px;width:auto}.login-page{min-height:100vh;display:grid;place-items:center;padding:var(--sp-7) var(--sp-5)}.login-page .login-card{width:min(400px,100%);display:flex;flex-direction:column;gap:var(--sp-3)}.login-card h1{margin:0;font-family:var(--font-display);font-size:1.5rem;text-align:center;color:var(--fg-1)}.login-card label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--fg-2)}.muted{color:var(--fg-3);text-align:center}.error-text,.muted{font-family:var(--font-mono);font-size:13px}.error-callout,.error-text{color:var(--spc-red-ink);margin:0}.error-callout{display:flex;align-items:center;gap:8px;background:var(--spc-red-soft);font-family:var(--font-mono);font-size:13px;padding:10px 14px;border-radius:var(--r-sm)}.error-callout svg{width:15px;height:15px;flex:none}.login-slogan{margin:var(--sp-4) 0 0;text-align:center;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--fg-3)}.admin-auth-overlay{position:fixed;inset:0;background:rgba(5,9,16,.55);display:flex;align-items:center;justify-content:center;padding:var(--sp-5);backdrop-filter:blur(6px);z-index:20}.admin-auth-panel{width:min(440px,100%);background:var(--surface-solid);border-radius:var(--r-lg);padding:var(--sp-6);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--sp-4)}.admin-auth-title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--fg-1)}.admin-auth-field{display:flex;flex-direction:column;gap:6px}.admin-auth-actions{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.editor-grid{display:grid;grid-template-columns:360px 1fr;gap:var(--sp-6);align-items:start}.editor-pane{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-5)}.editor-pane h3{margin:0 0 var(--sp-4);font-size:1.15rem;color:var(--fg-1)}.editor-toolbar{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}.editor-body textarea,.editor-textarea{width:100%;min-height:520px;font-family:var(--font-mono);font-size:14px;line-height:1.65;color:var(--fg-1);background:var(--surface-sunken);border:1px solid var(--border-hair);border-radius:var(--r-md);padding:var(--sp-4);outline:none;resize:vertical}.editor-body textarea:focus,.editor-textarea:focus{box-shadow:0 0 0 3px var(--accent-ring)}.editor-preview{min-height:520px}@media (max-width:980px){.editor-grid{grid-template-columns:1fr}}.editor-page{display:flex;flex-direction:column;gap:var(--sp-4)}.editor-meta,.editor-meta-compact,.editor-sidebar-panel,.editor-stage{background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-5)}.editor-meta-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4)}.editor-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--sp-3)}.editor-meta-grid label{display:flex;flex-direction:column;gap:6px;font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--fg-2)}.editor-title{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--fg-1)}.editor-actions{display:flex;gap:var(--sp-2);align-items:center;flex-wrap:wrap}.editor-workspace{display:flex;flex-direction:column;gap:var(--sp-4)}.editor-panels{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.editor-panel-title{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--fg-1)}.editor-preview,.preview-panel{border:1px solid var(--border-hair);border-radius:var(--r-md);background:var(--surface-1)}.preview-header{padding:8px 14px;border-bottom:1px solid var(--border-hair);font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--fg-2)}.preview-body{padding:var(--sp-4);overflow:auto}.editor-page-fullscreen{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);z-index:100}.editor-toolbar-fullscreen{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-6);background:var(--surface-2);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);flex-shrink:0}.editor-toolbar-left{flex:1;min-width:0;display:flex;align-items:center;gap:var(--sp-3)}.editor-toolbar-center{flex:0 0 auto;display:flex;justify-content:center;align-items:center;gap:var(--sp-4)}.view-mode-toggle{display:inline-flex;background:var(--surface-1);border-radius:var(--r-pill);padding:3px;gap:2px}.view-mode-btn{padding:6px 16px;border:none;background:none;color:var(--fg-2);border-radius:var(--r-pill);cursor:pointer;font-family:var(--font-display);font-weight:500;font-size:13px;transition:all var(--dur) var(--ease)}.view-mode-btn:hover{color:var(--fg-1)}.view-mode-btn.active{background:var(--accent);color:var(--fg-on-accent);box-shadow:var(--shadow-sm)}.auto-save-controls{display:flex;align-items:center;gap:var(--sp-3)}.auto-save-label{display:flex;align-items:center;gap:8px;color:var(--fg-3)}.auto-save-label,.auto-save-select{font-family:var(--font-mono);font-size:13px}.auto-save-select{color:var(--fg-1);background:var(--surface-2);border:1px solid transparent;border-radius:var(--r-sm);padding:5px 10px;cursor:pointer;outline:none;transition:box-shadow var(--dur) var(--ease)}.auto-save-select:focus{box-shadow:0 0 0 3px var(--accent-ring)}.auto-save-status{font-size:13px;min-width:100px}.auto-save-status,.save-status{font-family:var(--font-mono);color:var(--fg-3)}.save-status{display:inline-flex;align-items:center;gap:7px;font-size:12px;white-space:nowrap}.save-dot{display:inline-block;width:8px;height:8px;border-radius:var(--r-pill);background:var(--spc-green);flex:none}.save-dot.saving{background:var(--spc-amber)}.save-dot.error{background:var(--spc-red)}.wordcount{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);white-space:nowrap}.icon-btn{width:38px;height:38px;border-radius:var(--r-pill);flex:none;display:inline-flex;align-items:center;justify-content:center;color:var(--fg-2);background:none;border:none;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.icon-btn:hover{background:var(--surface-1);color:var(--fg-1)}.icon-btn svg{width:19px;height:19px}.ed-metabar{display:flex;align-items:center;gap:var(--sp-4);background:var(--surface-1);backdrop-filter:blur(10px);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:var(--sp-3) var(--sp-5);flex-shrink:0;min-width:0}.ed-metabar .ttl{font-family:var(--font-display);font-weight:700;font-size:1.02rem;color:var(--fg-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ed-metabar .slug{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);white-space:nowrap}.ed-metabar .spread{flex:1}.ed-banner-chip{display:inline-flex;align-items:center;gap:8px;flex:none;font-family:var(--font-mono);font-size:12px;color:var(--fg-2);background:var(--surface-2);border-radius:var(--r-pill);padding:4px 12px 4px 4px}.ed-banner-chip img{width:34px;height:22px;-o-object-fit:cover;object-fit:cover;border-radius:var(--r-pill);display:block}.ed-split{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);min-height:0}.ed-split>*{min-height:0;overflow:hidden;box-shadow:var(--shadow-sm)}.ed-split .editor-textarea-fullscreen,.ed-split>*{border-radius:var(--r-md)}.ed-split .ed-preview{background:var(--surface-1);backdrop-filter:blur(10px);display:flex;flex-direction:column;overflow:auto}.ed-split .ed-preview .preview-body{flex:1;padding:var(--sp-5);overflow:auto;line-height:1.8}@media (max-width:960px){.ed-split{grid-template-columns:1fr}}.editor-workspace-fullscreen{padding:var(--sp-4) var(--sp-6);gap:var(--sp-4)}.editor-content-fullscreen,.editor-workspace-fullscreen{flex:1;display:flex;flex-direction:column;overflow:hidden}.editor-content-fullscreen{min-height:0;background:var(--surface-1);border-radius:var(--r-md);box-shadow:var(--shadow-sm)}.editor-textarea-fullscreen{flex:1;min-height:0;width:100%;padding:var(--sp-5);border:none;background:var(--surface-sunken);color:var(--fg-1);font-family:var(--font-mono);line-height:1.8;font-size:1rem;resize:none;outline:none}.preview-panel-fullscreen{flex:1;display:flex;flex-direction:column;min-height:0;overflow:auto}.preview-panel-fullscreen .preview-body{flex:1;padding:var(--sp-5);overflow:auto;line-height:1.8}@media (max-width:960px){.editor-grid,.editor-panels{grid-template-columns:1fr}.editor-toolbar-fullscreen{flex-direction:column;align-items:stretch;gap:var(--sp-3)}.editor-toolbar-center{order:-1;flex-direction:column}.view-mode-toggle{width:100%}.view-mode-btn{flex:1}.auto-save-controls{margin-left:0;padding-left:0;border-left:none}}.dropzone{border:2px dashed var(--border-hair);border-radius:var(--r-lg);padding:var(--sp-7);text-align:center;color:var(--fg-3);font-family:var(--font-mono);font-size:14px;background:var(--surface-sunken);transition:all var(--dur) var(--ease);cursor:pointer}.dropzone:hover{border-color:var(--accent);color:var(--accent)}.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-4)}.img-tile{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);position:relative;aspect-ratio:4/3;cursor:pointer}.img-tile .art,.img-tile img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.img-tile .label{position:absolute;left:0;right:0;bottom:0;padding:8px 10px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.5));color:#fff;font-family:var(--font-mono);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.img-tile-card{display:flex;flex-direction:column;gap:var(--sp-2)}.img-tile-actions{display:flex;flex-wrap:wrap;gap:6px}.img-tile-actions .table-action{padding:4px 9px;font-size:11px}.toast{position:fixed;bottom:28px;left:50%;z-index:1000;background:var(--surface-solid);color:var(--fg-1);box-shadow:var(--shadow-lg);border-radius:var(--r-pill);padding:12px 22px;font-family:var(--font-display);font-size:14px;max-width:90%;text-align:center;opacity:0;transform:translateX(-50%) translateY(.5rem);transition:opacity var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}.toast-visible{opacity:1;transform:translateX(-50%) translateY(0)}.toast-hidden{opacity:0;transform:translateX(-50%) translateY(.5rem)}.notice-fixed{position:fixed;top:1rem;right:2rem;z-index:101;box-shadow:var(--shadow-lg);max-width:400px;animation:notice-fade-in .3s ease-out,notice-fade-out .3s ease-in 4.7s forwards}@keyframes notice-fade-in{0%{opacity:0;transform:translateY(-1rem)}to{opacity:1;transform:translateY(0)}}@keyframes notice-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-1rem)}}.error-page-container{text-align:center;padding:var(--sp-9) var(--sp-5);max-width:600px;margin:var(--sp-8) auto}.error-page-title{font-size:6rem}.error-page-title,.error-page-title-small{font-family:var(--font-display);margin:0;color:var(--accent)}.error-page-title-small{font-size:4rem}.error-page-heading{font-family:var(--font-display);font-size:2rem;margin:var(--sp-4) 0;color:var(--fg-1)}.error-page-message{color:var(--fg-2);font-size:1.1rem;margin-bottom:var(--sp-6)}.error-page-buttons{display:flex;gap:var(--sp-4);justify-content:center;flex-wrap:wrap}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.fade-up{animation:fadeUp var(--dur-slow) var(--ease-out) both}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--divider);border-radius:5px;-webkit-transition:background var(--dur) var(--ease);transition:background var(--dur) var(--ease)}::-webkit-scrollbar-thumb:hover{background:var(--fg-3)}[data-rmiz-modal-overlay]{background-color:rgba(0,0,0,.85)!important}html[data-theme=light] [data-rmiz-modal-overlay]{background-color:hsla(0,0%,100%,.92)!important}html[data-theme=dark] [data-rmiz-modal-img]{filter:none!important}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.fade-up{animation:none}.back-to-top:hover,.button:hover,.cat-card:hover,.feed-card:hover,.list-row:hover,.nav-link:hover,.tag-chip:hover{transform:none!important}}@media (max-width:640px){.main-container{padding:var(--sp-6) var(--sp-4) var(--sp-8)}.section-heading{gap:var(--sp-3)}.footer-inner{flex-direction:column;align-items:flex-start}.toast{bottom:16px;padding:10px 16px;font-size:13px;max-width:calc(100% - 2rem)}}