:root{--font:'Public Sans', -apple-system, sans-serif;--font-display:'Bricolage Grotesque', sans-serif;--text-sm:clamp(12px, calc(11.67px + 0.10vw), 13px);--text-base:clamp(14px, calc(13.67px + 0.10vw), 15px);--text-md:clamp(15px, calc(14.33px + 0.21vw), 16px);--text-lg:clamp(16px, calc(15.33px + 0.21vw), 18px);--text-xl:clamp(18px, calc(17.33px + 0.21vw), 20px);--text-2xl:clamp(20px, calc(18.67px + 0.42vw), 22px);--text-3xl:clamp(22px, calc(20px   + 0.63vw),  28px);--weight-normal:400;--weight-semibold:500;--lh-display:1.2;--lh-tight:1.35;--lh-relaxed:1.6;--lh-prose:1.75;--r-2:2px;--r-xs:4px;--r-sm:8px;--r:12px;--r-pill:20px;--r-full:50%;--col-w:280px;--hdr-h:48px;--peek:calc(33vw);--gap:28px;--gap-sm:20px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--z-elevated:10;--z-header:20;--z-chip:30;--z-tooltip:50;--z-sheet:100;--z-panel:150;--z-fab:200;--z-modal:400;--dur-fast:0.12s;--dur-base:0.2s;--shadow-sm:0 2px 12px rgba(0,0,0,0.08);--shadow-md:0 4px 20px rgba(0,0,0,0.12);--shadow-lg:0 8px 40px rgba(0,0,0,0.18);--overlay:rgba(0,0,0,0.30);--mac-dot-red:#ff5f57;--mac-dot-yellow:#febc2e;--mac-dot-green:#28c840}[data-theme=chalk]{--bg:#ffffff;--surface:#fafafa;--surface2:#f3f3f3;--ink:#111111;--ink2:#555555;--border:#e0e0e0;--border-light:#efefef;--accent:#113e9f;--accent-subtle:rgba(91, 143, 255, 0.15)}[data-theme=ink]{--bg:#0f0f0f;--surface:#1a1a1a;--surface2:#242424;--ink:#ededed;--ink2:#aaaaaa;--border:#2e2e2e;--border-light:#222222;--accent:#5b8fff;--accent-subtle:rgba(91, 143, 255, 0.15);--shadow-sm:0 2px 12px rgba(0,0,0,0.40);--shadow-md:0 4px 20px rgba(0,0,0,0.45);--shadow-lg:0 8px 40px rgba(0,0,0,0.50);--overlay:rgba(0,0,0,0.55)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);font-size:var(--text-base);line-height:1.5;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}body::after{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 120% 50% at 50% 105%,var(--accent-subtle) 0%,transparent 65%);pointer-events:none;z-index:0}*{scrollbar-width:none}*::-webkit-scrollbar{display:none}.d-cols{scrollbar-width:thin}.d-cols::-webkit-scrollbar{display:block;height:3px}button{font-family:var(--font)}.app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.content{flex:1;overflow:hidden;position:relative}.m-wrap{height:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.m-track{display:flex;height:100%}.m-panel{flex-shrink:0;width:calc(100vw - var(--peek));height:calc(100dvh - var(--hdr-h));overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--gap-sm)var(--gap-sm)100px;scroll-snap-align:start;border-right:1px solid var(--border-light)}.d-cols{display:none;height:100%;overflow-x:auto;overflow-y:hidden}.d-cols::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--r-2)}.d-col{flex-shrink:0;width:var(--col-w);height:100%;overflow-y:auto;border-right:1px solid var(--border-light);padding:var(--gap)var(--gap)80px}.d-col:last-child{border-right:none}.l-view{display:none;height:100%;overflow-y:auto;padding:0 var(--gap-sm)100px}.month-label{font-size:var(--text-sm);color:var(--ink2);margin-bottom:var(--space-4)}.l-month-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.07em;text-transform:uppercase;color:var(--ink2);padding:20px 0 10px;border-bottom:1px solid var(--border-light)}.empty-state{padding:var(--space-12)20px;text-align:center;color:var(--ink2);font-size:var(--text-base);line-height:var(--lh-relaxed)}.empty-state-icon{font-size:var(--text-2xl);opacity:.3;margin-bottom:var(--space-3)}@media(max-width:639px){.m-panel{padding:var(--gap)var(--gap)100px}.m-panel .month-label{margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}.m-panel .card{margin-bottom:24px;width:100%}.m-panel .nl-card-wrap{width:100%}.m-track.is-scrolling .card,.m-track.is-scrolling .nl-card-wrap{pointer-events:none}}@media(min-width:640px){.m-wrap{display:none}.d-cols{display:flex}}.home-app{justify-content:center;align-items:center}.home-body{padding:var(--gap)}.home-title{font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--ink);letter-spacing:-.02em;margin-bottom:var(--space-2)}.home-sub{font-size:var(--text-md);color:var(--ink2);line-height:var(--lh-relaxed)}.home-sub a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}.home-sub a[href^=http]::after,.home-link[href^=http]::after,.sp-text a[href^=http]::after,.sh-body a[href^=http]::after{content:'';display:inline-block;width:.4em;height:.4em;margin-left:2px;vertical-align:super;position:relative;top:-.04em;background-color:currentColor;opacity:.5;-webkit-mask-image:url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 10 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 8L8 2M8 2H4M8 2V6' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 10 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 8L8 2M8 2H4M8 2V6' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}.hdr{display:flex;align-items:center;height:var(--hdr-h);padding:0 var(--gap-sm);border-bottom:1px solid var(--border-light);background:var(--bg);flex-shrink:0;z-index:var(--z-header);gap:var(--space-2)}.hdr-logo{text-decoration:none;display:flex;align-items:center;flex-shrink:0}.hdr-title-group{display:flex;align-items:center;gap:var(--space-1);margin-right:auto;min-width:0}.hdr-title{font-size:var(--text-md);color:var(--ink);letter-spacing:-.02em;text-decoration:none;flex-shrink:0;transition:opacity var(--dur-fast)}.hdr-title:hover{opacity:.6}.hdr-logo-mark{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;color:var(--ink)}.hdr-logo-mark svg{width:18px;height:18px}.hdr-filter{position:relative;display:none}.hdr-filter.visible{display:flex;align-items:center}.hdr-filter-btn{display:flex;align-items:center;gap:4px;border:none;background:0 0;cursor:pointer;font-family:var(--font);font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--ink2);padding:4px;border-radius:var(--r-xs);letter-spacing:-.02em;transition:color var(--dur-fast),background var(--dur-fast)}.hdr-filter-btn:hover{color:var(--ink);background:var(--surface2)}.hdr-filter-btn.active{color:var(--ink)}.hdr-filter-label{white-space:nowrap}.hdr-filter-chevron{display:flex;align-items:center;opacity:.45;flex-shrink:0;transition:transform var(--dur-fast)}.hdr-filter-btn[aria-expanded=true] .hdr-filter-chevron{transform:rotate(180deg);opacity:.8}.hdr-filter-panel{position:absolute;top:calc(100% + 6px);left:0;min-width:160px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-md);z-index:var(--z-chip);display:none;flex-direction:column;padding:var(--space-1)0}.hdr-filter-panel.open{display:flex}.hdr-filter-overlay{display:none;position:fixed;inset:0;z-index:calc(var(--z-chip) - 1)}.hdr-filter-overlay.open{display:block}.hdr-filter-item{display:block;width:100%;text-align:left;font-family:var(--font);font-size:var(--text-base);color:var(--ink2);padding:8px var(--space-4);border:none;background:0 0;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.hdr-filter-item:hover{background:var(--surface2);color:var(--ink)}.hdr-filter-item.active{color:var(--accent);font-weight:var(--weight-semibold)}.latest-chip{position:fixed;top:calc(var(--hdr-h) + 10px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);font-size:var(--text-sm);padding:5px 13px;border-radius:var(--r-pill);cursor:pointer;z-index:var(--z-chip);display:none;box-shadow:var(--shadow-sm);white-space:nowrap}.latest-chip.visible{display:block}@media(max-width:639px){.latest-chip{display:none!important}}.fab{position:fixed;bottom:20px;right:20px;z-index:var(--z-fab);display:flex;align-items:center;background:color-mix(in srgb,var(--bg) 75%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 5px;gap:1px;box-shadow:var(--shadow-md)}.fab-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:0 0;color:var(--ink);cursor:pointer;border-radius:var(--r-full);opacity:.5;transition:opacity var(--dur-fast),background var(--dur-fast);flex-shrink:0}.fab-btn:hover{opacity:1;background:var(--surface2)}.fab-btn.active{opacity:1;color:var(--accent)}.fab-btn[data-tooltip]{position:relative}.fab-btn[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-semibold);padding:4px 9px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--dur-fast);z-index:var(--z-tooltip)}.fab-btn[data-tooltip]:hover::after{opacity:1}@media(min-width:640px){.fab-btn[data-tooltip]::after{bottom:auto;top:calc(100% + 7px)}}.fab-sep{width:1px;height:14px;background:var(--border);opacity:1;flex-shrink:0;margin:0 2px}.fab-panel{position:fixed;bottom:calc(20px + 38px + 10px);right:20px;width:220px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-md);z-index:calc(var(--z-fab) - 1);overflow:hidden;display:none;flex-direction:column}.fab-panel.open{display:flex}.fab-panel-inner{display:flex;flex-direction:column;max-height:280px;overflow-y:auto;padding:var(--space-1)0}.fab-filter-item,.fab-panel-item{display:block;width:100%;text-align:left;font-family:var(--font);font-size:var(--text-base);color:var(--ink2);padding:10px var(--space-4);border:none;background:0 0;cursor:pointer;transition:background .1s;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fab-filter-item:hover,.fab-panel-item:hover{background:var(--surface2);color:var(--ink)}.fab-filter-item.active{color:var(--accent);font-weight:var(--weight-semibold)}.fab-panel-search{padding:var(--space-2)var(--space-3);border-bottom:1px solid var(--border-light);flex-shrink:0}.fab-panel-input{width:100%;border:none;outline:none;font-family:var(--font);font-size:var(--text-base);color:var(--ink);background:0 0;padding:var(--space-1)0}.fab-panel-input::placeholder{color:var(--ink2);opacity:.5}.fab-panel-empty{padding:var(--space-3)var(--space-4);font-size:var(--text-sm);color:var(--ink2)}.fab-panel-overlay{display:none;position:fixed;inset:0;z-index:calc(var(--z-fab) - 2)}.fab-panel-overlay.open{display:block}.site-footer{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0 var(--space-3);padding:var(--space-10)var(--gap-sm)var(--space-8);margin-top:auto}.sf-name{font-size:var(--text-sm);color:var(--ink2);font-weight:var(--weight-semibold)}.sf-dot{font-size:var(--text-sm);color:var(--ink2);opacity:.35}.sf-link{font-size:var(--text-sm);color:var(--ink2);text-decoration:none;transition:color var(--dur-fast)}.sf-link:hover{color:var(--ink)}.note-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-display);letter-spacing:-.02em}.note-content{margin-bottom:var(--space-12)}.note-backlinks{border-top:1px solid var(--border-light);padding-top:20px;margin-top:0}.note-backlinks-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--ink2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.note-backlinks-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.note-backlink-item{display:block;font-size:var(--text-base);color:var(--ink);text-decoration:none;padding:10px var(--space-3);background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-sm);transition:border-color var(--dur-fast),background var(--dur-fast),color var(--dur-fast);line-height:var(--lh-tight)}.note-backlink-item:hover{color:var(--accent);border-color:var(--border);background:var(--surface2)}@media(max-width:639px){.note-backlinks-grid{grid-template-columns:1fr}}.nsm{display:none;position:fixed;inset:0;z-index:var(--z-modal);background:var(--overlay);align-items:flex-start;justify-content:center;padding-top:72px;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.nsm.open{display:flex}.nsm-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);width:min(520px,calc(100vw - 32px));max-height:60vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.nsm-input-wrap{display:flex;align-items:center;gap:10px;padding:14px var(--space-4);border-bottom:1px solid var(--border-light);flex-shrink:0}.nsm-icon{color:var(--ink2);display:flex;align-items:center;flex-shrink:0}.nsm-input{flex:1;border:none;outline:none;font-family:var(--font);font-size:var(--text-md);color:var(--ink);background:0 0;min-width:0}.nsm-input::placeholder{color:var(--ink2);opacity:.5}.nsm-close{width:24px;height:24px;border:none;background:0 0;color:var(--ink2);cursor:pointer;font-size:var(--text-sm);display:flex;align-items:center;justify-content:center;border-radius:var(--r-full);transition:color var(--dur-fast),background var(--dur-fast);flex-shrink:0}.nsm-close:hover{color:var(--ink);background:var(--surface2)}.nsm-results{flex:1;overflow-y:auto;padding:6px 0}.nsm-item{display:block;padding:10px var(--space-4);font-size:var(--text-base);color:var(--ink2);text-decoration:none;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nsm-item:hover{background:var(--surface2);color:var(--ink)}.nsm-empty{padding:20px var(--space-4);font-size:var(--text-base);color:var(--ink2);text-align:center}.sp-index-btn{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-sm);color:var(--ink2);text-decoration:none;padding:5px 0;transition:color var(--dur-fast),border-color var(--dur-fast),background var(--dur-fast)}.sp-index-btn:hover{color:var(--ink);border-color:var(--ink2);background:var(--surface2)}.sp-index-arrow{font-size:var(--text-sm);opacity:.7}@media(max-width:639px){.fab-btn{width:36px;height:36px}.fab{padding:4px 6px}}@media(min-width:640px){.hdr{padding:0 var(--gap)}.fab{bottom:auto;top:calc(var(--hdr-h)/2);transform:translateY(-50%);right:var(--gap)}.fab-panel{bottom:auto;top:calc(var(--hdr-h) + 8px);right:var(--gap)}.site-footer{padding:14px var(--gap)}}.card{margin-bottom:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}.card:active{opacity:.85}.card-below{padding:var(--space-1)0 var(--space-2)}.card-title{font-size:var(--text-sm);font-weight:var(--weight-normal);color:var(--ink);line-height:var(--lh-tight);display:inline}.card-rec{font-size:var(--text-sm);color:var(--ink);margin-left:5px;display:inline;vertical-align:middle}.ext-badge{width:22px;height:22px;border-radius:var(--r-full);background:var(--surface2);border:1px solid var(--border-light);display:inline-flex;align-items:center;justify-content:center;color:var(--ink2);cursor:pointer;flex-shrink:0;transition:background .12s;text-decoration:none}.ext-badge:hover{background:var(--border)}.card-cover{border-radius:var(--r-xs)var(--r-sm)var(--r-sm)var(--r-xs);overflow:hidden;position:relative;box-shadow:-3px 2px 10px rgba(0,0,0,.18),1px 1px 5px rgba(0,0,0,7%);transition:box-shadow .2s,transform .2s}.card:hover .card-cover{box-shadow:-5px 4px 16px rgba(0,0,0,.22),2px 2px 7px rgba(0,0,0,9%);transform:translateY(-1px)}.card-cover-img{width:100%;object-fit:cover;display:block;background:var(--surface2)}.card-cover-blank{width:100%;aspect-ratio:3/4;background:var(--surface2)}.card-spine{position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(to right,rgba(0,0,0,.22),transparent)}[data-theme=ink] .card-cover{box-shadow:-4px 3px 14px rgba(0,0,0,.55),2px 2px 6px rgba(0,0,0,.3)}[data-theme=ink] .card:hover .card-cover{box-shadow:-6px 5px 20px rgba(0,0,0,.65),3px 3px 8px rgba(0,0,0,.35)}.bm-card{border-radius:var(--r);overflow:hidden;border:1px solid var(--border-light);background:var(--surface);transition:border-color .15s,box-shadow .15s}.card:hover .bm-card{border-color:var(--border);box-shadow:0 3px 16px rgba(0,0,0,6%)}.bm-bar{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1)10px;border-bottom:1px solid var(--border-light);background:var(--surface2)}.bm-dots{display:flex;gap:var(--space-1);flex-shrink:0}.bm-dots span{width:8px;height:8px;border-radius:var(--r-full)}.bm-dots span:nth-child(1){background:var(--mac-dot-red)}.bm-dots span:nth-child(2){background:var(--mac-dot-yellow)}.bm-dots span:nth-child(3){background:var(--mac-dot-green)}.bm-url{flex:1;font-size:var(--text-sm);color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic;background:var(--surface);border-radius:var(--r-xs);padding:2px 6px}.bm-ext{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--ink2);text-decoration:none;transition:color .12s}.bm-ext:hover{color:var(--ink)}.bm-body{padding:var(--space-4)}.bm-title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-tight);margin-bottom:var(--space-2)}.bm-note{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-display);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media(max-width:639px){.card-title{font-size:var(--text-base);font-weight:var(--weight-semibold);line-height:var(--lh-display)}.bm-note{display:none}}.nl-card-wrap{display:block;text-decoration:none;position:relative}.nl-card{border-radius:var(--r);overflow:hidden;border:1px solid var(--border-light);background:var(--surface);transform:rotate(var(--rot,-1.5deg));box-shadow:var(--shadow-sm);transition:transform .25s cubic-bezier(.34,1.15,.64,1),box-shadow .25s ease}.nl-card-wrap:hover .nl-card{transform:rotate(0)translateY(-2px);box-shadow:var(--shadow-md)}.nl-card-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.nl-card-blank{width:100%;aspect-ratio:16/9;background:var(--surface2)}.nl-card-ext{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--r-xs);background:var(--bg);border:1px solid var(--border-light);color:var(--ink2);opacity:0;transform:translateY(5px);transition:opacity .18s ease,transform .22s cubic-bezier(.34,1.2,.64,1);pointer-events:none}.nl-card-wrap:hover .nl-card-ext{opacity:1;transform:translateY(0)}.sheet-overlay{position:fixed;inset:0;background:var(--overlay);z-index:var(--z-sheet);display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.sheet-overlay.open{display:flex;animation:fade-in .16s ease}.sheet{width:100%;max-width:540px;background:var(--bg);border-radius:var(--r)var(--r)0 0;border-top:1px solid var(--border);max-height:80vh;overflow-y:auto;animation:slide-up .26s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom,var(--space-6))}.sheet-handle{width:40px;height:4px;border-radius:var(--r-2);background:var(--border);margin:var(--space-3)auto 0}.sheet-inner{padding:20px 22px var(--space-6)}@media(max-width:639px){.sheet-inner{padding-bottom:80px}}@media(min-width:640px){.sheet-inner{padding:var(--space-6)var(--space-8)var(--space-12)}}.sh-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:var(--space-4);position:relative}.sh-cover{width:72px;height:96px;object-fit:cover;border-radius:var(--r-xs);flex-shrink:0;background:var(--surface2);box-shadow:-2px 2px 8px rgba(0,0,0,.16);display:block}[data-theme=ink] .sh-cover{box-shadow:-2px 2px 8px rgba(0,0,0,.5)}.sh-cover-blank{width:72px;height:96px;background:var(--surface2);border-radius:var(--r-xs);flex-shrink:0}.sh-info{display:flex;flex-direction:column;gap:var(--space-1);padding-top:2px;flex:1}.sh-title{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-display)}.sh-meta{font-size:var(--text-sm);color:var(--ink2)}.sh-date{font-size:var(--text-sm);color:var(--ink2)}.sh-rule{border:none;border-top:1px solid var(--border-light);margin:14px 0}.sh-body{font-size:var(--text-base);color:var(--ink2);line-height:var(--lh-prose)}.sh-body a{color:var(--ink);text-decoration:none;padding:0 3px;border-radius:var(--r-xs);background-color:var(--accent-subtle);transition:color var(--dur-fast)}.sh-body a:hover{color:var(--accent)}.sh-ext{position:absolute;top:0;right:0}a.sh-row{text-decoration:none;color:inherit;display:flex}a.sh-row:hover .sh-title{color:var(--accent)}.panel-overlay{position:fixed;inset:0;background:var(--overlay);z-index:var(--z-panel);display:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.panel-overlay.open{display:block}.side-panel{position:fixed;top:0;bottom:0;right:0;width:100%;background:var(--bg);z-index:calc(var(--z-panel) + 10);transform:translateX(100%);transition:transform .36s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}@media(min-width:640px){.side-panel{width:85%}}.side-panel.open{transform:translateX(0)}.sp-hdr{display:flex;align-items:center;padding:var(--space-4)var(--gap);flex-shrink:0}.sp-back{width:28px;height:28px;border-radius:var(--r-sm);background:0 0;border:1px solid var(--border);color:var(--ink2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);transition:all var(--dur-fast)}.sp-back:hover{color:var(--ink);border-color:var(--ink)}.sp-body{flex:1;overflow-y:auto;padding:var(--space-2)var(--space-12)80px;max-width:780px;margin:0 auto;width:100%}@media(max-width:639px){.sp-body{padding:var(--space-2)var(--space-6)60px}}.sp-cover{width:100%;aspect-ratio:16/9;background:var(--surface2);border-radius:var(--r);overflow:hidden;margin-bottom:var(--gap)}.sp-cover img{width:100%;height:100%;object-fit:cover;display:block}.sp-kicker{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--ink2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}.sp-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-display);margin-bottom:var(--space-1);letter-spacing:-.02em}.sp-byline{font-size:var(--text-sm);color:var(--ink2);margin-bottom:var(--space-6)}.sp-updated{font-size:var(--text-sm);color:var(--ink2);margin:6px 0 var(--gap)}.sp-rule{border:none;border-top:1px solid var(--border-light);margin:22px 0 26px}.sp-text{font-size:var(--text-lg);color:var(--ink2);line-height:var(--lh-prose)}.sp-text p{margin-bottom:18px}.sp-text p:last-child{margin-bottom:0}.sp-text h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-display);letter-spacing:-.02em;margin:36px 0 var(--space-3)}.sp-text h3{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--ink);margin:var(--gap)0 var(--space-2)}.sp-text ul,.sp-text ol{margin:0 0 18px 20px}.sp-text li{margin-bottom:6px;line-height:var(--lh-prose)}.sp-text strong{color:var(--ink);font-weight:var(--weight-semibold)}.sp-text em{font-style:italic}.sp-text blockquote{border-left:2px solid var(--border);padding-left:18px;color:var(--ink2);margin:0 0 18px;font-style:italic}.sp-text blockquote p{margin-bottom:0}.sp-text hr{border:none;border-top:1px solid var(--border-light);margin:28px 0}.sp-text pre{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-sm);padding:16px 18px;overflow-x:auto;margin:0 0 20px;font-size:var(--text-sm);line-height:1.6}.sp-text pre code{background:0 0;border:none;padding:0;font-size:inherit;color:var(--ink2)}.sp-text code{font-family:ui-monospace,sf mono,Menlo,Consolas,monospace;font-size:.875em;background:var(--surface2);border:1px solid var(--border-light);border-radius:4px;padding:1px 5px;color:var(--ink)}.sp-text h1{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-display);letter-spacing:-.02em;margin:36px 0 var(--space-3)}.sp-text img{max-width:100%;height:auto;border-radius:var(--r);margin:var(--space-2)0 20px;display:block}.sp-text a{color:var(--ink);text-decoration:none;padding:0 3px;border-radius:var(--r-xs);background-color:var(--accent-subtle);transition:color var(--dur-fast),background-color var(--dur-base)}.sp-text a:hover{color:var(--accent)}.sp-footer{margin-top:var(--space-10);font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-relaxed)}.sp-footer a{color:var(--ink2);text-decoration:underline;text-underline-offset:2px;transition:color var(--dur-fast)}.sp-footer a:hover{color:var(--ink)}.now-meta{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-relaxed);margin-bottom:var(--gap)}.now-meta a{color:var(--ink2);text-decoration:underline;text-underline-offset:2px;transition:color var(--dur-fast);background:0 0}.now-meta a:hover{color:var(--ink)}.colo-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-top:var(--gap)}.colo-card{display:block;padding:var(--space-3)14px;border:1px solid var(--border-light);border-radius:var(--r);text-decoration:none;transition:border-color var(--dur-fast),background var(--dur-fast)}.colo-card:hover{border-color:var(--border);background:var(--surface)}.colo-name{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--ink);margin-bottom:3px}.colo-desc{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-tight)}@media(max-width:639px){.colo-grid{grid-template-columns:1fr}}.colo-section-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.07em;text-transform:uppercase;color:var(--ink2);margin:36px 0 14px}.colo-people-intro{margin-bottom:20px}.people-badges{display:flex;flex-wrap:wrap;gap:6px}.people-badge{position:relative;text-decoration:none;flex-shrink:0}.people-badge-plain{cursor:default}.people-avatar{width:36px;height:36px;border-radius:var(--r-full);object-fit:cover;display:block;background:var(--surface2);border:2px solid var(--bg);transition:transform .15s ease}.people-avatar-init{width:36px;height:36px;border-radius:var(--r-full);background:var(--surface2);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:var(--text-base);color:var(--ink2)}.people-badge:hover .people-avatar,.people-badge:hover .people-avatar-init{transform:translateY(-3px)}.people-tip{position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:var(--space-1)9px;border-radius:var(--r-sm);white-space:nowrap;font-size:var(--text-sm);font-weight:var(--weight-semibold);opacity:0;pointer-events:none;transition:opacity var(--dur-fast);z-index:var(--z-tooltip)}.people-badge:hover .people-tip{opacity:1}.wikilink{color:var(--ink);text-decoration:none;padding:0 3px;border-radius:var(--r-xs);background-color:var(--accent-subtle);transition:color var(--dur-fast);cursor:pointer}.wikilink:hover{color:var(--accent)}.wikilink-dead{position:relative;color:var(--ink2);text-decoration:none;padding:0 3px;border-radius:var(--r-xs);background-color:var(--surface2);cursor:default}.wikilink-dead::after{content:'Private link';position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-semibold);padding:4px 9px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--dur-fast);z-index:var(--z-tooltip)}.wikilink-dead:hover::after{opacity:1}.sp-graph-section{margin-top:var(--space-10);padding-top:20px;border-top:1px solid var(--border-light)}.sp-graph-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.07em;text-transform:uppercase;color:var(--ink2);margin-bottom:var(--space-3)}.sp-backlink-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.sp-backlink-item{font-size:var(--text-base);color:var(--ink2);padding:10px var(--space-3);background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur-fast);line-height:var(--lh-tight);box-shadow:0 1px 4px rgba(0,0,0,4%)}.sp-backlink-item:hover{color:var(--ink);border-color:var(--border);background:var(--surface2)}.sp-outlink-pill{display:inline-block;font-size:var(--text-sm);color:var(--ink2);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 10px;margin:0 var(--space-1)var(--space-1)0;cursor:default}.notes-scroll-area{flex:1;overflow-y:auto;display:flex;flex-direction:column}.notes-reading{flex:1;width:100%;max-width:640px;margin:0 auto;padding:var(--space-8)var(--gap)var(--space-12)}.page-title-row{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-4)}.page-title-row .notes-nav{flex-shrink:0}.page-title-row .note-title{min-width:0}.notes-nav{display:inline-flex}@media(min-width:900px){.page-title-row{display:block}.notes-nav{position:fixed;left:max(var(--gap),calc(50% - 320px - 48px));top:calc(var(--space-8) + 43px + 20px);z-index:var(--z-elevated)}.page-wide .page-title-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:var(--space-4)}.page-wide .notes-nav{position:static;left:auto;top:auto;flex-shrink:0;margin-top:5px}.page-wide .page-title-row .note-title{flex:1}}.notes-intro{font-size:var(--text-lg);color:var(--ink2);line-height:var(--lh-prose);margin:0 0 var(--space-8)}.notes-list{list-style:none;margin:0;padding:0}.notes-list-item{border-bottom:1px solid var(--border-light)}.notes-list-link{display:block;padding:14px 0;font-size:var(--text-md);color:var(--ink2);text-decoration:none;transition:color var(--dur-fast);line-height:var(--lh-tight);letter-spacing:-.01em}.notes-list-link:hover{color:var(--ink)}@media(max-width:639px){.notes-reading{padding:var(--space-6)var(--gap-sm)var(--space-10)}}.anti-list .notes-list-item{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4);padding:var(--space-3)0}.anti-title{font-size:var(--text-md);color:var(--ink2);line-height:var(--lh-tight);letter-spacing:-.01em;flex:1;min-width:0}.anti-author{font-size:var(--text-sm);color:var(--ink2);white-space:nowrap;flex-shrink:0}.now-reading{margin-top:var(--space-10)}.now-reading-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-4)}.now-reading-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--ink2);text-transform:uppercase;letter-spacing:.06em}.now-reading-link{font-size:var(--text-sm);color:var(--ink2);text-decoration:none;transition:color var(--dur-fast)}.now-reading-link:hover{color:var(--ink)}.now-reading-grid{display:flex;gap:var(--space-4);flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:var(--space-2);scroll-snap-type:x mandatory}.now-reading-grid::-webkit-scrollbar{display:none}.now-book{width:116px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-2);scroll-snap-align:start;transition:transform .2s ease,opacity .2s ease}.now-book:hover{transform:translateY(-4px);opacity:.9}.now-book-cover{position:relative;width:116px;height:154px;border-radius:var(--r-xs);overflow:hidden;background:var(--surface2);box-shadow:-3px 3px 10px rgba(0,0,0,.18);flex-shrink:0}[data-theme=ink] .now-book-cover{box-shadow:-3px 3px 10px rgba(0,0,0,.5)}.now-book-cover img{width:100%;height:100%;object-fit:cover;display:block}.now-book-blank{width:100%;height:100%;background:var(--surface2)}.now-book-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--ink);line-height:var(--lh-tight)}.now-book-author{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-tight)}.l-row{position:relative;display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4);padding:14px 0;border-bottom:1px solid var(--border-light);cursor:pointer}.l-row:last-child{border-bottom:none}.l-title{font-size:var(--text-md);color:var(--ink2);font-weight:var(--weight-normal);flex:1;min-width:0;line-height:var(--lh-tight);display:flex;align-items:center;gap:var(--space-1);transition:color .15s}.l-row:hover .l-title{color:var(--ink)}.l-tag{font-size:var(--text-sm);color:var(--ink2);font-weight:var(--weight-normal);flex-shrink:0;white-space:nowrap;display:flex;align-items:center;gap:5px}.l-ext{display:inline-flex;align-items:center;opacity:.5}.l-row[data-type=newsletter] .l-ext{opacity:0;transform:translateY(3px);transition:opacity .18s ease,transform .2s cubic-bezier(.34,1.2,.64,1)}.l-row[data-type=newsletter]:hover .l-ext{opacity:1;transform:translateY(0)}@media(min-width:1024px){.l-view{padding-left:max(var(--gap),calc((100% - 900px)/2))!important;padding-right:max(var(--gap),calc((100% - 900px)/2))!important}}#lTip{position:fixed;width:150px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg);box-shadow:var(--shadow-md);overflow:hidden;opacity:0;pointer-events:none;z-index:calc(var(--z-sheet) - 10);transition:opacity var(--dur-fast)}#lTip.show{opacity:1}.l-tip-img{width:100%;aspect-ratio:2/3;background:var(--surface2);overflow:hidden}.l-tip-img.wide{aspect-ratio:16/9}.l-tip-img img{width:100%;height:100%;object-fit:cover;display:block}@keyframes fade-in{from{opacity:0}to{opacity:1}}@keyframes slide-up{from{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes card-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes row-in{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}.card{animation:card-in .32s ease both;animation-delay:calc(var(--i,0) * 50ms)}.l-row{animation:row-in .28s ease both;animation-delay:calc(var(--i,0) * 40ms)}.home-page{display:flex;flex-direction:column;min-height:100dvh}.home-nav{display:flex;align-items:center;padding:var(--space-4)var(--gap-sm);flex-shrink:0}@media(min-width:640px){.home-nav{padding:20px var(--gap)}}.home-body{flex:1;display:flex;flex-direction:column;justify-content:center;padding:4vh var(--gap-sm);max-width:600px;margin:0 auto;width:100%}@media(min-width:640px){.home-body{padding:4vh var(--gap)5vh}}.home-p{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-normal);color:var(--ink);line-height:var(--lh-prose);letter-spacing:-.01em;margin:0}.home-p2,.home-p3{margin-top:var(--gap)}@media(min-width:640px){.home-p{font-size:var(--text-2xl)}}.page-avatar{display:block;width:40px;height:40px;border-radius:var(--r-sm);overflow:hidden;margin:0 0 20px -10px;text-decoration:none;flex-shrink:0}.page-avatar img,.page-avatar svg{width:100%;height:100%;object-fit:cover;display:block}.home-avatar{position:relative;display:inline-block;vertical-align:middle;width:60px;height:60px;border-radius:var(--r-sm);overflow:hidden;margin-left:-8px;margin-right:2px;margin-bottom:var(--space-4);flex-shrink:0;cursor:default;z-index:1;transition:transform .32s cubic-bezier(.34,1.15,.64,1),border-radius .28s ease}.home-avatar svg{width:60px;height:60px;display:block;transition:opacity .18s ease}.home-avatar-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .22s ease .06s}.home-avatar:hover{transform:scale(1.6);border-radius:var(--r-2);z-index:var(--z-header)}.home-avatar:hover .home-avatar-img{opacity:1}.home-avatar:hover svg{opacity:0}@media(hover:none){.home-avatar:hover{transform:none;border-radius:var(--r-sm)}.home-avatar:hover .home-avatar-img{opacity:0}.home-avatar:hover svg{opacity:1}}.home-avatar{opacity:0;animation:homeFadeIn .5s ease 0s both}@keyframes homeFadeIn{from{opacity:0}to{opacity:1}}.home-p1{opacity:0;animation:homeSlideUp .55s cubic-bezier(.22,1,.36,1).05s both}.home-p2{opacity:0;animation:homeSlideUp .55s cubic-bezier(.22,1,.36,1).16s both}.home-p3{opacity:0;animation:homeSlideUp .55s cubic-bezier(.22,1,.36,1).27s both}@keyframes homeSlideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.home-link{color:var(--ink);text-decoration:none;padding:var(--space-1);border-radius:var(--r-xs);background-color:var(--accent-subtle);transition:text-decoration-color .18s,text-underline-offset .18s,background-color .2s ease}.home-link:hover{color:var(--accent)}.home-email-wrap{position:relative;display:inline}.home-email{font-family:var(--font);font-size:inherit;font-weight:inherit;color:var(--ink);background-color:var(--accent-subtle);border:none;padding:var(--space-1);margin:0 -4px;cursor:pointer;border-radius:var(--r-xs);text-decoration:none;transition:background-color .2s ease}.home-email:hover{color:var(--accent)}.home-email-tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%)translateY(6px);background:var(--bg);color:var(--ink2);font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-semibold);padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--border);box-shadow:var(--shadow-md);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .18s ease,transform .22s cubic-bezier(.34,1.2,.64,1)}.home-email-tip.show{opacity:1;transform:translateX(-50%)translateY(0)}.tip-check{color:var(--accent);font-weight:var(--weight-semibold);margin-right:3px}.ev-wrap{position:relative;display:inline-block}.ev-pill{color:var(--ink);font-weight:inherit;text-decoration:none;border-radius:var(--r-xs);padding:var(--space-1);margin:0 -4px;background-color:var(--accent-subtle);transition:background-color .2s ease}.ev-wrap:hover .ev-pill{color:var(--accent)}.ev-deck{position:absolute;bottom:0;left:50%;width:0;height:0;pointer-events:none;z-index:var(--z-chip)}.ev-deck::after{content:'';position:absolute;bottom:-8px;left:-80px;width:160px;height:12px}.ev-card{position:absolute;left:50%;bottom:0;white-space:nowrap;padding:var(--space-1)11px 5px;border-radius:var(--r-pill);border:1px solid var(--border);background:var(--bg);box-shadow:var(--shadow-sm);font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.05em;text-transform:uppercase;color:var(--ink2);text-decoration:none;opacity:0;transform:translateX(-50%)translateY(4px)scale(.88);transition:transform .35s cubic-bezier(.34,1.1,.64,1)calc(var(--i,0) * .05s),opacity .2s ease calc(var(--i,0) * .05s)}.ev-wrap:hover .ev-deck{pointer-events:none}.ev-wrap:hover .ev-card:nth-child(1){opacity:1;transform:translateX(calc(-50% - 72px))translateY(-44px)rotate(-8deg)scale(1)}.ev-wrap:hover .ev-card:nth-child(2){opacity:1;transform:translateX(calc(-50% + 4px))translateY(-68px)rotate( 2deg)scale(1)}.ev-wrap:hover .ev-card:nth-child(3){opacity:1;transform:translateX(calc(-50% + 72px))translateY(-44px)rotate(8deg)scale(1)}.ev-card:hover{color:var(--ink);border-color:var(--ink2)}.wn-cursor::after{content:'';display:inline-block;width:1.5px;height:.85em;background:currentColor;margin-left:2px;vertical-align:-.05em;opacity:0}.wn-cursor:hover::after{opacity:1;animation:wn-blink 1s step-end infinite}@keyframes wn-blink{0%,100%{opacity:1}50%{opacity:0}}.tt-link{position:relative;display:inline-block;vertical-align:baseline;padding:0 4px}.tt-default{display:inline;transition:opacity .15s ease}.tt-hover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;color:var(--accent);transform:translateY(4px);transition:opacity .18s ease,transform .22s cubic-bezier(.34,1.2,.64,1)}.tt-link:hover .tt-default{opacity:0}.tt-link:hover .tt-hover{opacity:1;transform:translateY(0)}.tt-link[href^=http]::after{transition:opacity .15s ease}.tt-link:hover[href^=http]::after{opacity:0}.tnt-wrap{position:relative;display:inline-block}.tnt-tip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%)translateY(6px)scale(.92);opacity:0;transition:opacity .18s ease,transform .22s cubic-bezier(.34,1.2,.64,1);z-index:var(--z-header)}.tnt-tip svg{width:100%;height:100%;display:block}.tnt-wrap:hover .tnt-tip{opacity:1;transform:translateX(-50%)translateY(0)scale(1)}.tnt-logo-static{display:inline-block;vertical-align:middle;line-height:0;opacity:.7}.tnt-logo-svg{display:inline-flex;align-items:center}.tnt-logo-svg svg{height:18px;width:auto;display:block}.wow-wrap{position:relative;display:inline-block}.wow-logo{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%)translateY(4px)scale(.92);pointer-events:none;opacity:0;transition:opacity .15s ease,transform .15s ease;z-index:var(--z-elevated)}.wow-logo svg{display:block;height:28px;width:auto;border-radius:var(--r-xs)}.wow-wrap:hover .wow-logo{opacity:1;transform:translateX(-50%)translateY(0)scale(1)}.page-wide{max-width:1040px}.page-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-8);margin-top:var(--space-6);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}@media(min-width:640px){.page-filters{flex-wrap:wrap;overflow-x:visible}}.page-filter-btn{font-family:var(--font);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--ink2);background:0 0;border:1px solid var(--border-light);border-radius:var(--r-pill);padding:5px 14px;cursor:pointer;transition:color .15s,background .15s,border-color .15s;white-space:nowrap;flex-shrink:0}.page-filter-btn:hover{color:var(--ink);border-color:var(--border)}.page-filter-btn.is-active{color:var(--ink);background:var(--surface2);border-color:var(--border)}.uses-intro{color:var(--ink2);margin-bottom:0!important}.uses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.uses-card{border:1px solid var(--border-light);border-radius:var(--r);overflow:hidden;background:var(--surface);transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.uses-card[hidden]{display:none}.uses-card:hover{border-color:var(--border);box-shadow:0 3px 16px rgba(0,0,0,6%)}.uses-card--rec{border-color:var(--border)}.uses-card-img-wrap{display:block;aspect-ratio:1/1;background:var(--surface2);overflow:hidden;padding:8%;background:#fff}.uses-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.uses-card:hover .uses-card-img{transform:scale(1.03)}.uses-card-body{padding:var(--space-3)var(--space-3)var(--space-4);flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.uses-card-title-row{display:flex;align-items:baseline;gap:var(--space-1);margin-bottom:2px}.uses-card-title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--ink);text-decoration:none;line-height:var(--lh-tight)}.uses-card-title:hover{color:var(--accent)}.uses-card-note{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-relaxed);margin:0;flex:1}.uses-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-2)}.uses-card-date{font-size:var(--text-sm);color:var(--ink2);opacity:.7;white-space:nowrap}.proj-intro{color:var(--ink2);margin-bottom:0!important}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4);margin-top:var(--space-6)}.proj-card{border:1px solid var(--border-light);border-radius:var(--r);overflow:hidden;background:var(--surface);transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.proj-card:hover{border-color:var(--border);box-shadow:0 3px 16px rgba(0,0,0,6%)}.proj-card-img-wrap{display:block;aspect-ratio:16/9;background:var(--surface2);overflow:hidden}.proj-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.proj-card:hover .proj-card-img{transform:scale(1.03)}.proj-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface2)}.proj-card-ph-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--ink2);opacity:.35}.proj-card-body{padding:var(--space-3)var(--space-4)var(--space-4);flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.proj-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.proj-card-title{font-size:var(--text-md);font-weight:var(--weight-semibold);font-family:var(--font-display);color:var(--ink);text-decoration:none;line-height:var(--lh-tight);flex:1}.proj-card-title:hover{color:var(--accent)}.proj-card-ext{display:flex;align-items:center;flex-shrink:0;color:var(--ink2);opacity:.5;transition:opacity .15s,color .15s;margin-top:2px}.proj-card-ext:hover{opacity:1;color:var(--ink)}.proj-card-summary{font-size:var(--text-sm);color:var(--ink2);line-height:var(--lh-relaxed);margin:0;flex:1}.proj-card-year{font-size:var(--text-sm);color:var(--ink2);margin-top:auto;padding-top:var(--space-2)}@media(max-width:480px){.uses-grid{grid-template-columns:1fr 1fr}.proj-grid{grid-template-columns:1fr}}