@layer tokens{:root{--washi-50:#faf6ec;--washi-100:#f5f1e8;--washi-200:#efe9dc;--washi-300:#e5ddc8;--washi-400:#c9bfa6;--sumi-900:#1a1614;--sumi-800:#2b2422;--sumi-700:#4a413c;--sumi-600:#6b5f56;--sumi-500:#8b7e72;--shu-red:#b8423a;--shu-red-soft:#c6635b;--shu-red-bg:color-mix(in srgb, var(--shu-red) 8%, transparent);--ginkgo:#d4a437;--ginkgo-soft:#e0b85c;--ginkgo-bg:color-mix(in srgb, var(--ginkgo) 10%, transparent);--color-bg:var(--washi-100);--color-bg-elevated:var(--washi-50);--color-bg-subtle:var(--washi-200);--color-border:var(--washi-300);--color-border-strong:var(--sumi-500);--color-text:var(--sumi-800);--color-text-heading:var(--sumi-900);--color-text-muted:var(--sumi-600);--color-text-subtle:var(--sumi-500);--color-link:var(--sumi-900);--color-accent:var(--shu-red);--font-display:var(--font-cormorant);--font-body:var(--font-eb-garamond);--font-mono:var(--font-jetbrains-mono);--font-kanji:var(--font-noto-serif-jp);--text-2xs:.6875rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1.0625rem;--text-md:1.25rem;--text-lg:1.625rem;--text-xl:2.125rem;--text-2xl:2.75rem;--text-3xl:4rem;--text-hero:6rem;--leading-tight:1.15;--leading-snug:1.35;--leading-normal:1.6;--leading-relaxed:1.75;--leading-loose:2;--tracking-tightest:-.02em;--tracking-tight:-.01em;--tracking-normal:0;--tracking-wide:.05em;--tracking-wider:.12em;--tracking-widest:.25em;--space-0:0;--space-1:.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2rem;--space-5:3rem;--space-6:4rem;--space-7:6rem;--space-8:8rem;--space-9:12rem;--space-10:16rem;--container-prose:38rem;--container-text:44rem;--container-wide:64rem;--container-full:80rem;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--ease-natural:cubic-bezier(.4, 0, .2, 1);--duration-fast:.25s;--duration-base:.4s;--duration-slow:.6s;--duration-slower:1s;--border-hairline:1px solid var(--washi-300);--border-subtle:1px solid var(--sumi-500);--border-strong:1px solid var(--sumi-800);--border-accent:1px solid var(--shu-red);--shadow-sm:0 1px 2px color-mix(in srgb, var(--sumi-900) 4%, transparent);--shadow-md:0 4px 12px color-mix(in srgb, var(--sumi-900) 6%, transparent);--shadow-lg:0 12px 32px color-mix(in srgb, var(--sumi-900) 8%, transparent);--z-base:0;--z-dropdown:10;--z-sticky:50;--z-overlay:100;--z-modal:200;--z-tooltip:300}@media (prefers-reduced-motion:reduce){:root{--duration-fast:0s;--duration-base:0s;--duration-slow:0s;--duration-slower:0s}}}@layer base{*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;text-size-adjust:100%;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text);background-color:var(--color-bg);background-image:radial-gradient(ellipse at top left, color-mix(in srgb, var(--ginkgo) 3%, transparent) 0%, transparent 50%), radial-gradient(ellipse at bottom right, color-mix(in srgb, var(--shu-red) 2%, transparent) 0%, transparent 60%), url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100vh;overflow-x:hidden}::selection{background-color:var(--shu-red);color:var(--washi-50)}img,picture,svg,video{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}:focus{outline:none}:focus-visible{outline:2px solid var(--shu-red);outline-offset:2px}}@layer layout{.container-prose{max-width:var(--container-prose);padding-inline:var(--space-3);margin-inline:auto}.container-text{max-width:var(--container-text);padding-inline:var(--space-3);margin-inline:auto}.container-wide{max-width:var(--container-wide);padding-inline:var(--space-5);margin-inline:auto}@media (width<=640px){.container-wide{padding-inline:var(--space-3)}}.container-full{max-width:var(--container-full);padding-inline:var(--space-5);margin-inline:auto}@media (width<=640px){.container-full{padding-inline:var(--space-3)}}.stack>*+*{margin-top:var(--stack-gap,var(--space-3))}.grid{gap:var(--space-3);display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}@media (width<=768px){.grid-2,.grid-3{grid-template-columns:1fr}}}@layer components{.type-h1{font-family:var(--font-display);font-weight:300;font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tightest);color:var(--color-text-heading)}.type-h2{font-family:var(--font-display);font-weight:400;font-size:var(--text-2xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-heading)}.type-h3{font-family:var(--font-display);font-weight:400;font-size:var(--text-xl);line-height:var(--leading-snug);color:var(--color-text-heading)}.type-h4{font-family:var(--font-display);font-weight:400;font-size:var(--text-lg);line-height:var(--leading-snug);color:var(--color-text-heading)}.type-h5{font-family:var(--font-display);font-weight:500;font-size:var(--text-md);line-height:var(--leading-snug);color:var(--color-text-heading)}.type-h6{font-family:var(--font-display);font-weight:500;font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-heading)}.type-subtitle1{font-family:var(--font-display);font-style:italic;font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--color-text-muted)}.type-subtitle2{font-family:var(--font-display);font-style:italic;font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-muted)}.type-body1{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text)}.type-body2{font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-text)}.type-button{font-family:var(--font-mono);font-weight:500;font-size:var(--text-sm);letter-spacing:var(--tracking-wider);text-transform:uppercase}.type-caption{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.type-overline{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--color-text-muted);display:inline-block}.btn{justify-content:center;align-items:center;gap:var(--space-1);font-family:var(--font-mono);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--sumi-900);cursor:pointer;transition:letter-spacing var(--duration-slow) var(--ease-out), background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;font-weight:500;line-height:1.5;text-decoration:none;display:inline-flex}.btn:hover{letter-spacing:.16em}.btn-sm{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.btn-base{font-size:var(--text-sm);padding:var(--space-2) var(--space-4)}.btn-lg{font-size:var(--text-base);padding:var(--space-3) var(--space-5)}.btn-primary{background-color:var(--sumi-900);border-color:var(--sumi-900);color:var(--washi-50)}.btn-primary:hover{background-color:var(--sumi-700);border-color:var(--sumi-700)}.btn-ghost{border-color:var(--sumi-900);color:var(--sumi-900)}.btn-ghost:hover{background-color:var(--sumi-900);color:var(--washi-50)}.btn-text{color:var(--sumi-900);padding-inline:0}.btn-text:hover{background:0 0}.btn-accent.btn-primary{background-color:var(--shu-red);border-color:var(--shu-red);color:var(--washi-50)}.btn-accent.btn-primary:hover{background-color:var(--shu-red-soft);border-color:var(--shu-red-soft)}.btn-accent.btn-ghost{border-color:var(--shu-red);color:var(--shu-red)}.btn-accent.btn-ghost:hover{background-color:var(--shu-red);color:var(--washi-50)}.btn-accent.btn-text{color:var(--shu-red)}.btn-seal{background-color:var(--shu-red);color:var(--washi-50);border-color:var(--shu-red);font-family:var(--font-kanji);letter-spacing:var(--tracking-wide);text-transform:none;font-weight:700}.btn-seal:hover{background-color:var(--shu-red-soft);border-color:var(--shu-red-soft);letter-spacing:var(--tracking-wide)}.btn[disabled],.btn.is-disabled{opacity:.45;cursor:not-allowed;pointer-events:none;letter-spacing:var(--tracking-wider)}.btn-icon{display:inline-flex}.icon-btn{width:40px;height:40px;padding:var(--space-1);color:var(--sumi-800);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{background-color:color-mix(in srgb, var(--sumi-900) 6%, transparent)}.icon-btn-accent{color:var(--shu-red)}.icon-btn-sm{width:32px;height:32px}.icon-btn-lg{width:48px;height:48px}.icon{vertical-align:middle;flex-shrink:0;display:inline-block}.icon-sm{width:18px;height:18px}.icon-lg{width:32px;height:32px}.kanji{font-family:var(--font-kanji);color:var(--sumi-900);font-weight:700;line-height:1;display:inline-block}.kanji-sm{font-size:var(--text-base)}.kanji-base{font-size:var(--text-lg)}.kanji-lg{font-size:var(--text-xl)}.kanji-xl{font-size:var(--text-3xl)}.kanji-hero{font-size:var(--text-hero)}.tag{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;border:var(--border-hairline);color:var(--sumi-700);background-color:var(--washi-50);white-space:nowrap;transition:all var(--duration-base) var(--ease-out);align-items:center;padding:4px 10px;text-decoration:none;display:inline-flex}.tag:hover{border-color:var(--sumi-900);color:var(--sumi-900)}.tag-filled{background-color:var(--washi-200);border-color:#0000}.tag-accent{border-color:var(--shu-red);color:var(--shu-red);background-color:#0000}.tag-ginkgo{border-color:var(--ginkgo);color:var(--ginkgo);background-color:#0000}.tag-sm{font-size:var(--text-2xs);padding:2px 8px}.avatar{width:40px;height:40px;font-family:var(--font-kanji);font-weight:700;font-size:var(--text-md);color:var(--washi-50);background-color:var(--sumi-900);user-select:none;justify-content:center;align-items:center;line-height:1;display:inline-flex;overflow:hidden}.avatar-circle{border-radius:9999px}.avatar-square{border-radius:0}.avatar-rounded{border-radius:4px}.avatar-sm{width:32px;height:32px;font-size:var(--text-base)}.avatar-lg{width:56px;height:56px;font-size:1.6rem}.avatar-accent{background-color:var(--shu-red)}.avatar-ginkgo{background-color:var(--ginkgo);color:var(--sumi-900)}.badge-wrap{display:inline-flex;position:relative}.badge{min-width:18px;height:18px;font-family:var(--font-mono);font-size:var(--text-2xs);color:var(--washi-50);background-color:var(--shu-red);border-radius:9999px;justify-content:center;align-items:center;padding:0 5px;line-height:1;display:inline-flex;position:absolute;top:0;right:0;transform:translate(40%,-40%)}.badge-dot{width:8px;min-width:8px;height:8px;padding:0}.field{gap:var(--space-1);flex-direction:column;display:flex}.field-label{font-family:var(--font-mono);font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.field-control{align-items:center;gap:var(--space-1);padding:var(--space-1) 0;border-bottom:1px solid var(--washi-400);transition:border-color var(--duration-fast) var(--ease-out);display:flex}.field-control:focus-within{border-bottom-color:var(--sumi-900)}.field-input{width:100%;font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:0 0;border:none;outline:none;flex:1}.field-input::placeholder{color:var(--color-text-subtle);font-style:italic}.field-help{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.field.is-error .field-control{border-bottom-color:var(--shu-red)}.field.is-error .field-help{color:var(--shu-red)}.check,.radio,.switch{align-items:center;gap:var(--space-1);cursor:pointer;display:inline-flex}.check-input,.radio-input{width:18px;height:18px;accent-color:var(--sumi-900);cursor:pointer}.switch{gap:var(--space-2)}.switch-input{opacity:0;width:0;height:0;position:absolute}.switch-track{background-color:var(--washi-400);width:40px;height:22px;transition:background-color var(--duration-fast) var(--ease-out);align-items:center;padding:2px;display:inline-flex}.switch-thumb{background-color:var(--washi-50);width:18px;height:18px;transition:transform var(--duration-fast) var(--ease-out)}.switch-input:checked+.switch-track{background-color:var(--sumi-900)}.switch-input:checked+.switch-track .switch-thumb{transform:translate(18px)}.divider{border:none;border-top:1px solid var(--color-border);margin:0}.divider-text{align-items:center;gap:var(--space-3);font-family:var(--font-kanji);font-size:var(--text-md);color:var(--color-text-muted);text-align:center;display:flex}.divider-text:before,.divider-text:after{content:"";background-color:var(--color-border);flex:1;height:1px}.path-divider{margin:var(--space-6) 0;justify-content:center;align-items:center;gap:6px;display:flex}.path-divider span{background-color:var(--washi-400);border-radius:50%;width:3px;height:3px}.path-divider span:nth-child(2n){background-color:var(--sumi-500)}.link{color:var(--sumi-900);border-bottom:1px solid var(--washi-400);transition:color var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);text-decoration:none}.link:hover{color:var(--shu-red);border-bottom-color:var(--shu-red)}.link-hover{border-bottom-color:#0000}.link-hover:hover{border-bottom-color:var(--shu-red)}.link-plain,.link-plain:hover{border-bottom:none}.progress{background-color:var(--color-border);width:100%;height:2px;position:relative;overflow:hidden}.progress-bar{transform-origin:0;transform:scaleX(calc(1 - var(--_remain,0%) / 100%));background:linear-gradient(90deg, var(--sumi-900), var(--shu-red));position:absolute;inset:0}.skeleton{background-color:var(--washi-200);animation:1.6s ease-in-out infinite sumi-skeleton;display:block}.skeleton-text{height:1em;margin-bottom:var(--space-1)}.skeleton-rect{width:100%;height:120px}@keyframes sumi-skeleton{0%,to{opacity:1}50%{opacity:.4}}@media (prefers-reduced-motion:reduce){.skeleton{animation:none}}.seal{font-family:var(--font-kanji);color:var(--washi-50);user-select:none;justify-content:center;align-items:center;font-weight:700;display:inline-flex;transform:rotate(-2deg)}.seal-sm{width:32px;height:32px;font-size:1rem}.seal-base{width:40px;height:40px;font-size:var(--text-md)}.seal-lg{width:56px;height:56px;font-size:1.6rem}.seal-red{background-color:var(--shu-red)}.seal-sumi{background-color:var(--sumi-900)}.seal-ginkgo{background-color:var(--ginkgo);color:var(--sumi-900)}.card{background-color:var(--color-bg-elevated);border:var(--border-hairline);flex-direction:column;display:flex}.card-elevated{box-shadow:var(--shadow-sm)}.card-action{transition:box-shadow var(--duration-base) var(--ease-out)}.card-action:hover{box-shadow:var(--shadow-md)}.card-header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-3) 0;display:flex}.card-avatar{flex-shrink:0}.card-head-content{min-width:0}.card-title{font-family:var(--font-display);font-size:var(--text-base);color:var(--color-text-heading);margin:0;font-weight:500}.card-subhead{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin:4px 0 0}.card-content{padding:var(--space-3)}.card-actions{align-items:center;gap:var(--space-1);padding:0 var(--space-3) var(--space-3);display:flex}.alert{gap:var(--space-2);margin:var(--space-4) 0;padding:var(--space-2) var(--space-3);border-left:2px solid var(--sumi-700);background-color:color-mix(in srgb, var(--sumi-700) 6%, transparent);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);display:flex}.alert-icon{color:var(--sumi-700);flex-shrink:0;padding-top:2px}.alert-message{min-width:0}.alert-message>:last-child{margin-bottom:0}.alert-title{font-family:var(--font-mono);font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin-bottom:6px;display:block}.alert-info{border-left-color:var(--sumi-700);background-color:color-mix(in srgb, var(--sumi-700) 6%, transparent)}.alert-info .alert-icon{color:var(--sumi-700)}.alert-warning{border-left-color:var(--ginkgo);background-color:var(--ginkgo-bg)}.alert-warning .alert-icon{color:var(--ginkgo)}.alert-error{border-left-color:var(--shu-red);background-color:var(--shu-red-bg)}.alert-error .alert-icon{color:var(--shu-red)}.alert-success{background-color:#6b7d3c1f;border-left-color:#6b7d3c}.alert-success .alert-icon{color:#6b7d3c}.list{margin:0;padding:0;list-style:none}.list-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:var(--border-hairline);display:flex}.list-item-button{cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out)}.list-item-button:hover{background-color:color-mix(in srgb, var(--sumi-900) 6%, transparent)}.list-avatar{flex-shrink:0}.list-text{flex:1;min-width:0}.list-primary{font-family:var(--font-display);font-size:var(--text-md);color:var(--color-text-heading);margin:0}.list-secondary{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wide);color:var(--color-text-muted);margin:4px 0 0}.breadcrumbs{align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);flex-wrap:wrap;display:flex}.breadcrumb-sep{color:var(--color-text-subtle)}.tabs{border-bottom:var(--border-hairline);display:flex}.tab{padding:var(--space-2) var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab:hover{color:var(--color-text)}.tab.is-active{color:var(--color-text);border-bottom-color:var(--shu-red)}.pull-quote-cite{margin-top:var(--space-2);font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:var(--tracking-wide);color:var(--color-text-muted);font-style:normal;display:block}.appbar{z-index:var(--z-sticky);background:color-mix(in srgb, var(--color-bg) 85%, transparent);-webkit-backdrop-filter:blur(12px);border-bottom:var(--border-hairline);position:sticky;top:0}.toolbar{align-items:center;gap:var(--space-3);max-width:var(--container-full);padding:var(--space-2) var(--space-3);margin:0 auto;display:flex}.drawer{background-color:var(--color-bg-elevated);border:var(--border-hairline);padding:var(--space-3)}.dialog{background-color:var(--color-bg-elevated);border:var(--border-hairline);box-shadow:var(--shadow-lg);max-width:28rem}.dialog-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text-heading);padding:var(--space-3) var(--space-3) 0;margin:0;font-weight:400}.dialog-content{padding:var(--space-2) var(--space-3)}.dialog-actions{justify-content:flex-end;gap:var(--space-1);padding:0 var(--space-3) var(--space-3);display:flex}.article-card{color:inherit;text-decoration:none;display:block}.article-card-title{font-family:var(--font-display);color:var(--color-text-heading);margin:var(--space-2) 0;transition:color var(--duration-fast) var(--ease-out);font-weight:400}.article-card:hover .article-card-title{color:var(--shu-red)}.article-card-excerpt{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-muted);margin:0}.article-card-featured{gap:var(--space-5);padding:var(--space-5) 0;border-top:1px solid var(--sumi-900);border-bottom:var(--border-hairline);grid-template-columns:2fr 3fr;display:grid}.article-card-featured .article-card-title{font-size:var(--text-2xl)}.article-card-list{padding:var(--space-4) 0;border-bottom:var(--border-hairline)}.article-card-list .article-card-title{font-size:var(--text-xl)}.article-card-grid{padding:var(--space-3);border:var(--border-hairline);background-color:var(--color-bg-elevated);transition:box-shadow var(--duration-base) var(--ease-out)}.article-card-grid:hover{box-shadow:var(--shadow-md)}.article-card-grid .article-card-title{font-size:var(--text-md)}@media (width<=768px){.article-card-featured{gap:var(--space-3);grid-template-columns:1fr}}.stack-flex{flex-direction:column;display:flex}.stack-row{flex-direction:row}.stack-1{gap:var(--space-1)}.stack-2{gap:var(--space-2)}.stack-3{gap:var(--space-3)}.stack-divider.stack-flex>*+*{border-top:var(--border-hairline);padding-top:var(--space-1)}.stack-divider.stack-row>*+*{border-left:var(--border-hairline);padding-left:var(--space-2)}.article-layout{gap:var(--space-5);grid-template-columns:220px minmax(0,608px) 220px;justify-content:center;display:grid}.article-layout-toc{font-size:var(--text-sm)}.article-layout-content{min-width:0}.article-layout-aside{font-size:var(--text-sm)}@media (width<=1100px){.article-layout{grid-template-columns:minmax(0,1fr)}.article-layout-toc,.article-layout-aside{display:none}}.article-meta{gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--sumi-600);letter-spacing:var(--tracking-wide);align-items:center;display:flex}.meta-category{text-transform:uppercase;letter-spacing:var(--tracking-widest)}.meta-dot{background-color:var(--washi-400);border-radius:50%;flex-shrink:0;width:3px;height:3px}.byline{align-items:center;gap:var(--space-2);padding:var(--space-3) 0;border-top:var(--border-hairline);border-bottom:var(--border-hairline);margin:var(--space-4) 0;display:flex}.byline-avatar{background-color:var(--sumi-900);width:48px;height:48px;color:var(--washi-50);font-family:var(--font-kanji);font-size:var(--text-md);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.byline-info{flex-direction:column;flex:1;gap:2px;display:flex}.byline-name{font-family:var(--font-display);font-size:var(--text-base);color:var(--sumi-900);font-weight:500}.byline-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--sumi-600);letter-spacing:var(--tracking-wide)}.newsletter{padding:var(--space-6) var(--space-4);margin:var(--space-6) 0;text-align:center;background-color:var(--washi-50);border-block:var(--border-hairline);position:relative}.newsletter:before,.newsletter:after{content:"·";color:var(--washi-400);font-size:2rem;position:absolute;top:50%;transform:translateY(-50%)}.newsletter:before{left:var(--space-3)}.newsletter:after{right:var(--space-3)}.newsletter-eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);margin-bottom:var(--space-2)}.newsletter-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--sumi-900);margin-bottom:var(--space-2);letter-spacing:var(--tracking-tight);font-weight:400}.newsletter-desc{font-family:var(--font-body);color:var(--sumi-700);max-width:30rem;margin:0 auto var(--space-4);font-style:italic;line-height:var(--leading-relaxed)}.newsletter-form{gap:0;max-width:26rem;margin:0 auto;display:flex}.newsletter-input{font-family:var(--font-body);font-size:var(--text-base);padding:var(--space-2) var(--space-3);border:1px solid var(--sumi-700);color:var(--sumi-900);transition:border-color var(--duration-base) var(--ease-out);background:0 0;border-right:none;outline:none;flex:1}.newsletter-input::placeholder{color:var(--sumi-500);font-style:italic}.newsletter-input:focus{border-color:var(--sumi-900)}.newsletter-submit{font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:var(--tracking-wider);text-transform:uppercase;padding:var(--space-2) var(--space-4);background-color:var(--sumi-900);color:var(--washi-50);border:1px solid var(--sumi-900);cursor:pointer;transition:all var(--duration-base) var(--ease-out)}.newsletter-submit:hover:not(:disabled){background-color:var(--sumi-700);border-color:var(--sumi-700)}.newsletter-submit:disabled{opacity:.6;cursor:not-allowed}@media (width<=480px){.newsletter-form{gap:var(--space-1);flex-direction:column}.newsletter-input{border-right:1px solid var(--sumi-700)}}.nav{z-index:var(--z-sticky);background:color-mix(in srgb, var(--washi-100) 85%, transparent);-webkit-backdrop-filter:blur(12px);border-bottom:var(--border-hairline);transition:padding var(--duration-base) var(--ease-out);position:fixed;inset:0 0 auto}.nav-inner{max-width:var(--container-full);padding:var(--space-2) var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-4);margin:0 auto;display:flex}@media (width<=640px){.nav-inner{padding-inline:var(--space-3)}}.nav-brand{align-items:baseline;gap:var(--space-1);font-family:var(--font-display);font-size:var(--text-md);letter-spacing:var(--tracking-wide);color:var(--sumi-900);font-weight:500;text-decoration:none;display:flex}.nav-brand-dot{color:var(--washi-400);font-size:var(--text-xs)}.nav-menu{gap:var(--space-5);align-items:center;list-style:none;display:flex}.nav-link{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-700);letter-spacing:var(--tracking-wider);text-transform:uppercase;transition:color var(--duration-base) var(--ease-out), letter-spacing var(--duration-slow) var(--ease-out);padding-bottom:2px;text-decoration:none;position:relative}.nav-link:after{content:"";background-color:var(--sumi-900);width:0;height:1px;transition:width var(--duration-slow) var(--ease-out), left var(--duration-slow) var(--ease-out);position:absolute;bottom:0;left:50%}.nav-link:hover,.nav-link.active{color:var(--sumi-900);letter-spacing:.16em}.nav-link:hover:after,.nav-link.active:after{width:100%;left:0}.nav-search-btn{color:var(--sumi-700);padding:var(--space-1);transition:color var(--duration-base) var(--ease-out);align-items:center;display:flex}.nav-search-btn:hover{color:var(--sumi-900)}.nav-toggle{padding:var(--space-1);flex-direction:column;gap:4px;display:none}.nav-toggle span{background-color:var(--sumi-900);width:24px;height:1px;transition:transform var(--duration-base) var(--ease-out);display:block}@media (width<=768px){.nav-toggle{display:flex}.nav-menu{background:color-mix(in srgb, var(--washi-50) 98%, transparent);backdrop-filter:blur(20px);padding:var(--space-5);gap:var(--space-3);opacity:0;pointer-events:none;transition:transform var(--duration-base) var(--ease-out), opacity var(--duration-base) var(--ease-out);border-bottom:var(--border-hairline);flex-direction:column;position:fixed;inset:56px 0 auto;transform:translateY(-100%)}.nav-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}}.footer{padding:var(--space-7) var(--space-5) var(--space-5);border-top:var(--border-hairline);background-color:var(--washi-50);margin-top:var(--space-8)}.footer-inner{max-width:var(--container-full);margin:0 auto}.footer-grid{gap:var(--space-5);padding-bottom:var(--space-5);border-bottom:var(--border-hairline);grid-template-columns:2fr 1fr 1fr;display:grid}.footer-brand-row{align-items:baseline;gap:var(--space-1);margin-bottom:var(--space-2);display:flex}.footer-brand-text{font-family:var(--font-display);font-size:var(--text-lg);color:var(--sumi-900);font-style:italic}.footer-desc{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-700);max-width:28rem;font-style:italic;line-height:var(--leading-relaxed)}.footer-col-title{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);margin-bottom:var(--space-2);font-weight:400}.footer-links{padding:0;list-style:none}.footer-links li{margin-bottom:var(--space-1)}.footer-links a{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-700);transition:color var(--duration-base) var(--ease-out);align-items:center;gap:4px;text-decoration:none;display:inline-flex}.footer-links a:hover{color:var(--sumi-900)}.footer-bottom{padding-top:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--sumi-600);letter-spacing:var(--tracking-wide);justify-content:space-between;gap:var(--space-2);flex-wrap:wrap;display:flex}@media (width<=768px){.footer-grid{gap:var(--space-4);grid-template-columns:1fr}.footer-bottom{gap:var(--space-1);flex-direction:column}}.post-nav{gap:var(--space-3);margin:var(--space-6) 0;padding:var(--space-4) 0;border-block:var(--border-hairline);grid-template-columns:1fr 1fr;display:grid}.post-nav-item{color:inherit;padding:var(--space-2);transition:all var(--duration-base) var(--ease-out);text-decoration:none;display:block}.post-nav-item:hover{background-color:var(--washi-200)}.post-nav-item.next{text-align:right}.post-nav-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);margin-bottom:var(--space-1);display:block}.post-nav-title{font-family:var(--font-display);font-size:var(--text-md);color:var(--sumi-900);line-height:var(--leading-snug)}@media (width<=640px){.post-nav{grid-template-columns:1fr}.post-nav-item.next{text-align:left}}.reading-progress{height:2px;z-index:calc(var(--z-sticky) + 1);pointer-events:none;background:0 0;position:fixed;inset:0 0 auto}.reading-progress-bar{background:linear-gradient(90deg, var(--sumi-900), var(--shu-red));width:0%;height:100%;transition:width .1s linear}.toc{top:var(--space-7);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-snug);position:sticky}.toc-title{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:var(--border-hairline)}.toc-list{padding:0;list-style:none}.toc-item{margin-bottom:var(--space-2)}.toc-item.level-3{padding-left:var(--space-2);font-size:.85em}.toc-link{color:var(--sumi-600);padding:4px 0 4px var(--space-2);border-left:1px solid var(--washi-300);transition:all var(--duration-base) var(--ease-out);line-height:var(--leading-snug);text-decoration:none;display:block}.toc-link:hover{color:var(--sumi-900);border-left-color:var(--sumi-900);padding-left:var(--space-3)}.toc-link.active{color:var(--sumi-900);border-left-color:var(--shu-red);padding-left:var(--space-2);border-left-width:2px;font-weight:500}.search-overlay{background:var(--washi-100);z-index:var(--z-modal);padding:15vh var(--space-3) var(--space-3);opacity:0;pointer-events:none;transition:opacity var(--duration-base) var(--ease-out);justify-content:center;align-items:flex-start;display:flex;position:fixed;inset:0;overflow-y:auto}.search-overlay.open{opacity:1;pointer-events:auto}.search-box{width:100%;max-width:600px}.search-header{margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:var(--border-hairline);justify-content:space-between;align-items:baseline;display:flex}.search-title{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);font-weight:400}.search-close{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wider);border:1px solid var(--sumi-500);color:var(--sumi-700);transition:all var(--duration-base) var(--ease-out);padding:2px 8px}.search-close:hover{border-color:var(--sumi-900);color:var(--sumi-900)}.search-fallback{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-600);line-height:var(--leading-relaxed);padding:var(--space-3);border:var(--border-hairline);background-color:var(--washi-50)}.search-fallback code{font-family:var(--font-mono);background-color:var(--washi-100);border:1px solid var(--washi-200);padding:2px 6px;font-size:.85em}.search-container .pagefind-ui{--pagefind-ui-primary:var(--sumi-900);--pagefind-ui-text:var(--sumi-800);--pagefind-ui-background:var(--washi-50);--pagefind-ui-border:var(--washi-300);--pagefind-ui-tag:var(--washi-200);--pagefind-ui-border-width:1px;--pagefind-ui-border-radius:0;--pagefind-ui-font:var(--font-body)}.article-hero{padding:calc(var(--space-7) + var(--space-5)) 0 var(--space-5);text-align:center;position:relative;overflow:hidden}.article-kanji-bg{font-family:var(--font-kanji);color:var(--washi-200);opacity:.5;pointer-events:none;user-select:none;z-index:0;font-size:28rem;font-weight:700;line-height:1;position:absolute;top:5rem;right:-3rem}.article-hero-content{z-index:1;max-width:var(--container-text);padding:0 var(--space-3);margin:0 auto;position:relative}.article-cat{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--shu-red);margin-bottom:var(--space-3)}.article-title{font-family:var(--font-display);font-size:clamp(2rem, 5vw, var(--text-2xl));font-weight:400;line-height:var(--leading-tight);color:var(--sumi-900);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-3)}.article-subtitle{font-family:var(--font-body);font-size:var(--text-md);color:var(--sumi-700);font-style:italic;line-height:var(--leading-relaxed);margin-bottom:var(--space-4);max-width:32rem;margin-inline:auto}.article-meta-bar{justify-content:center;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);color:var(--sumi-600);margin-top:var(--space-4);padding-top:var(--space-3);border-top:var(--border-hairline);flex-wrap:wrap;display:flex}.article-meta-dot{background-color:var(--washi-400);border-radius:50%;width:3px;height:3px}.featured-flag{color:var(--shu-red)}.article-shell{gap:var(--space-5);max-width:var(--container-full);padding:var(--space-6) var(--space-5);grid-template-columns:1fr;margin:0 auto;display:grid;position:relative}@media (width>=1100px){.article-shell{grid-template-columns:220px minmax(0, var(--container-prose)) 220px;gap:var(--space-6);justify-content:center;align-items:start}}.article-toc-col,.article-side-col{display:none}@media (width>=1100px){.article-toc-col,.article-side-col{display:block}}.article-content-col{width:100%;min-width:0}@media (width>=1100px){.article-content-col{justify-self:center}}.article-side-sticky{top:var(--space-7);gap:var(--space-3);flex-direction:column;display:flex;position:sticky}.share-block{padding:var(--space-3);background:var(--washi-50);border:var(--border-hairline)}.share-title{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--sumi-600);margin-bottom:var(--space-2);font-weight:400}.share-buttons{gap:var(--space-1);flex-direction:column;display:flex}.share-btn{font-family:var(--font-body);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);color:var(--sumi-700);padding:var(--space-1) 0;border-bottom:1px solid var(--washi-300);transition:all var(--duration-base) var(--ease-out);background:0 0;border-radius:0;justify-content:space-between;align-items:center;text-decoration:none;display:flex}.share-btn:last-child{border-bottom:none}.share-btn:hover{color:var(--sumi-900);padding-left:var(--space-1)}.tag-list{gap:var(--space-1);flex-direction:column;display:flex}}@layer prose{.prose{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text)}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-display);color:var(--color-text-heading);letter-spacing:var(--tracking-tight);font-weight:500;line-height:var(--leading-snug);margin-top:var(--space-5);margin-bottom:var(--space-3)}.prose h2{font-size:var(--text-xl);padding-bottom:var(--space-2);font-weight:400;position:relative}.prose h2:after{content:"";background-color:var(--sumi-700);width:40px;height:1px;position:absolute;bottom:0;left:0}.prose h3{font-size:var(--text-lg);font-weight:500}.prose h4{font-family:var(--font-body);font-size:var(--text-md);color:var(--sumi-700);font-style:italic;font-weight:400}.prose h2 a,.prose h3 a{color:inherit;border-bottom:none}:is(.prose h2 a,.prose h3 a):hover{color:var(--shu-red)}.prose p{margin-bottom:var(--space-3)}.prose p.lead{font-size:var(--text-md);color:var(--sumi-700);font-style:italic;line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.prose p.drop-cap:first-letter{font-family:var(--font-display);float:left;color:var(--sumi-900);margin:.1em .15em 0 0;font-size:4.5rem;font-weight:400;line-height:.9}.prose a{color:var(--sumi-900);border-bottom:1px solid var(--washi-400);transition:border-color var(--duration-base) var(--ease-out), color var(--duration-base) var(--ease-out);text-decoration:none}.prose a:hover{color:var(--shu-red);border-bottom-color:var(--shu-red)}.prose strong{color:var(--sumi-900);font-weight:600}.prose em{font-style:italic}.prose code{font-family:var(--font-mono);background-color:var(--washi-200);color:var(--sumi-900);border-radius:2px;padding:2px 6px;font-size:.88em}.prose mark{background-color:var(--ginkgo-bg);color:var(--sumi-900);padding:0 2px}.prose kbd{font-family:var(--font-mono);border:var(--border-hairline);background-color:var(--washi-50);color:var(--sumi-800);border-bottom-width:2px;border-radius:3px;padding:2px 6px;font-size:.8em}.prose ul,.prose ol{margin-bottom:var(--space-3);padding-left:var(--space-4)}.prose li{margin-bottom:var(--space-1);padding-left:var(--space-1)}.prose ul li{list-style:none;position:relative}.prose ul li:before{content:"—";left:calc(-1 * var(--space-3));color:var(--sumi-500);position:absolute}.prose ol{list-style:decimal}.prose ol li::marker{font-family:var(--font-mono);color:var(--sumi-600);font-size:.9em}.prose blockquote{margin:var(--space-4) 0;padding:var(--space-2) var(--space-4);border-left:1px solid var(--sumi-900);position:relative}.prose blockquote p{font-family:var(--font-display);font-size:var(--text-md);color:var(--sumi-800);font-style:italic;line-height:var(--leading-relaxed);margin-bottom:var(--space-1)}.prose blockquote cite{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-600);letter-spacing:var(--tracking-wide);font-style:normal}.prose blockquote cite:before{content:"— "}.prose hr{text-align:center;margin:var(--space-6) 0;border:none;height:1.5rem;position:relative}.prose hr:before{content:"· · ·";font-family:var(--font-body);font-size:var(--text-lg);letter-spacing:.5em;color:var(--sumi-500)}.prose pre{border:var(--border-hairline);border-left:2px solid var(--sumi-900);padding:var(--space-3) var(--space-4);margin:var(--space-4) 0;font-size:var(--text-sm);line-height:var(--leading-relaxed);overflow-x:auto;background-color:var(--washi-50)!important}.prose pre code{font-size:inherit;background:0 0;padding:0}.prose table{border-collapse:collapse;width:100%;margin:var(--space-4) 0;font-size:var(--text-sm)}.prose th{font-family:var(--font-body);text-align:left;padding:var(--space-2);border-bottom:1px solid var(--sumi-900);color:var(--sumi-900);font-weight:600}.prose td{padding:var(--space-2);border-bottom:var(--border-hairline);color:var(--sumi-800);line-height:var(--leading-normal)}.prose tbody tr:last-child td{border-bottom:none}.prose tbody tr:hover{background-color:var(--washi-200)}.prose figure{margin:var(--space-5) 0}.prose figure img{border:var(--border-hairline);width:100%}.prose figcaption{font-family:var(--font-body);font-size:var(--text-sm);color:var(--sumi-600);text-align:center;margin-top:var(--space-2);font-style:italic;line-height:var(--leading-normal)}.pull-quote{font-family:var(--font-display);font-size:var(--text-xl);font-style:italic;font-weight:300;line-height:var(--leading-snug);color:var(--sumi-900);text-align:center;margin:var(--space-6) auto;max-width:32rem;padding:var(--space-4) 0;border-top:1px solid var(--washi-400);border-bottom:1px solid var(--washi-400)}}@layer utilities{.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-center{text-align:center}.text-right{text-align:right}.italic{font-style:italic}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:var(--tracking-wider)}.tracking-widest{letter-spacing:var(--tracking-widest)}.text-muted{color:var(--color-text-muted)}.text-subtle{color:var(--color-text-subtle)}.text-heading{color:var(--color-text-heading)}.font-mono{font-family:var(--font-mono)}.font-display{font-family:var(--font-display)}.font-kanji{font-family:var(--font-kanji)}}
