@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-serif:ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-lg:.5rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--hue:220;--accent:oklch(.58 .16 var(--hue));--accent-2:oklch(.72 .11 var(--hue));--accent-soft:oklch(.95 .04 var(--hue));--accent-ink:oklch(.32 .11 var(--hue));--bg:oklch(.99 .005 var(--hue));--panel:#fff;--ink:oklch(.22 .03 var(--hue));--ink-2:oklch(.44 .03 var(--hue));--ink-3:oklch(.62 .02 var(--hue));--line:oklch(.92 .015 var(--hue));--line-2:oklch(.96 .01 var(--hue));--shadow:0 1px 2px #0f172a0a, 0 8px 24px -12px oklch(.7 .1 var(--hue) / .25);--shadow-lg:0 2px 4px #0f172a0a, 0 24px 48px -24px oklch(.5 .12 var(--hue) / .28);--radius:16px;--radius-sm:10px;--radius-lg:24px;--gap:20px;--font-sans:"IBM Plex Sans","IBM Plex Sans Thai",system-ui,sans-serif;--font-serif:"Fraunces","IBM Plex Sans Thai",Georgia,serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}[data-font=manrope]{--font-sans:"Manrope","IBM Plex Sans Thai",system-ui,sans-serif}[data-font=sarabun]{--font-sans:"Sarabun","IBM Plex Sans",system-ui,sans-serif}[data-density=compact]{--gap:14px;--radius:12px;--radius-lg:18px}[data-theme=dark]{--accent:oklch(.72 .14 var(--hue));--accent-2:oklch(.62 .13 var(--hue));--accent-soft:oklch(.28 .08 var(--hue));--accent-ink:oklch(.88 .08 var(--hue));--bg:oklch(.18 .02 var(--hue));--panel:oklch(.22 .025 var(--hue));--ink:oklch(.96 .01 var(--hue));--ink-2:oklch(.78 .02 var(--hue));--ink-3:oklch(.62 .02 var(--hue));--line:oklch(.3 .03 var(--hue));--line-2:oklch(.26 .025 var(--hue));--shadow:0 1px 2px #00000040, 0 10px 32px -12px #00000073;--shadow-lg:0 2px 4px #0000004d, 0 24px 60px -24px #0009}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.55}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0}img{max-width:100%;display:block}.container{max-width:1180px;margin:0 auto;padding:0 28px}.container-narrow{max-width:760px;margin:0 auto;padding:0 28px}.nav{z-index:30;-webkit-backdrop-filter:saturate(140%)blur(10px);backdrop-filter:saturate(140%)blur(10px);background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.nav{background:color-mix(in oklch, var(--bg) 82%, transparent)}}.nav{border-bottom:1px solid var(--line)}.nav-inner{align-items:center;gap:24px;height:64px;display:flex}.brand{letter-spacing:-.01em;align-items:center;gap:10px;font-weight:600;display:flex}.brand-mark{background:linear-gradient(135deg, var(--accent), var(--accent-2));width:30px;height:30px;box-shadow:inset 0 1px 0 #fff6, 0 4px 12px -4px var(--accent);border-radius:10px;position:relative}.brand-mark:after{content:"";background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 55%);border-radius:6px;position:absolute;inset:6px}.nav-links{gap:4px;margin-left:12px;display:flex}.nav-link{color:var(--ink-2);border-radius:999px;padding:8px 14px;font-size:14px;font-weight:500;transition:color .15s,background .15s}.nav-link:hover{color:var(--ink);background:var(--line-2)}.nav-link.active{color:var(--accent-ink);background:var(--accent-soft)}.nav-right{align-items:center;gap:8px;margin-left:auto;display:flex}.search{background:var(--panel);border:1px solid var(--line);border-radius:999px;align-items:center;gap:8px;width:260px;padding:7px 12px;transition:border-color .15s,box-shadow .15s;display:flex}.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.search input{color:inherit;font:inherit;background:0 0;border:0;outline:0;flex:1;font-size:14px}.search kbd{font-family:var(--font-mono);color:var(--ink-3);border:1px solid var(--line);background:var(--bg);border-radius:6px;padding:1px 6px;font-size:11px}.icon-btn{width:38px;height:38px;color:var(--ink-2);border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.icon-btn:hover{background:var(--line-2);color:var(--ink)}.icon-btn.primary{background:var(--accent);color:#fff}.icon-btn.primary:hover{background:var(--accent-ink);color:#fff}.hero{border-bottom:1px solid var(--line);padding:56px 0 32px;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(600px 260px at 15% 0%, var(--accent-soft), transparent 60%), radial-gradient(500px 220px at 95% 40%, var(--accent), transparent 60%);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.hero:before{background:radial-gradient(600px 260px at 15% 0%, var(--accent-soft), transparent 60%), radial-gradient(500px 220px at 95% 40%, color-mix(in oklch, var(--accent) 18%, transparent), transparent 60%)}}.hero:before{opacity:.9}.hero-inner{grid-template-columns:1.2fr .9fr;align-items:center;gap:48px;display:grid;position:relative}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.eyebrow .dot{background:var(--accent);border-radius:999px;width:6px;height:6px}.hero h1{font-family:var(--font-serif);letter-spacing:-.02em;text-wrap:balance;margin:18px 0 16px;font-size:clamp(38px,5vw,60px);font-weight:500;line-height:1.02}.hero h1 em{color:var(--accent);font-style:italic;font-weight:500}.hero p{color:var(--ink-2);text-wrap:pretty;max-width:54ch;font-size:18px}.hero-cta{flex-wrap:wrap;gap:12px;margin-top:22px;display:flex}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:999px;align-items:center;gap:8px;padding:11px 18px;font-size:14px;font-weight:500;transition:transform 80ms,background .15s,border-color .15s;display:inline-flex}.btn:hover{border-color:var(--ink-3)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px -6px var(--accent);border-color:#0000}.btn.primary:hover{background:var(--accent-ink)}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--line-2)}.hero-visual{aspect-ratio:5/4;border-radius:var(--radius-lg);background:linear-gradient(160deg, var(--accent-soft), var(--panel));border:1px solid var(--line);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.hero-visual .shape{border-radius:40% 60% 55% 45%/50%;position:absolute}.hv-1{aspect-ratio:1;background:radial-gradient(circle at 35% 35%, var(--accent-2), var(--accent));filter:blur(.5px);opacity:.9;width:60%;top:-12%;right:-10%}.hv-2{aspect-ratio:1;background:linear-gradient(135deg, var(--panel), var(--accent-soft));border:1px solid var(--line);width:42%;bottom:-8%;left:8%}.hv-3{aspect-ratio:1;background:var(--panel);border:1px solid var(--line);width:28%;box-shadow:var(--shadow);bottom:14%;right:18%}.hv-grid{background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);opacity:.4;background-size:28px 28px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 75%);mask-image:radial-gradient(circle,#000,#0000 75%)}.hv-tag{background:var(--panel);border:1px solid var(--line);color:var(--ink-2);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:flex;position:absolute;top:20px;left:20px}.hv-tag .dot{background:#22c55e;border-radius:999px;width:6px;height:6px}.hv-chip{background:var(--accent);color:#fff;font-family:var(--font-mono);box-shadow:0 10px 24px -8px var(--accent);border-radius:14px;padding:10px 14px;font-size:12px;position:absolute;bottom:18px;right:18px}[data-hero=center] .hero-inner{text-align:center;grid-template-columns:1fr;justify-items:center}[data-hero=center] .hero p{margin-left:auto;margin-right:auto}[data-hero=center] .hero-visual{display:none}[data-hero=center] .hero-cta{justify-content:center}[data-hero=minimal] .hero{padding:36px 0 20px}[data-hero=minimal] .hero:before,[data-hero=minimal] .hero-visual{display:none}[data-hero=minimal] .hero-inner{grid-template-columns:1fr}[data-hero=minimal] .hero h1{font-size:clamp(30px,3.6vw,44px)}.section{padding:56px 0}.section-head{justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:24px;display:flex}.section-head h2{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-size:30px;font-weight:500}.section-head .sub{color:var(--ink-3);font-size:14px}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{color:var(--ink-2);background:var(--panel);border:1px solid var(--line);border-radius:999px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;transition:all .15s;display:inline-flex}.chip:hover{color:var(--ink);border-color:var(--ink-3)}.chip.active{background:var(--accent);color:#fff;border-color:#0000}.chip .count{color:var(--ink-3);font-size:12px}.chip.active .count{color:#fffc}.feed{grid-template-columns:1.3fr .9fr;align-items:start;gap:32px;display:grid}@media (max-width:900px){.feed{grid-template-columns:1fr}}.post-list{flex-direction:column;gap:12px;display:flex}.post-card{border-radius:var(--radius);background:var(--panel);border:1px solid var(--line);cursor:pointer;grid-template-columns:160px 1fr;gap:20px;padding:18px;transition:border-color .15s,transform .15s,box-shadow .15s;display:grid}.post-card:hover{border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.post-card:hover{border-color:color-mix(in oklch, var(--accent) 50%, var(--line))}}.post-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.post-thumb{aspect-ratio:4/3;border-radius:var(--radius-sm);background:var(--accent-soft);position:relative;overflow:hidden}.post-meta{color:var(--ink-3);align-items:center;gap:10px;font-size:13px;display:flex}.post-meta .sep{opacity:.6;background:currentColor;border-radius:999px;width:3px;height:3px}.post-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:8px 0 6px;font-size:22px;font-weight:500;line-height:1.2}.post-excerpt{color:var(--ink-2);font-size:14.5px;line-height:1.55}.post-foot{color:var(--ink-3);align-items:center;gap:10px;margin-top:12px;font-size:13px;display:flex}.post-tag{color:var(--accent-ink);background:var(--accent-soft);border-radius:6px;padding:3px 8px;font-size:12px}[data-card=minimal] .post-card{border-color:#0000;border-bottom:1px solid var(--line);background:0 0;border-radius:0;grid-template-columns:1fr;padding:20px 0}[data-card=minimal] .post-thumb{display:none}[data-card=minimal] .post-card:hover{box-shadow:none;transform:none}[data-card=cover] .post-card{grid-template-columns:1fr;padding:0;overflow:hidden}[data-card=cover] .post-thumb{aspect-ratio:16/8;border-radius:0}[data-card=cover] .post-body{padding:18px 20px 20px}.featured{border-radius:var(--radius-lg);background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}.featured-cover{aspect-ratio:16/9;background:linear-gradient(130deg, var(--accent-soft), var(--accent-2));position:relative}.featured-body{padding:20px}.featured-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:8px 0;font-size:22px;font-weight:500;line-height:1.25}.side-card{border-radius:var(--radius);background:var(--panel);border:1px solid var(--line);padding:18px}.side-title{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin:0 0 12px;font-size:13px;font-weight:600}.side-list{flex-direction:column;display:flex}.side-list a{border-top:1px solid var(--line-2);color:var(--ink-2);gap:10px;padding:10px 0;font-size:14px;display:flex}.side-list a:first-child{border-top:0}.side-list a:hover{color:var(--accent-ink)}.side-list .num{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600;font-family:var(--font-mono);padding-top:1px;font-size:12px}.thumb{background:linear-gradient(135deg, var(--accent-soft), var(--panel));position:absolute;inset:0;overflow:hidden}.thumb .t-a{aspect-ratio:1;background:radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent));border-radius:50%;width:60%;position:absolute;top:-18%;right:-12%}.thumb .t-b{aspect-ratio:1;background:var(--panel);border:1px solid var(--line);border-radius:30% 70% 60% 40%/60% 40%;width:35%;position:absolute;bottom:-10%;left:12%}.thumb .t-c{aspect-ratio:1;background:var(--panel);border:1px solid var(--line);border-radius:50%;width:22%;position:absolute;bottom:26%;right:28%}.thumb .t-grid{background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);opacity:.45;background-size:20px 20px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 75%);mask-image:radial-gradient(circle,#000,#0000 75%)}.thumb.v-stack{background:linear-gradient(180deg, var(--accent-soft), var(--panel))}.thumb.v-stack .t-a{width:80%;top:-30%;right:-20%}.thumb.v-stack .t-b{width:55%;bottom:-20%;left:-10%}.thumb.v-code{background:oklch(.28 .04 var(--hue))}.thumb.v-code:before{content:"";background:linear-gradient(90deg, transparent 0 12%, oklch(.82 .1 var(--hue) / .6) 12% 40%, transparent 40% 48%, oklch(.78 .14 var(--hue) / .55) 48% 72%, transparent 72%), linear-gradient(90deg, transparent 0 18%, oklch(.7 .1 var(--hue) / .55) 18% 60%, transparent 60%), linear-gradient(90deg, transparent 0 12%, oklch(.75 .12 var(--hue) / .55) 12% 50%, transparent 50% 58%, oklch(.85 .08 var(--hue) / .45) 58% 80%, transparent 80%), linear-gradient(90deg, transparent 0 22%, oklch(.7 .1 var(--hue) / .5) 22% 70%, transparent 70%);opacity:.95;background-position:24px 34px,24px 58px,24px 82px,24px 106px;background-repeat:no-repeat;background-size:100% 14px;position:absolute;inset:0}.thumb.v-code:after{content:"";background:linear-gradient(90deg, oklch(.9 .1 var(--hue)) 0 24px, transparent 24px);border-radius:999px;width:calc(100% - 48px);height:10px;position:absolute;top:16px;left:24px}.thumb.v-design{background:var(--accent-soft)}.thumb.v-design .block{background:var(--panel);border:1px solid var(--line);border-radius:8px;position:absolute}.thumb.v-design .b1{width:38%;height:22%;top:18%;left:12%}.thumb.v-design .b2{background:var(--accent);border-color:#0000;width:28%;height:40%;top:18%;right:14%}.thumb.v-design .b3{width:68%;height:18%;bottom:14%;left:12%}.thumb.v-note{background:var(--panel)}.thumb.v-note:before{content:"";background:var(--accent);border-radius:999px;width:40%;height:8px;position:absolute;top:18px;left:18px;right:18px}.thumb.v-note:after{content:"";background:linear-gradient(var(--line) 1px, transparent 1px);background-size:100% 14px;position:absolute;inset:38px 18px 18px}.article-hero{padding:48px 0 24px}.article-hero h1{font-family:var(--font-serif);letter-spacing:-.02em;text-wrap:balance;margin:12px 0 16px;font-size:clamp(32px,4.2vw,52px);font-weight:500;line-height:1.08}.article-hero .meta{color:var(--ink-3);align-items:center;gap:14px;font-size:14px;display:flex}.avatar{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border-radius:999px;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:inline-flex}.article-layout{grid-template-columns:220px minmax(0,1fr) 240px;gap:48px;padding:24px 0 80px;display:grid}@media (max-width:1060px){.article-layout{grid-template-columns:minmax(0,1fr)}.toc,.article-side{display:none}}.toc{align-self:start;position:sticky;top:88px}.toc-title{color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;margin:0 0 12px;font-size:12px;font-weight:600}.toc a{border-left:2px solid var(--line);color:var(--ink-2);padding:7px 12px;font-size:13.5px;line-height:1.4;transition:all .15s;display:block}.toc a:hover{color:var(--ink);border-color:var(--ink-3)}.toc a.active{color:var(--accent-ink);border-color:var(--accent);background:var(--accent-soft);border-radius:0 8px 8px 0}.toc a.sub{color:var(--ink-3);padding-left:24px;font-size:13px}.prose{max-width:68ch}.prose h1{font-family:var(--font-serif);letter-spacing:-.02em;margin:48px 0 16px;scroll-margin-top:80px;font-size:36px;font-weight:500}.prose h2{font-family:var(--font-serif);letter-spacing:-.015em;margin:40px 0 12px;scroll-margin-top:80px;font-size:28px;font-weight:500}.prose h3{margin:28px 0 8px;scroll-margin-top:80px;font-size:18px}.prose h4{margin:24px 0 8px;scroll-margin-top:80px;font-size:16px;font-weight:600}.prose h5{text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2);margin:20px 0 6px;scroll-margin-top:80px;font-size:14px;font-weight:600}.prose h6{color:var(--ink-3);margin:18px 0 6px;scroll-margin-top:80px;font-size:13px;font-weight:600}.prose p{color:var(--ink);margin:0 0 16px;font-size:17px;line-height:1.7}.prose a{color:var(--accent);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px}.prose a:hover{color:var(--accent-ink)}.prose strong{color:var(--ink);font-weight:600}.prose em{font-style:italic}.prose del{color:var(--ink-3)}.prose blockquote{background:var(--accent-soft);border-radius:0 var(--radius) var(--radius) 0;border-left:3px solid var(--accent);color:var(--accent-ink);font-family:var(--font-serif);margin:24px 0;padding:14px 20px;font-size:18px;font-style:italic}.prose code{font-family:var(--font-mono);background:var(--line-2);color:var(--accent-ink);border-radius:6px;padding:2px 6px;font-size:.88em}.prose pre{background:oklch(.22 .03 var(--hue));color:oklch(.92 .02 var(--hue));border-radius:var(--radius);font-family:var(--font-mono);margin:20px 0;padding:18px 20px;font-size:13.5px;line-height:1.6;overflow-x:auto}.prose pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.prose pre .k{color:oklch(.8 .15 var(--hue))}.prose pre .s{color:#9ed691;color:lab(80.4509% -28.411 27.8605)}.prose pre .c{color:oklch(.6 .02 var(--hue));font-style:italic}.prose ul,.prose ol{color:var(--ink);margin:0 0 16px;padding-left:22px;font-size:17px;line-height:1.7}.prose li{margin:6px 0}.prose img{border-radius:var(--radius);max-width:100%;height:auto;margin:20px 0}.prose hr{border:0;border-top:1px solid var(--line);margin:32px 0}.prose .callout{border-radius:var(--radius);background:var(--accent-soft);color:var(--accent-ink);border:1px solid var(--accent);gap:12px;padding:16px 18px;display:flex}@supports (color:color-mix(in lab, red, red)){.prose .callout{border:1px solid color-mix(in oklch, var(--accent) 30%, var(--line))}}.prose .callout{margin:20px 0}.prose .callout .emoji{font-size:20px}.article-side{flex-direction:column;align-self:start;gap:16px;display:flex;position:sticky;top:88px}.action-stack{background:var(--panel);border:1px solid var(--line);border-radius:999px;flex-direction:column;align-items:center;gap:6px;width:56px;margin-left:auto;padding:12px;display:flex}.action-btn{width:40px;height:40px;color:var(--ink-2);border-radius:999px;justify-content:center;align-items:center;transition:all .15s;display:flex}.action-btn:hover{background:var(--line-2);color:var(--ink)}.action-btn.on{color:var(--accent);background:var(--accent-soft)}.progress{z-index:40;pointer-events:none;background:0 0;height:3px;position:fixed;top:0;left:0;right:0}.progress-bar{background:linear-gradient(90deg, var(--accent), var(--accent-2));transform-origin:0;height:100%;transition:transform .1s linear;transform:scaleX(0)}.comments{border-top:1px solid var(--line);margin-top:48px;padding-top:28px}.comments h3{font-family:var(--font-serif);margin:0 0 16px;font-size:24px;font-weight:500}.comment-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);gap:12px;margin-bottom:20px;padding:14px;display:flex}.comment-box textarea{resize:none;font:inherit;color:inherit;background:0 0;border:0;outline:0;flex:1;min-height:56px;font-size:14.5px;line-height:1.55}.comment{border-top:1px solid var(--line-2);grid-template-columns:36px 1fr;gap:12px;padding:14px 0;display:grid}.comment:first-of-type{border-top:0}.comment .who{font-size:14px;font-weight:600}.comment .when{color:var(--ink-3);margin-left:6px;font-size:12.5px;font-weight:400}.comment .body{color:var(--ink);margin-top:2px;font-size:14.5px}.comment .actions{color:var(--ink-3);gap:14px;margin-top:8px;font-size:12.5px;display:flex}.works-grid{gap:var(--gap);grid-template-columns:repeat(3,1fr);display:grid}@media (max-width:900px){.works-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.works-grid{grid-template-columns:1fr}}.work-card{border-radius:var(--radius);background:var(--panel);border:1px solid var(--line);cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}.work-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.work-cover{aspect-ratio:4/3;position:relative;overflow:hidden}.work-body{padding:14px 16px 16px}.work-title{letter-spacing:-.01em;margin:0;font-size:15.5px;font-weight:600}.work-sub{color:var(--ink-3);margin-top:4px;font-size:13px}.work-year{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.work-card.feature{grid-column:span 2}.work-card.feature .work-cover{aspect-ratio:16/8}.project-hero{padding:40px 0 24px}.project-cover{aspect-ratio:16/8;border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent-soft), var(--accent));border:1px solid var(--line);margin-top:20px;position:relative;overflow:hidden}.project-facts{background:var(--line);border-radius:var(--radius);border:1px solid var(--line);grid-template-columns:repeat(4,1fr);gap:1px;margin:28px 0 40px;display:grid;overflow:hidden}.project-facts div{background:var(--panel);padding:14px 16px}.project-facts .lab{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-size:11.5px;font-weight:600}.project-facts .val{margin-top:4px;font-size:15px}.about-hero{grid-template-columns:1fr 1.3fr;align-items:center;gap:48px;padding:56px 0;display:grid}@media (max-width:780px){.about-hero{grid-template-columns:1fr}}.about-photo{aspect-ratio:4/5;border-radius:var(--radius-lg);background:linear-gradient(160deg, var(--accent-soft), var(--accent-2));border:1px solid var(--line);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.about-photo:after{content:"[ author photo ]";color:var(--panel);font-family:var(--font-mono);opacity:.7;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;inset:0}.about-hero h1{font-family:var(--font-serif);letter-spacing:-.02em;text-wrap:balance;margin:0 0 20px;font-size:clamp(36px,4vw,52px);font-weight:500;line-height:1.05}.about-hero p{color:var(--ink-2);font-size:17px;line-height:1.7}.stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px;display:grid}.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}.stat .num{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--accent);font-size:30px;font-weight:500}.stat .lab{color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-size:12.5px;font-weight:600}.timeline{border-left:1px solid var(--line);flex-direction:column;gap:0;margin-left:8px;display:flex}.t-item{padding:14px 0 14px 24px;position:relative}.t-item:before{content:"";background:var(--panel);border:2px solid var(--accent);border-radius:999px;width:9px;height:9px;position:absolute;top:20px;left:-5px}.t-item .year{font-family:var(--font-mono);color:var(--accent);font-size:12px;font-weight:500}.t-item .t-title{margin-top:2px;font-size:15px;font-weight:600}.t-item .t-desc{color:var(--ink-2);margin-top:4px;font-size:14px}.footer{border-top:1px solid var(--line);color:var(--ink-3);margin-top:40px;padding:40px 0 60px;font-size:13.5px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.tweaks-panel{z-index:60;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);width:320px;position:fixed;bottom:20px;right:20px;overflow:hidden;box-shadow:0 24px 60px -20px #0f172a40}.tweaks-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.tweaks-head h3{letter-spacing:-.01em;margin:0;font-size:14px;font-weight:600}.tweaks-body{flex-direction:column;gap:14px;max-height:70vh;padding:14px 18px 18px;display:flex;overflow:auto}.tweak-row{flex-direction:column;gap:6px;display:flex}.tweak-row .label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.seg{background:var(--line-2);border-radius:999px;gap:2px;padding:3px;display:flex}.seg button{color:var(--ink-2);border-radius:999px;flex:1;padding:7px 10px;font-size:12.5px;font-weight:500}.seg button.on{background:var(--panel);color:var(--ink);box-shadow:0 1px 2px #0000000f}input[type=range]{accent-color:var(--accent)}.swatches{flex-wrap:wrap;gap:8px;display:flex}.swatch{cursor:pointer;border:2px solid #0000;border-radius:999px;width:28px;height:28px}.swatch.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--panel) inset}.tag-cloud{flex-wrap:wrap;gap:10px;display:flex}.tag-pill{background:var(--panel);border:1px solid var(--line);color:var(--ink-2);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;font-size:14px;transition:all .15s;display:flex}.tag-pill:hover{color:var(--ink);border-color:var(--accent);transform:translateY(-1px)}@supports (color:color-mix(in lab, red, red)){.tag-pill:hover{border-color:color-mix(in oklch, var(--accent) 50%, var(--line))}}.tag-pill .count{color:var(--ink-3);font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:12px}.tag-pill.hot{background:var(--accent-soft);color:var(--accent-ink);border-color:#0000}.results{flex-direction:column;gap:2px;display:flex}.result{border-radius:var(--radius);border:1px solid var(--line);background:var(--panel);cursor:pointer;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:16px 18px;transition:all .15s;display:grid}.result:hover{border-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.result:hover{border-color:color-mix(in oklch, var(--accent) 40%, var(--line))}}.result:hover{box-shadow:var(--shadow)}.result .kind{text-transform:uppercase;letter-spacing:.08em;color:var(--accent-ink);background:var(--accent-soft);border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600}.result .title{font-size:15px;font-weight:500}.result .snip{color:var(--ink-3);margin-top:2px;font-size:13px}.result mark{background:var(--accent)}@supports (color:color-mix(in lab, red, red)){.result mark{background:color-mix(in oklch, var(--accent) 30%, transparent)}}.result mark{color:inherit;border-radius:3px;padding:0 2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--bg);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}.admin-root{background:var(--bg);grid-template-columns:240px 1fr;min-height:100vh;display:grid}.admin-side{background:var(--panel);border-right:1px solid var(--line);flex-direction:column;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}.admin-brand{border-bottom:1px solid var(--line);align-items:center;gap:10px;margin-bottom:14px;padding:6px 10px 18px;display:flex}.admin-brand .brand-mark{border-radius:8px;width:28px;height:28px}.admin-brand .title{letter-spacing:-.01em;font-size:14px;font-weight:600}.admin-brand .sub{color:var(--ink-3);font-size:11px}.admin-nav{flex-direction:column;gap:2px;display:flex}.admin-nav .group{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:14px 10px 6px;font-size:11px;font-weight:600}.admin-nav a{color:var(--ink-2);cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:9px 10px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.admin-nav a:hover{background:var(--line-2);color:var(--ink)}.admin-nav a.active{background:var(--accent-soft);color:var(--accent-ink)}.admin-nav a .badge{background:var(--accent);color:#fff;border-radius:999px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:600}.admin-side-foot{border-top:1px solid var(--line);align-items:center;gap:10px;margin-top:auto;padding-top:14px;display:flex}.admin-main{flex-direction:column;min-width:0;display:flex}.admin-top{z-index:20;background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.admin-top{background:color-mix(in oklch, var(--bg) 90%, transparent)}}.admin-top{-webkit-backdrop-filter:saturate(140%)blur(10px);backdrop-filter:saturate(140%)blur(10px);border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:10px 14px;padding:16px 28px;display:flex}.admin-top h1{font-family:var(--font-serif);letter-spacing:-.01em;margin:0;font-size:22px;font-weight:500}.admin-top .crumbs{color:var(--ink-3);font-size:13px}.admin-top .right{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;display:flex}.admin-body{flex:1;padding:28px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (max-width:1000px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden}.stat-card .lab{color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.stat-card .num{font-family:var(--font-serif);letter-spacing:-.02em;margin-top:6px;font-size:34px;font-weight:500;line-height:1}.stat-card .delta{font-variant-numeric:tabular-nums;align-items:center;gap:4px;margin-top:6px;font-size:12.5px;font-weight:500;display:inline-flex}.stat-card .delta.up{color:#15803d}.stat-card .delta.down{color:#b45309}.stat-card .spark{opacity:.9;position:absolute;bottom:14px;right:14px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.panel-head{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:14px 16px;display:flex}.panel-head h3{letter-spacing:-.01em;margin:0;font-size:15px;font-weight:600}.panel-head .right{gap:8px;margin-left:auto;display:flex}.table{border-collapse:collapse;width:100%;font-size:14px}.table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);background:var(--line-2);border-bottom:1px solid var(--line);padding:10px 16px;font-size:11.5px;font-weight:600}.table td{border-bottom:1px solid var(--line-2);vertical-align:middle;padding:12px 16px}.table tr:last-child td{border-bottom:0}.table tr.sel td,.table tr:hover td{background:var(--accent-soft)}@supports (color:color-mix(in lab, red, red)){.table tr:hover td{background:color-mix(in oklch, var(--accent-soft) 40%, transparent)}}.row-thumb{background:var(--line-2);border-radius:6px;flex-shrink:0;width:44px;height:32px;position:relative;overflow:hidden}.row-title{align-items:center;gap:12px;min-width:0;display:flex}.row-title .t{color:var(--ink);font-weight:500;line-height:1.3}.row-title .s{color:var(--ink-3);margin-top:2px;font-size:12.5px}.status{border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.status .dot{border-radius:999px;width:6px;height:6px}.status.published{color:#00490c;color:lab(25.9874% -33.9172 30.3241);background:#45ba5026;background:lab(67.3528% -50.581 42.6409/.15)}.status.published .dot{background:#008a22;background:lab(49.8938% -50.813 44.8413)}.status.draft{background:var(--line-2);color:var(--ink-2)}.status.draft .dot{background:var(--ink-3)}.status.scheduled{color:#5f3800;color:lab(27.798% 17.3409 48.0198);background:#d58d252e;background:lab(64.9119% 22.5495 61.7416/.18)}.status.scheduled .dot{background:#b17000;background:lab(53.2002% 25.643 81.037)}.status.pending{color:#5f3800;color:lab(27.798% 17.3409 48.0198);background:#d58d252e;background:lab(64.9119% 22.5495 61.7416/.18)}.status.pending .dot{background:#b17000;background:lab(53.2002% 25.643 81.037)}.status.spam{color:#831a1d;color:lab(28.9798% 44.3251 27.7132);background:#de3b3d26;background:lab(51.5803% 63.2457 38.9399/.15)}.status.spam .dot{background:#d73337;background:lab(49.2539% 63.2983 39.3808)}.status.approved{color:#00490c;color:lab(25.9874% -33.9172 30.3241);background:#45ba5026;background:lab(67.3528% -50.581 42.6409/.15)}.status.approved .dot{background:#008a22;background:lab(49.8938% -50.813 44.8413)}.row-actions{justify-content:flex-end;gap:4px;display:flex}.row-actions .icon-btn{width:32px;height:32px}.row-actions .icon-btn:hover{color:var(--accent)}.row-actions .icon-btn.danger:hover{color:#cc272e;color:lab(45.7636% 63.3818 40.1799);background:#de3b3d1a;background:lab(51.5803% 63.2457 38.9399/.1)}.toolbar{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.toolbar .search{width:280px;padding:5px 12px}.toolbar-seg{background:var(--line-2);border-radius:999px;gap:2px;padding:3px;display:flex}.toolbar-seg button{color:var(--ink-2);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:500}.toolbar-seg button.on{background:var(--panel);color:var(--ink);box-shadow:0 1px 2px #0000000f}.toolbar-seg button .count{color:var(--ink-3);font-variant-numeric:tabular-nums;margin-left:4px;font-size:11.5px}.toolbar-seg button.on .count{color:var(--accent)}.checkbox{border:1.5px solid var(--line);cursor:pointer;background:var(--panel);color:#0000;border-radius:4px;justify-content:center;align-items:center;width:16px;height:16px;transition:all .15s;display:inline-flex}.checkbox.on{background:var(--accent);border-color:var(--accent);color:#fff}.checkbox:hover{border-color:var(--accent)}.editor-layout{background:var(--line);grid-template-columns:1fr 1fr;gap:1px;min-height:calc(100vh - 64px);display:grid}.editor-pane,.preview-pane{background:var(--panel);min-width:0;padding:28px 32px;overflow:auto}.editor-pane .meta{border-bottom:1px solid var(--line);flex-direction:column;gap:14px;margin-bottom:20px;padding-bottom:20px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-size:12px;font-weight:600}.input,.textarea,.select{border:1px solid var(--line);background:var(--panel);width:100%;color:var(--ink);font:inherit;border-radius:10px;padding:10px 14px;font-size:14.5px;transition:border-color .15s,box-shadow .15s}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);outline:none}.title-input{font-family:var(--font-serif);letter-spacing:-.02em;width:100%;color:inherit;background:0 0;border:0;padding:4px 0;font-size:34px;font-weight:500}.title-input:focus{outline:none}.title-input::placeholder{color:var(--ink-3)}.md-input{min-height:400px;font-family:var(--font-mono);resize:vertical;font-size:14px;line-height:1.7}.tag-input-wrap{border:1px solid var(--line);background:var(--panel);border-radius:10px;flex-wrap:wrap;gap:6px;padding:8px 10px;display:flex}.tag-input-wrap input{min-width:120px;font:inherit;color:inherit;background:0 0;border:0;outline:0;flex:1;padding:4px;font-size:14px}.tag-bubble{background:var(--accent-soft);color:var(--accent-ink);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;font-weight:500;display:inline-flex}.autosave{color:var(--ink-3);align-items:center;gap:6px;font-size:12.5px;display:inline-flex}.autosave .dot{background:#5bb661;background:lab(67.0254% -42.0639 34.724);border-radius:999px;width:6px;height:6px}@keyframes pulse{50%{opacity:.3}}.media-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.media-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:all .15s;position:relative;overflow:hidden}.media-item:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-1px)}@supports (color:color-mix(in lab, red, red)){.media-item:hover{border-color:color-mix(in oklch, var(--accent) 40%, var(--line))}}.media-thumb{aspect-ratio:4/3;position:relative}.media-info{padding:10px 12px}.media-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.media-meta{color:var(--ink-3);font-size:11.5px;font-family:var(--font-mono);justify-content:space-between;margin-top:4px;display:flex}.upload-zone{border:2px dashed var(--line);border-radius:var(--radius);color:var(--ink-3);background:var(--panel);flex-direction:column;justify-content:center;align-items:center;min-height:160px;margin-bottom:24px;padding:48px 40px;transition:all .15s;display:flex}.upload-zone:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}.comment-admin{border-bottom:1px solid var(--line-2);grid-template-columns:40px 1fr auto;gap:14px;padding:14px 16px;display:grid}.activity{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid var(--line-2);grid-template-columns:28px 1fr auto;align-items:start;gap:12px;padding:12px 16px;font-size:14px;display:grid}.activity-item:last-child{border-bottom:0}.activity-item .dot{background:var(--accent-soft);width:24px;height:24px;color:var(--accent-ink);border-radius:7px;justify-content:center;align-items:center;display:flex}.activity-item.edit .dot{color:#573000;color:lab(24.2919% 17.748 45.4764);background:#d58d2533;background:lab(64.9119% 22.5495 61.7416/.2)}.activity-item.publish .dot{color:#00490c;color:lab(25.9874% -33.9172 30.3241);background:#45ba5033;background:lab(67.3528% -50.581 42.6409/.2)}.activity-item.draft .dot{background:var(--line-2);color:var(--ink-3)}.activity-item .when{color:var(--ink-3);font-variant-numeric:tabular-nums;font-size:12.5px}.login-wrap{background:linear-gradient(160deg, var(--accent-soft), var(--bg) 60%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:32px}.login-card h1{font-family:var(--font-serif);letter-spacing:-.02em;margin:12px 0 6px;font-size:28px;font-weight:500}.login-card .sub{color:var(--ink-3);margin-bottom:24px;font-size:14px}.login-card .hint{color:var(--ink-3);background:var(--line-2);font-size:12px;font-family:var(--font-mono);border-radius:10px;margin-top:16px;padding:10px}.settings-section{border-bottom:1px solid var(--line);grid-template-columns:240px 1fr;gap:32px;padding:24px 0;display:grid}.settings-section:last-child{border-bottom:0}.settings-section .head h3{letter-spacing:-.01em;margin:0 0 4px;font-size:16px;font-weight:600}.settings-section .head p{color:var(--ink-3);margin:0;font-size:13px}.settings-section .body{flex-direction:column;gap:16px;max-width:520px;display:flex}.chart-body{padding:8px 20px;position:relative}.chart-grid{pointer-events:none;flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:8px 20px}.chart-grid>span{background:var(--line);opacity:.7;height:1px;display:block}.chart{align-items:flex-end;gap:5px;height:180px;display:flex;position:relative}.chart .bar{background:linear-gradient(180deg, var(--accent), var(--accent-2));border-radius:4px 4px 0 0;flex:1;min-height:4px;transition:all .2s;position:relative}.chart .bar:hover{background:var(--accent-ink)}.chart .bar.dim{background:var(--line)}@supports (color:color-mix(in lab, red, red)){.chart .bar.dim{background:color-mix(in oklch, var(--line) 85%, var(--accent) 15%)}}.chart-legend{color:var(--ink-3);font-variant-numeric:tabular-nums;justify-content:space-between;padding:10px 20px 18px;font-size:11px;display:flex}body.admin-mode .nav,body.admin-mode .footer{display:none}.dash-grid{grid-template-columns:1.6fr 1fr;align-items:start;gap:20px;display:grid}@media (max-width:980px){.dash-grid{grid-template-columns:1fr}}.notice{background:var(--accent-soft);color:var(--accent-ink);border-radius:10px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;font-size:13.5px;display:flex}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(8px)scale(.96)}}.toast-stack{z-index:9999;pointer-events:none;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{pointer-events:auto;color:#fff;border-radius:12px;align-items:center;gap:10px;min-width:200px;max-width:360px;padding:11px 18px;font-size:13.5px;font-weight:500;line-height:1.4;animation:.2s cubic-bezier(.34,1.56,.64,1) both toast-in;display:flex;box-shadow:0 4px 24px #0003,0 1px 3px #0000001f}.toast.leaving{animation:.18s both toast-out}.toast.success{background:#004608;background:lab(24.822% -33.9458 30.5679)}.toast.error{background:#82000f;background:lab(26.1938% 57.4319 40.7186)}.toast.warning{background:#794400;background:lab(34.4279% 28.848 73.1808)}.toast.info{background:oklch(.36 .14 var(--hue))}.toast-icon{opacity:.9;flex-shrink:0}.toast-close{opacity:.6;color:inherit;flex-shrink:0;margin-left:auto;padding:0 0 0 8px}.toast-close:hover{opacity:1}@media (max-width:480px){.container,.container-narrow{padding:0 16px}}.nav-menu-btn,.nav-search-icon,.nav-link-admin-mobile{display:none}@media (max-width:768px){.nav{position:sticky}.nav-links{background:var(--panel);border-bottom:1px solid var(--line);z-index:35;flex-direction:column;gap:2px;padding:10px 20px 18px;display:none;position:absolute;top:64px;left:0;right:0;box-shadow:0 12px 32px -8px #0f172a1f}.nav-links.mobile-open{display:flex}.nav-link{border-radius:var(--radius-sm);padding:12px 16px;font-size:15px}.nav-menu-btn{display:inline-flex}.search{display:none}.nav-search-icon{display:inline-flex}.nav-link-admin-mobile{display:flex}.nav-right .icon-btn.primary{display:none}.hero-inner{grid-template-columns:1fr!important}.hero-visual{display:none!important}.hero{padding:36px 0 24px}.hero p{font-size:16px}}@media (max-width:560px){.post-card{grid-template-columns:96px 1fr;gap:14px;padding:14px}}@media (max-width:400px){.post-card{grid-template-columns:1fr}.post-thumb{aspect-ratio:16/7}}@media (max-width:560px){.work-card.feature{grid-column:span 1}.work-card.feature .work-cover{aspect-ratio:4/3}.project-facts{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.article-hero{padding:28px 0 16px}.article-hero h1{font-size:clamp(26px,8vw,36px)}.prose p{font-size:16px}.stats{grid-template-columns:1fr 1fr}}@media (max-width:768px){.section{padding:36px 0}.section-head h2{font-size:24px}}@media (max-width:480px){.footer{padding:28px 0 40px}.footer-inner{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width:380px){.tweaks-panel{width:auto;bottom:10px;left:8px;right:8px}}@media (max-width:480px){.result{grid-template-columns:1fr}.result .kind{display:none}}@media (max-width:768px){.editor-layout{grid-template-columns:1fr}.preview-pane{display:none}}@media (max-width:640px){.settings-section{grid-template-columns:1fr;gap:12px}}.admin-overlay{display:none}.admin-menu-btn{display:none!important}@media (max-width:900px){.admin-root{grid-template-columns:1fr}.admin-side{z-index:50;width:260px;height:100dvh;transition:transform .25s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.admin-side.open{box-shadow:var(--shadow-lg);transform:translate(0)}.admin-overlay{z-index:49;opacity:0;pointer-events:none;background:#0006;transition:opacity .2s;display:block;position:fixed;inset:0}.admin-overlay.visible{opacity:1;pointer-events:auto}.admin-menu-btn{display:inline-flex!important}.admin-body{padding:20px 16px}.admin-top{padding:12px 16px}}@media (max-width:600px){.stat-grid{grid-template-columns:1fr 1fr}.dash-grid{grid-template-columns:1fr}}@media (max-width:400px){.stat-grid{grid-template-columns:1fr}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
