:root{--accent:#2a6fdb;--accent-soft:color-mix(in oklch, var(--accent) 12%, white);--accent-ghost:color-mix(in oklch, var(--accent) 6%, white);--ink:#111418;--ink-2:#41474f;--ink-3:#6b727c;--line:color-mix(in oklch, var(--ink) 12%, white);--line-soft:color-mix(in oklch, var(--ink) 7%, white);--bg:#fff;--surface:#f5f6f8;--font-sans:"Pretendard", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--anim:1;--dur:calc(.7s);--rise:26px;--maxw:1180px;--pad:clamp(20px, 5vw, 72px);--radius:18px}*{box-sizing:border-box}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{font-family:var(--font-sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;line-height:1.55;overflow-x:hidden}::selection{background:var(--accent);color:#fff}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.card-link{z-index:1;border-radius:inherit;text-indent:-9999px;white-space:nowrap;position:absolute;inset:0;overflow:hidden}.card-link:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:12px}.project image-slot,.project .oe-p-del,.feat image-slot,.entry image-slot,.u-actions,.oe-p-del{z-index:2;position:relative}body.oe-editing .card-link{pointer-events:none}:where(a,button,[role=button],summary,input,select,textarea,[tabindex]):focus-visible{outline:2.5px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.progress{transform-origin:0;background:var(--accent);z-index:200;width:100%;height:2px;position:fixed;top:0;left:0;transform:scaleX(0)}.nav{z-index:100;padding:18px var(--pad);background:color-mix(in oklch, var(--bg) 78%, transparent);-webkit-backdrop-filter:blur(14px)saturate(1.4);backdrop-filter:blur(14px)saturate(1.4);border-bottom:1px solid #0000;grid-template-columns:1fr auto 1fr;align-items:center;transition:border-color .4s,padding .4s,background .4s;display:grid;position:fixed;top:0;left:0;right:0}.nav[data-scrolled=true]{border-bottom-color:var(--line-soft);padding-top:12px;padding-bottom:12px}.brand{letter-spacing:-.01em;white-space:nowrap;align-items:center;gap:11px;font-weight:700;display:flex}.brand>span{white-space:nowrap}.brand .mark{background:var(--ink);color:#fff;width:30px;height:30px;font-family:var(--font-mono);background:var(--accent);border-radius:9px;place-items:center;font-size:13px;font-weight:700;display:grid}.nav-links{align-items:center;gap:2px;display:flex}.nav-links a{color:var(--ink-2);border-radius:999px;padding:8px 11px;font-size:13.5px;transition:color .25s,background .25s;position:relative}.nav-links a:hover{color:var(--ink);background:var(--accent-ghost)}.nav-links a[data-active=true]{color:var(--accent)}.nav-cta{color:var(--ink);border:1px solid var(--line);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:9px 15px;font-size:13px;font-weight:600;transition:border-color .25s,background .25s,transform .25s;display:inline-flex}.nav-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-1px)}.nav-cta .dot{background:#1f8a5b;border-radius:50%;width:7px;height:7px;animation:2.4s infinite pulse;box-shadow:0 0 #1f8a5b99;box-shadow:0 0 lab(50.8726% -39.4292 16.464/.6)}@keyframes pulse{0%{box-shadow:0 0 #1f8a5b8c;box-shadow:0 0 lab(50.8726% -39.4292 16.464/.55)}70%{box-shadow:0 0 0 7px #0000}to{box-shadow:0 0 #0000}}@media (max-width:1040px){.nav-links{display:none}}.nav-right{justify-self:end;align-items:center;gap:10px;display:flex}.nav-toggle{border:1px solid var(--line);cursor:pointer;background:0 0;border-radius:11px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:42px;height:42px;transition:background .2s,border-color .2s;display:none}.nav-toggle:hover{background:var(--accent-ghost)}.nav-toggle span{background:var(--ink);border-radius:2px;width:18px;height:2px;transition:transform .28s,opacity .2s;display:block}.nav-toggle[aria-expanded=true] span:first-child{transform:translateY(6px)rotate(45deg)}.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.nav-menu{z-index:99;background:color-mix(in oklch, var(--bg) 96%, transparent);-webkit-backdrop-filter:blur(14px)saturate(1.4);backdrop-filter:blur(14px)saturate(1.4);border-bottom:1px solid var(--line);padding:6px var(--pad) 14px;flex-direction:column;display:none;position:fixed;top:70px;left:0;right:0}.nav-menu[data-open=true]{animation:.28s cubic-bezier(.2,.7,.2,1) menuDrop;display:flex}@keyframes menuDrop{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.nav-menu a{color:var(--ink);border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding:15px 4px;font-size:17px;font-weight:600;transition:color .2s,padding-left .2s;display:flex}.nav-menu a:last-child{border-bottom:none}.nav-menu a:after{content:"→";color:var(--accent);opacity:0;transition:opacity .2s,transform .2s}.nav-menu a:hover{color:var(--accent);padding-left:10px}.nav-menu a:hover:after{opacity:1}@media (max-width:1040px){.nav-toggle{display:flex}}@media (min-width:1041px){.nav-menu{display:none!important}}@media (max-width:560px){.nav-cta{display:none}}.wrap{max-width:var(--maxw);padding:0 var(--pad);margin:0 auto}section{position:relative}.eyebrow{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);align-items:center;gap:10px;font-size:12.5px;display:inline-flex}.eyebrow:before{content:"";background:var(--accent);width:26px;height:1px;display:inline-block}.section-head{max-width:720px}.section-head h2{letter-spacing:-.025em;text-wrap:balance;margin:18px 0 0;font-size:clamp(28px,4.4vw,46px);font-weight:800;line-height:1.12}.section-head p{color:var(--ink-2);text-wrap:pretty;max-width:56ch;margin:16px 0 0;font-size:clamp(15px,1.6vw,18px)}.hero{padding-top:clamp(140px,22vh,220px);padding-bottom:clamp(70px,12vh,130px);position:relative}.hero:before{content:"";z-index:-1;background:radial-gradient(60% 70% at 78% 8%, color-mix(in oklch, var(--accent) 16%, transparent), transparent 70%), radial-gradient(50% 60% at 8% 30%, color-mix(in oklch, var(--accent) 9%, transparent), transparent 70%);filter:blur(8px);height:620px;position:absolute;inset:-10% -20% auto}.hero .status{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-2);border:1px solid var(--line);background:color-mix(in oklch, var(--bg) 60%, transparent);border-radius:999px;align-items:center;gap:9px;padding:7px 14px;font-size:12.5px;display:inline-flex}.hero .status .dot{background:#1f8a5b;border-radius:50%;width:7px;height:7px}.hero h1{letter-spacing:-.035em;margin:26px 0 0;font-size:clamp(36px,6.4vw,82px);font-weight:800;line-height:1.08}.hero h1 .line{display:block}.hero h1 .accent{color:var(--accent);font-style:normal}.hero .lead{color:var(--ink-2);text-wrap:pretty;max-width:50ch;margin:28px 0 0;font-size:clamp(16px,2vw,21px)}.hero .lead b{color:var(--ink);font-weight:600}.hero .actions{flex-wrap:wrap;gap:12px;margin-top:36px;display:flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:999px;align-items:center;gap:9px;padding:13px 22px;font-size:15px;font-weight:600;transition:transform .2s,background .25s,box-shadow .25s,border-color .25s;display:inline-flex}.btn .arr{transition:transform .25s}.btn:hover .arr{transform:translate(3px)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 30px -12px color-mix(in oklch, var(--accent) 80%, black)}.btn-primary:hover{box-shadow:0 16px 38px -12px color-mix(in oklch, var(--accent) 80%, black);transform:translateY(-2px)}.btn-ghost{color:var(--ink);border-color:var(--line);background:0 0}.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}.hero .scroll-hint{font-family:var(--font-mono);color:var(--ink-3);letter-spacing:.08em;align-items:center;gap:12px;margin-top:64px;font-size:12px;display:inline-flex}.hero .scroll-hint .bar{background:var(--line);width:34px;height:1px;position:relative;overflow:hidden}.hero .scroll-hint .bar:after{content:"";background:var(--accent);width:40%;animation:2.2s infinite slide;position:absolute;inset:0}@keyframes slide{0%{transform:translate(-120%)}to{transform:translate(280%)}}.hero .marquee-meta{border-top:1px solid var(--line-soft);flex-wrap:wrap;gap:40px;margin-top:56px;padding-top:28px;display:flex}.hero .marquee-meta div{flex-direction:column;gap:4px;display:flex}.hero .marquee-meta .k{letter-spacing:-.03em;font-size:clamp(26px,3.4vw,40px);font-weight:800;font-family:var(--font-mono)}.hero .marquee-meta .v{color:var(--ink-3);font-size:13px}.block{padding:clamp(80px,13vh,150px) 0}.block.tinted{background:var(--surface)}.block.tinted+.block.tinted{padding-top:0}.features{grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px;display:grid}.feature{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--bg);padding:26px;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s}.feature:hover{border-color:var(--line);transform:translateY(-4px);box-shadow:0 24px 50px -28px #1114184d}.feature .ic{background:var(--accent-ghost);width:46px;height:46px;color:var(--accent);border-radius:13px;place-items:center;margin-bottom:20px;display:grid}.feature .ic svg{width:22px;height:22px}.feature h3{letter-spacing:-.01em;margin:0 0 10px;font-size:19px;font-weight:700}.feature p{color:var(--ink-2);margin:0;font-size:14.5px}.feature .num{font-family:var(--font-mono);color:var(--ink-3);float:right;font-size:12px}@media (max-width:900px){.features{grid-template-columns:1fr}}.skills-grid{grid-template-columns:repeat(2,1fr);gap:14px 40px;margin-top:52px;display:grid}.skill-group{border-top:1px solid var(--line);padding:24px 0}.skill-group h4{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-3);justify-content:space-between;margin:0 0 18px;font-size:13px;display:flex}.skill-group h4 span{color:var(--accent)}.chips{flex-wrap:wrap;gap:9px;display:flex}.chip{border:1px solid var(--line);background:var(--bg);color:var(--ink);cursor:default;border-radius:999px;padding:8px 14px;font-size:14px;transition:background .2s,color .2s,border-color .2s,transform .2s}.chip:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px)}@media (max-width:820px){.skills-grid{grid-template-columns:1fr}}.ai-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:56px;display:grid}.ai-card{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--bg);flex-direction:column;padding:26px 24px 24px;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;display:flex;position:relative}.ai-card:hover{border-color:var(--line);transform:translateY(-4px);box-shadow:0 24px 50px -28px #1114184d}.ai-card .num{font-family:var(--font-mono);color:var(--accent);letter-spacing:.04em;align-items:center;gap:9px;margin-bottom:18px;font-size:13px;font-weight:700;display:inline-flex}.ai-card .num:after{content:"";background:var(--line-soft);flex:1;height:1px}.ai-card h3{letter-spacing:-.01em;margin:0 0 10px;font-size:18px;font-weight:700}.ai-card p{color:var(--ink-2);margin:0 0 18px;font-size:14px;line-height:1.6}.ai-card .tagline{font-family:var(--font-mono);color:var(--ink-3);letter-spacing:.02em;border-top:1px solid var(--line-soft);margin-top:auto;padding-top:14px;font-size:11.5px}@media (max-width:980px){.ai-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:540px){.ai-grid{grid-template-columns:1fr}}.ai-tools{border-top:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:18px;margin-top:30px;padding-top:26px;display:flex}.ai-tools .k{font-family:var(--font-mono);letter-spacing:.12em;color:var(--ink-3);font-size:12px}.ai-tools .chips{margin:0}.timeline{border-top:1px solid var(--line);margin-top:56px;margin-inline:calc(var(--pad) * -.45)}.tl-item{padding:30px calc(var(--pad) * .45);border-bottom:1px solid var(--line-soft);grid-template-columns:160px 1fr auto;align-items:start;gap:24px;transition:background .3s;display:grid;position:relative}.tl-item:hover{background:var(--accent-ghost)}.tl-item .yr{font-family:var(--font-mono);color:var(--ink-3);padding-top:3px;font-size:14px}.tl-item h3{letter-spacing:-.01em;margin:0;font-size:21px;font-weight:700}.tl-item .role{color:var(--ink-2);margin:6px 0 14px;font-size:14.5px}.tl-item .tl-tags{flex-wrap:wrap;gap:7px;display:flex}.tl-item .tl-tags span{font-family:var(--font-mono);color:var(--ink-2);border:1px solid var(--line-soft);border-radius:6px;padding:3px 8px;font-size:12px}.tl-item .badge{font-family:var(--font-mono);color:var(--accent);white-space:nowrap;padding-top:4px;font-size:12px}@media (max-width:760px){.tl-item{grid-template-columns:1fr;gap:10px}.tl-item .badge{display:none}}.projects{grid-template-columns:repeat(2,1fr);gap:26px;margin-top:56px;display:grid}.project{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--bg);cursor:pointer;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s;overflow:hidden}.project:hover{border-color:var(--line);transform:translateY(-6px);box-shadow:0 34px 60px -34px #11141866}.project .shot{background:var(--surface);width:100%;height:230px;position:relative;overflow:hidden}.project .shot image-slot{will-change:transform;width:100%;height:124%;display:block;position:absolute;top:-12%;left:0}.project .meta{padding:22px 24px 26px}.project .meta .top{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.project .meta .yr{font-family:var(--font-mono);color:var(--ink-3);font-size:12.5px}.project h3{letter-spacing:-.01em;margin:4px 0 8px;font-size:21px;font-weight:700}.project p{color:var(--ink-2);margin:0 0 16px;font-size:14.5px}.project .ptags{flex-wrap:wrap;gap:7px;display:flex}.project .ptags span{font-family:var(--font-mono);color:var(--ink-2);background:var(--surface);border-radius:6px;padding:4px 9px;font-size:11.5px}.project .go{color:var(--accent);align-items:center;gap:7px;margin-top:18px;font-size:13.5px;font-weight:600;display:inline-flex}.project .go .arr{transition:transform .25s}.project:hover .go .arr{transform:translate(4px)}@media (max-width:760px){.projects{grid-template-columns:1fr}}.posts{border-top:1px solid var(--line);margin-top:52px}.post{border-bottom:1px solid var(--line-soft);cursor:pointer;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:24px 4px;transition:padding-left .3s,background .3s;display:grid;position:relative}.post:hover{padding-left:16px}.post:hover .arr{opacity:1;transform:translate(0)}.post .date{font-family:var(--font-mono);color:var(--ink-3);white-space:nowrap;font-size:13px}.post h3{letter-spacing:-.01em;margin:0;font-size:18px;font-weight:600;transition:color .25s}.post:hover h3{color:var(--accent)}.post .arr{opacity:0;color:var(--accent);transition:opacity .25s,transform .25s;transform:translate(-8px)}@media (max-width:640px){.post{grid-template-columns:1fr;gap:6px}.post .arr{display:none}}.edu{grid-template-columns:repeat(2,1fr);gap:14px 40px;margin-top:52px;display:grid}.edu-item{border-top:1px solid var(--line);padding:26px 0}.edu-item .yr{font-family:var(--font-mono);color:var(--ink-3);font-size:13px}.edu-item h3{margin:8px 0 6px;font-size:19px;font-weight:700}.edu-item p{color:var(--ink-2);margin:0;font-size:14.5px}.edu-certs{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.edu-certs span{font-family:var(--font-mono);border:1px solid var(--line-soft);color:var(--ink-2);border-radius:7px;padding:5px 10px;font-size:12px}@media (max-width:760px){.edu{grid-template-columns:1fr}}.contact{text-align:center;padding:clamp(100px,16vh,180px) 0}.contact h2{letter-spacing:-.03em;text-wrap:balance;margin:22px 0 0;font-size:clamp(34px,6vw,68px);font-weight:800;line-height:1.08}.contact .lead{color:var(--ink-2);max-width:44ch;margin:20px auto 0;font-size:clamp(16px,1.8vw,19px)}.contact .mail{letter-spacing:-.02em;color:var(--ink);border-bottom:2px solid #0000;align-items:center;gap:12px;margin-top:40px;font-size:clamp(20px,3vw,34px);font-weight:700;transition:border-color .3s,color .3s;display:inline-flex}.contact .mail:hover{color:var(--accent);border-bottom-color:var(--accent)}.contact .socials{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:40px;display:flex}.contact .socials a{font-family:var(--font-mono);color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-size:13.5px;transition:all .25s}.contact .socials a:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}.footer{padding:40px var(--pad);border-top:1px solid var(--line-soft);color:var(--ink-3);font-size:13px;font-family:var(--font-mono);flex-wrap:wrap;justify-content:space-between;gap:12px;display:flex}.reveal{opacity:0;transform:translateY(calc(var(--rise) * var(--anim)));transition:opacity calc(var(--dur) * (.4 + .6 * var(--anim))) cubic-bezier(.2,.7,.2,1), transform calc(var(--dur) * (.4 + .6 * var(--anim))) cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--d,0) * 1ms * var(--anim));will-change:opacity, transform}.reveal.in{opacity:1;transform:none}.hero h1 .line{opacity:0;transform:translateY(calc(.42em * var(--anim)))}.hero.lit h1 .line{animation:lineIn calc(.7s * (.5 + .5 * var(--anim))) cubic-bezier(.2,.8,.2,1) forwards;animation-delay:calc(var(--li,0) * .13s * var(--anim))}@keyframes lineIn{to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}.hero h1 .line{opacity:1!important;animation:none!important;transform:none!important}}
.blog-ownerbar{z-index:120;background:color-mix(in oklch, var(--bg) 86%, transparent);-webkit-backdrop-filter:blur(16px)saturate(1.5);backdrop-filter:blur(16px)saturate(1.5);border:1px solid var(--line);border-radius:999px;align-items:center;gap:8px;max-width:calc(100vw - 32px);padding:9px 9px 9px 18px;animation:.35s cubic-bezier(.2,.7,.2,1) obRise;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 26px 60px -26px #11141899}@keyframes obRise{0%{opacity:0;transform:translate(-50%,18px)}to{opacity:1;transform:translate(-50%)}}.blog-ownerbar .ob-state{border-right:1px solid var(--line);white-space:nowrap;align-items:center;gap:9px;padding-right:14px;display:flex}.blog-ownerbar .led{background:#1f8a5b;border-radius:50%;width:8px;height:8px;animation:2.4s infinite obPulse;box-shadow:0 0 #1f8a5b8c;box-shadow:0 0 lab(50.8726% -39.4292 16.464/.55)}@keyframes obPulse{0%{box-shadow:0 0 #1f8a5b8c;box-shadow:0 0 lab(50.8726% -39.4292 16.464/.55)}70%{box-shadow:0 0 0 7px #0000}to{box-shadow:0 0 #0000}}.blog-ownerbar .lbl{letter-spacing:-.01em;color:var(--ink);font-size:13px;font-weight:700}.blog-ownerbar .meta{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.blog-ownerbar .ob-acts{align-items:center;gap:6px;display:flex}.blog-ownerbar .ob-btn{cursor:pointer;font-family:var(--font-sans);color:var(--ink-2);background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:7px;padding:9px 14px;font-size:12.5px;font-weight:600;text-decoration:none;transition:background .2s,color .2s,transform .15s;display:inline-flex}.blog-ownerbar .ob-btn svg{width:15px;height:15px}.blog-ownerbar .ob-btn:hover{background:var(--accent-ghost);color:var(--ink)}.blog-ownerbar .ob-btn.lock:hover{color:#c0392b;background:#e5484d24;background:lab(54.5836% 61.4482 33.7329/.14)}body.has-ownerbar{padding-bottom:92px}@media (max-width:480px){.blog-ownerbar .ob-btn .t{display:none}.blog-ownerbar .ob-btn{padding:9px}}@media (prefers-reduced-motion:reduce){.blog-ownerbar,.blog-ownerbar .led{animation:none}}.nav-write{display:none!important}.nav-write.legacy{white-space:nowrap;color:#fff;background:var(--accent);border:1px solid var(--accent);box-shadow:0 10px 26px -14px color-mix(in oklch, var(--accent) 80%, black);border-radius:999px;align-items:center;gap:8px;padding:9px 15px;font-size:13px;font-weight:600;transition:transform .22s,box-shadow .25s,filter .25s;display:inline-flex}.nav-write svg{margin-top:-1px}.nav-write:hover{filter:brightness(1.04);box-shadow:0 16px 32px -14px color-mix(in oklch, var(--accent) 80%, black);transform:translateY(-1px)}@media (max-width:420px){.nav-write{padding:9px 12px}.nav-write span.t{display:none}}.cat-empty{text-align:center;border:1px dashed var(--line);border-radius:var(--radius);background:color-mix(in oklch, var(--surface) 60%, transparent);margin-top:20px;padding:clamp(48px,9vh,96px) 24px}.cat-empty .ce-ic{color:var(--ink-3);opacity:.6;font-size:30px}.cat-empty h4{letter-spacing:-.02em;margin:12px 0 0;font-size:19px;font-weight:800}.cat-empty p{color:var(--ink-2);margin:8px 0 0;font-size:14.5px}.cat-empty .ce-all{cursor:pointer;font-family:var(--font-sans);border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:999px;margin-top:18px;padding:10px 18px;font-size:13.5px;font-weight:600;transition:transform .18s,filter .2s}.cat-empty .ce-all:hover{filter:brightness(1.05);transform:translateY(-1px)}.entries{min-height:320px}.bp-notfound{text-align:center;padding:clamp(120px,22vh,220px) 24px clamp(80px,14vh,160px)}.bp-notfound .nf-code{font-family:var(--font-mono);color:var(--accent);opacity:.25;letter-spacing:-.04em;font-size:clamp(56px,12vw,104px);font-weight:700;line-height:1}.bp-notfound h1{letter-spacing:-.03em;margin:18px 0 0;font-size:clamp(26px,4vw,38px);font-weight:800}.bp-notfound p{color:var(--ink-2);max-width:460px;margin:14px auto 0;font-size:16px;line-height:1.7}.bp-notfound .nf-acts{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:30px;display:flex}.blog-hero{padding-top:clamp(132px,20vh,196px);padding-bottom:clamp(40px,7vh,72px);position:relative}.blog-hero:before{content:"";z-index:-1;background:radial-gradient(58% 70% at 80% 4%, color-mix(in oklch, var(--accent) 14%, transparent), transparent 70%), radial-gradient(48% 60% at 6% 26%, color-mix(in oklch, var(--accent) 8%, transparent), transparent 70%);filter:blur(8px);height:480px;position:absolute;inset:-10% -20% auto}.blog-hero h1{letter-spacing:-.035em;text-wrap:balance;margin:22px 0 0;font-size:clamp(34px,6vw,74px);font-weight:800;line-height:1.08}.blog-hero h1 .accent{color:var(--accent)}.blog-hero .lead{color:var(--ink);letter-spacing:-.015em;text-wrap:pretty;max-width:36ch;margin:18px 0 0;font-size:clamp(19px,2.6vw,28px);font-weight:500;line-height:1.45}.blog-hero .lead b{color:var(--accent);font-weight:600}.blog-meta-row{border-top:1px solid var(--line-soft);flex-wrap:wrap;gap:36px;margin-top:38px;padding-top:24px;display:flex}.blog-meta-row div{flex-direction:column;gap:4px;display:flex}.blog-meta-row .k{font-family:var(--font-mono);letter-spacing:-.03em;font-size:clamp(22px,3vw,32px);font-weight:800}.blog-meta-row .v{color:var(--ink-3);font-size:12.5px;font-family:var(--font-mono);letter-spacing:.04em}.cat-bar{z-index:40;background:color-mix(in oklch, var(--bg) 80%, transparent);-webkit-backdrop-filter:blur(12px)saturate(1.3);backdrop-filter:blur(12px)saturate(1.3);flex-wrap:wrap;align-items:center;gap:9px;margin-bottom:8px;padding:16px 0;display:flex;position:sticky;top:64px}.cat-bar .cat-label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-right:4px;font-size:11.5px}.cat{border:1px solid var(--line);background:var(--bg);color:var(--ink-2);cursor:pointer;border-radius:999px;padding:8px 15px;font-size:13.5px;font-weight:600;transition:background .22s,color .22s,border-color .22s,transform .22s}.cat:hover{color:var(--ink);border-color:var(--ink-3);transform:translateY(-1px)}.cat[data-active=true]{background:var(--accent);color:#fff;border-color:var(--accent)}.cat .n{font-family:var(--font-mono);opacity:.65;margin-left:6px;font-size:11px}.cat{align-items:center;display:inline-flex}.cat .cat-del{cursor:pointer;width:15px;height:15px;color:var(--ink-3);background:color-mix(in oklch, var(--ink) 9%, transparent);border-radius:50%;place-items:center;margin:0 -4px 0 8px;transition:background .15s,color .15s;display:inline-grid}.cat .cat-del svg{width:9px;height:9px}.cat .cat-del:hover{color:#fff;background:#e5484d}.cat[data-active=true] .cat-del{color:#fff;background:#ffffff4d;background:lab(100% 0 0/.3)}.cat-add{font-family:var(--font-sans);cursor:pointer;color:var(--accent);border:1px dashed color-mix(in oklch, var(--accent) 50%, var(--line));background:0 0;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .18s,border-color .18s}.cat-add:hover{background:var(--accent-ghost);border-color:var(--accent)}.cat-newinput{font-family:var(--font-sans);color:var(--ink);border:1px solid var(--accent);background:var(--bg);width:180px;box-shadow:0 0 0 4px color-mix(in oklch, var(--accent) 12%, transparent);border-radius:999px;outline:none;padding:8px 14px;font-size:13.5px}.feat{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--bg);cursor:pointer;grid-template-columns:1.05fr 1fr;align-items:stretch;gap:clamp(24px,4vw,56px);margin-top:8px;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s;display:grid;overflow:hidden}.feat:hover{border-color:var(--line);transform:translateY(-5px);box-shadow:0 38px 70px -36px #1114186b}.feat .shot{background:var(--surface);min-height:320px;position:relative;overflow:hidden}.feat .shot image-slot{width:100%;height:100%;display:block;position:absolute;inset:0}.feat .shot .pin{z-index:2;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;background:var(--accent);color:#fff;border-radius:999px;padding:6px 11px;font-size:11px;position:absolute;top:16px;left:16px}.feat .body{flex-direction:column;padding:clamp(26px,3.4vw,44px) clamp(24px,3vw,40px);display:flex}.feat .kick{font-family:var(--font-mono);color:var(--ink-3);align-items:center;gap:12px;font-size:12px;display:flex}.feat .kick .tag{color:var(--accent)}.feat .kick .dotsep{background:var(--ink-3);border-radius:50%;width:3px;height:3px}.feat h2{letter-spacing:-.028em;text-wrap:balance;margin:16px 0 0;font-size:clamp(24px,3vw,38px);font-weight:800;line-height:1.16}.feat p{color:var(--ink-2);max-width:52ch;margin:16px 0 0;font-size:clamp(14.5px,1.6vw,16.5px);line-height:1.66}.feat .ftags{flex-wrap:wrap;gap:7px;margin-top:20px;display:flex}.feat .ftags span{font-family:var(--font-mono);color:var(--ink-2);background:var(--surface);border-radius:6px;padding:4px 9px;font-size:11.5px}.feat .go{color:var(--accent);align-items:center;gap:8px;margin-top:auto;padding-top:24px;font-size:14px;font-weight:600;display:inline-flex}.feat .go .arr{transition:transform .25s}.feat:hover .go .arr{transform:translate(4px)}@media (max-width:820px){.feat{grid-template-columns:1fr}.feat .shot{min-height:220px}}.list-head{justify-content:space-between;align-items:baseline;gap:16px;margin:clamp(56px,8vh,96px) 0 0;padding-bottom:4px;display:flex}.list-head h3{letter-spacing:-.02em;margin:0;font-size:clamp(20px,2.4vw,27px);font-weight:800}.list-head .count{font-family:var(--font-mono);color:var(--ink-3);font-size:12.5px}.entries{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:28px;display:grid}.entry{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--bg);cursor:pointer;flex-direction:column;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;display:flex;overflow:hidden}.entry:hover{border-color:var(--line);transform:translateY(-5px);box-shadow:0 30px 56px -32px #11141861}.entry .shot{background:var(--surface);height:176px;position:relative;overflow:hidden}.entry .shot image-slot{width:100%;height:100%;display:block;position:absolute;inset:0}.feat .shot image-slot,.entry .shot image-slot{pointer-events:none}.u-cover{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.u-cover-ph{background:radial-gradient(120% 120% at 0% 0%, color-mix(in oklch, var(--accent) 22%, var(--surface)), transparent 60%), radial-gradient(120% 120% at 100% 100%, color-mix(in oklch, var(--accent) 14%, var(--surface)), var(--surface));place-items:center;display:grid;position:absolute;inset:0}.u-cover-ph span{font-family:var(--font-mono);letter-spacing:-.02em;color:color-mix(in oklch, var(--accent) 70%, var(--ink));opacity:.8;font-size:22px;font-weight:700}.u-actions{z-index:4;gap:6px;display:flex;position:absolute;top:10px;right:10px}.u-actions button{cursor:pointer;border:1px solid var(--line);background:color-mix(in oklch, var(--bg) 86%, transparent);-webkit-backdrop-filter:blur(8px)saturate(1.3);backdrop-filter:blur(8px)saturate(1.3);width:30px;height:30px;color:var(--ink-2);border-radius:9px;place-items:center;padding:0;transition:background .16s,color .16s,border-color .16s,transform .16s;display:grid;box-shadow:0 6px 16px -8px #11141873}.u-actions button svg{width:15px;height:15px}.u-actions .u-edit:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px)}.u-actions .u-del:hover{color:#fff;background:#e5484d;border-color:#e5484d;transform:translateY(-1px)}.feat .u-actions{top:14px;right:14px}.bp-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;display:flex}.bp-owner{align-items:center;gap:8px;display:inline-flex}.bp-owner .oseg{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);padding-right:4px;font-size:11px}.bp-owner .obtn{cursor:pointer;font-family:var(--font-sans);color:var(--ink-2);border:1px solid var(--line);background:var(--bg);border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .18s,color .18s,border-color .18s,transform .16s;display:inline-flex}.bp-owner .obtn svg{width:15px;height:15px}.bp-owner .obtn:hover{background:var(--accent-ghost);color:var(--ink);border-color:var(--ink-3);transform:translateY(-1px)}.bp-owner .obtn.danger:hover{color:#fff;background:#e5484d;border-color:#e5484d}.entry .body{flex-direction:column;flex:1;padding:20px 21px 22px;display:flex}.entry .kick{font-family:var(--font-mono);color:var(--ink-3);align-items:center;gap:9px;font-size:11.5px;display:flex}.entry .kick .tag{color:var(--accent)}.entry .kick .dotsep{background:var(--ink-3);border-radius:50%;width:3px;height:3px}.entry h4{letter-spacing:-.015em;margin:12px 0 0;font-size:18px;font-weight:700;line-height:1.32;transition:color .22s}.entry:hover h4{color:var(--accent)}.entry p{color:var(--ink-2);margin:10px 0 0;font-size:14px;line-height:1.6}.entry .foot{flex-wrap:wrap;align-items:center;gap:8px;margin-top:auto;padding-top:18px;display:flex}.entry .foot span{font-family:var(--font-mono);color:var(--ink-2);background:var(--surface);border-radius:6px;padding:3px 8px;font-size:11px}@media (max-width:940px){.entries{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.entries{grid-template-columns:1fr}}.entry[hidden],.feat[hidden]{display:none!important}.archive{border-top:1px solid var(--line);margin-top:28px}.arow{border-bottom:1px solid var(--line-soft);cursor:pointer;grid-template-columns:116px 1fr auto;align-items:center;gap:24px;padding:20px 4px;transition:padding-left .28s,background .28s;display:grid}.arow:hover{background:var(--accent-ghost);padding-left:14px}.arow .date{font-family:var(--font-mono);color:var(--ink-3);white-space:nowrap;font-size:12.5px}.arow .mid{min-width:0}.arow h4{letter-spacing:-.01em;margin:0;font-size:16.5px;font-weight:600;transition:color .22s}.arow:hover h4{color:var(--accent)}.arow .at{gap:9px;margin-top:5px;display:flex}.arow .at span{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.arow .read{font-family:var(--font-mono);color:var(--ink-3);white-space:nowrap;font-size:12px}.arow .read .arr{color:var(--accent);opacity:0;margin-left:6px;transition:opacity .22s,transform .22s;display:inline-block;transform:translate(-6px)}.arow:hover .read .arr{opacity:1;transform:translate(0)}@media (max-width:640px){.arow{grid-template-columns:1fr;gap:6px}.arow .read{display:none}}.subscribe{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);text-align:center;margin-top:clamp(64px,10vh,110px);padding:clamp(34px,5vw,56px)}.subscribe .eyebrow{justify-content:center}.subscribe h3{letter-spacing:-.025em;text-wrap:balance;margin:18px 0 0;font-size:clamp(24px,3.4vw,38px);font-weight:800}.subscribe p{color:var(--ink-2);max-width:46ch;margin:14px auto 0;font-size:clamp(15px,1.7vw,17px)}.sub-form{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:28px;display:flex}.sub-form input{font-family:var(--font-sans);color:var(--ink);border:1px solid var(--line);background:var(--bg);border-radius:999px;width:min(320px,80vw);padding:13px 18px;font-size:15px;transition:border-color .2s,box-shadow .2s}.sub-form input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ghost);outline:none}.sub-form input::placeholder{color:var(--ink-3)}.sub-note{font-family:var(--font-mono);color:var(--ink-3);margin-top:16px;font-size:12px}.bp-main{--maxw:1180px;padding-top:88px}.bp-top{max-width:var(--maxw);padding:24px var(--pad) 0;margin:0 auto}.bp-back{color:var(--ink-2);font-size:14px;font-family:var(--font-mono);align-items:center;gap:9px;transition:gap .25s,color .25s;display:inline-flex}.bp-back:hover{color:var(--accent);gap:13px}.bp-back .arr{transition:transform .25s}.bp-back:hover .arr{transform:translate(-3px)}.bp-header{max-width:800px;padding:30px var(--pad) 0;text-align:center;margin:0 auto}.bp-kick{font-family:var(--font-mono);color:var(--ink-3);align-items:center;gap:11px;font-size:12.5px;display:inline-flex}.bp-kick .tag{color:var(--accent);letter-spacing:.06em;text-transform:uppercase}.bp-kick .dotsep{background:var(--ink-3);border-radius:50%;width:3px;height:3px}.bp-title{letter-spacing:-.03em;text-wrap:balance;margin:20px 0 0;font-size:clamp(30px,5vw,56px);font-weight:800;line-height:1.12}.bp-lead{color:var(--ink-2);text-wrap:pretty;max-width:60ch;margin:22px auto 0;font-size:clamp(16px,2vw,20px)}.bp-byline{align-items:center;gap:12px;margin-top:30px;display:inline-flex}.bp-byline .ava{background:var(--accent);color:#fff;width:40px;height:40px;font-family:var(--font-mono);border-radius:50%;place-items:center;font-size:14px;font-weight:700;display:grid}.bp-byline .who{text-align:left}.bp-byline .who b{font-size:14.5px;font-weight:600;display:block}.bp-byline .who .sub{font-family:var(--font-mono);color:var(--ink-3);font-size:12px}.bp-hero{max-width:1080px;padding:0 var(--pad);margin:40px auto 0}.bp-hero image-slot{border-radius:var(--radius);pointer-events:none;width:100%;height:clamp(260px,42vw,520px);display:block;overflow:hidden}.bp-hero .u-cover{border-radius:var(--radius);width:100%;height:clamp(260px,42vw,520px);position:static}.bp-body{max-width:var(--maxw);padding:clamp(50px, 8vh, 90px) var(--pad);grid-template-columns:1fr 220px;align-items:start;gap:clamp(40px,6vw,88px);margin:0 auto;display:grid}.bp-toc{order:2;position:sticky;top:104px}.bp-toc .k{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--line);padding-bottom:14px;font-size:11.5px}.bp-toc ul{flex-direction:column;gap:2px;margin:14px 0 0;padding:0;list-style:none;display:flex}.bp-toc a{color:var(--ink-3);border-left:2px solid #0000;border-radius:0 7px 7px 0;padding:7px 12px;font-size:13.5px;transition:color .2s,border-color .2s,background .2s;display:block}.bp-toc a:hover{color:var(--ink);background:var(--accent-ghost)}.bp-toc a[data-active=true]{color:var(--accent);border-left-color:var(--accent);font-weight:600}.bp-toc .share{border-top:1px solid var(--line);gap:8px;margin-top:22px;padding-top:18px;display:flex}.bp-toc .share a{font-family:var(--font-mono);color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-size:11.5px;transition:all .2s}.bp-toc .share a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}.prose{order:1;min-width:0;max-width:720px}.prose>*+*{margin-top:22px}.prose h2{letter-spacing:-.022em;margin-top:clamp(44px,6vh,64px);scroll-margin-top:100px;font-size:clamp(23px,2.8vw,31px);font-weight:800;line-height:1.24}.prose h2 .hn{font-family:var(--font-mono);color:var(--accent);vertical-align:2px;margin-right:12px;font-size:.52em;font-weight:600}.prose h3{letter-spacing:-.015em;margin-top:36px;font-size:clamp(18px,2vw,22px);font-weight:700}.prose p{color:var(--ink-2);text-wrap:pretty;font-size:clamp(16px,1.7vw,18px);line-height:1.78}.prose p b,.prose li b{color:var(--ink);font-weight:600}.prose a:not(.btn){color:var(--accent);border-bottom:1px solid color-mix(in oklch, var(--accent) 40%, white);transition:border-color .2s}.prose a:not(.btn):hover{border-bottom-color:var(--accent)}.prose ul,.prose ol{color:var(--ink-2);padding-left:4px;font-size:clamp(16px,1.7vw,18px);line-height:1.74}.prose li{margin-top:9px;padding-left:26px;list-style:none;position:relative}.prose ul li:before{content:"";background:color-mix(in oklch, var(--accent) 55%, white);border-radius:2px;width:7px;height:7px;position:absolute;top:13px;left:4px}.prose ol{counter-reset:li}.prose ol li{counter-increment:li}.prose ol li:before{content:counter(li);font-family:var(--font-mono);color:var(--accent);font-size:12.5px;font-weight:700;position:absolute;top:2px;left:0}.prose blockquote{border-left:3px solid var(--accent);color:var(--ink);letter-spacing:-.01em;margin-left:0;margin-right:0;padding:6px 0 6px 24px;font-size:clamp(17px,1.9vw,21px);font-weight:500;line-height:1.5}.prose blockquote cite{font-family:var(--font-mono);color:var(--ink-3);margin-top:12px;font-size:13px;font-style:normal;font-weight:400;display:block}.prose pre{color:#2b323c;font-family:var(--font-mono);background:#eceff4;border:1px solid #dde2ea;border-radius:14px;padding:20px 22px;font-size:13.5px;line-height:1.7;overflow-x:auto}.prose pre .cm{color:#9aa2b0}.prose pre .kw{color:#2a6fdb}.prose pre .fn{color:#1f8a5b}.prose pre .str{color:#b3541e}.prose pre code.hljs,.prose pre .hljs{color:#2b323c;background:0 0;padding:0}.prose .hljs-comment,.prose .hljs-quote{color:#9aa2b0;font-style:italic}.prose .hljs-keyword,.prose .hljs-selector-tag,.prose .hljs-literal,.prose .hljs-section,.prose .hljs-built_in,.prose .hljs-name,.prose .hljs-doctag{color:#2a6fdb}.prose .hljs-title,.prose .hljs-title.function_,.prose .hljs-title.class_,.prose .hljs-type,.prose .hljs-params{color:#1f8a5b}.prose .hljs-string,.prose .hljs-attr,.prose .hljs-template-tag,.prose .hljs-addition,.prose .hljs-regexp,.prose .hljs-selector-attr{color:#b3541e}.prose .hljs-number,.prose .hljs-meta,.prose .hljs-symbol,.prose .hljs-bullet,.prose .hljs-link{color:#9a5cd0}.prose .hljs-variable,.prose .hljs-attribute,.prose .hljs-tag,.prose .hljs-selector-id,.prose .hljs-selector-class{color:#2b323c}.prose .hljs-deletion{color:#c0392b}.prose .hljs-emphasis{font-style:italic}.prose .hljs-strong{font-weight:700}.prose :not(pre)>code{font-family:var(--font-mono);background:var(--surface);border:1px solid var(--line-soft);color:var(--ink);border-radius:6px;padding:2px 6px;font-size:.88em}.prose figure{margin:0}.prose figure image-slot{border-radius:12px;width:100%;height:clamp(220px,34vw,380px);display:block;overflow:hidden}.prose figure img{border-radius:12px;width:100%;height:auto}.prose figcaption{font-family:var(--font-mono);color:var(--ink-3);text-align:center;margin-top:11px;font-size:12.5px}.prose .callout{background:var(--accent-ghost);border:1px solid color-mix(in oklch, var(--accent) 22%, white);border-radius:14px;padding:20px 22px}.prose .callout p{color:var(--ink);margin:0;font-size:15.5px}.prose .callout .lbl{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:11.5px;display:block}.prose table{border-collapse:collapse;width:100%;font-size:clamp(14px,1.5vw,15.5px)}.prose th,.prose td{text-align:left;border-bottom:1px solid var(--line-soft);padding:11px 14px}.prose th{font-family:var(--font-mono);letter-spacing:.03em;color:var(--ink-3);text-transform:uppercase;border-bottom:1px solid var(--line);font-size:12.5px}.prose td{color:var(--ink-2)}.prose hr{border:none;border-top:1px solid var(--line);margin:clamp(36px,5vh,52px) 0}.bp-tags{border-top:1px solid var(--line);flex-wrap:wrap;gap:8px;margin-top:44px;padding-top:28px;display:flex}.bp-tags span{font-family:var(--font-mono);color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:6px 13px;font-size:12.5px}.bp-author{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--surface);align-items:flex-start;gap:18px;margin-top:30px;padding:26px;display:flex}.bp-author .ava{background:var(--accent);color:#fff;width:52px;height:52px;font-family:var(--font-mono);border-radius:50%;flex:none;place-items:center;font-size:17px;font-weight:700;display:grid}.bp-author b{font-size:16px;font-weight:700}.bp-author .sub{font-family:var(--font-mono);color:var(--ink-3);margin-top:2px;font-size:12.5px}.bp-author p{color:var(--ink-2);margin:10px 0 0;font-size:14.5px;line-height:1.6}@media (max-width:860px){.bp-body{grid-template-columns:1fr}.bp-toc{display:none}.prose{max-width:none}}.bp-more{border-top:1px solid var(--line);background:var(--surface)}.bp-more .wrap{padding-top:clamp(56px,8vh,88px);padding-bottom:clamp(56px,8vh,88px)}.bp-more .list-head{margin-top:0}.bp-more .entries{margin-top:26px}
