*,::after,::before{margin:0;padding:0;box-sizing:border-box}.skip-link{position:absolute;left:50%;top:-64px;transform:translateX(-50%);z-index:2000;background:var(--ink);color:var(--bg);padding:10px 18px;border-radius:0 0 12px 12px;text-decoration:none;font-size:.9rem;font-weight:500;transition:top .18s}.skip-link:focus{top:0;outline:2px solid var(--accent);outline-offset:2px}:root{--ink:#191918;--ink2:#3d3d3a;--ink3:#6b6b65;--ink4:#9c9c94;--bg:#f4f1e8;--card:#fbf8f0;--accent:#d97757;--accent-soft:rgba(217,119,87,.08);--accent-med:rgba(217,119,87,.16);--accent-text:#a4502f;--line:#dcd6c8;--line-l:#e8e2d4;--code-bg:#1a1a17;--code-ink:#f4f1e8;--code-accent:#e8a088;--serif:'Instrument Serif',Georgia,serif;--sans:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,sans-serif;--mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;--ease:cubic-bezier(.22,1,.36,1);--nav:68px;--max:1120px}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav) + 24px)}body{font-family:var(--sans);font-size:1rem;line-height:1.75;color:var(--ink2);background:var(--bg);-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column;animation:.3s ease-out appear;padding-top:var(--nav)}@keyframes appear{from{opacity:0}to{opacity:1}}a{color:var(--accent-text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:0.22em;transition:color 150ms linear}a:hover{color:var(--ink)}::selection{background:rgba(217,119,87,.15);color:var(--ink)}body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.03;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");mix-blend-mode:multiply}.breadcrumb,footer,header,main{position:relative;z-index:2}.container{max-width:48rem;margin-left:auto;margin-right:auto;padding-left:clamp(1.5rem,5vw,3rem);padding-right:clamp(1.5rem,5vw,3rem)}.container-wide{max-width:62rem}header{padding:2rem 0 0}header .container{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}header .brand{font-family:var(--serif);font-size:1.25rem;color:var(--ink);text-decoration:none}header .brand .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle}header .back{font-family:var(--sans);font-size:.875rem;color:var(--ink3);text-decoration:none}header .back:hover{color:var(--ink)}main{flex:1;padding:5rem 0 0}.hero-section{padding-bottom:5rem}.eyebrow{font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-text);margin-bottom:1.25rem}h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.25rem,4vw + 1rem,3.4rem);line-height:1.08;letter-spacing:-.022em;color:var(--ink);margin-bottom:1.5rem;text-wrap:balance}.lede{font-size:1.18rem;line-height:1.55;color:var(--ink2);max-width:34rem;margin-bottom:2.5rem;text-wrap:pretty}.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;font-size:.92rem;font-weight:500;border-radius:999px;text-decoration:none;cursor:pointer;border:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s ease,color .2s ease}.btn-primary{background:var(--ink);color:var(--bg)}.btn-primary:hover{transform:translateY(-1px);color:var(--bg);box-shadow:0 12px 28px -6px rgba(217,119,87,.32),0 16px 36px -8px rgba(25,25,24,.22)}.btn-ghost{background:0 0;color:var(--ink);box-shadow:inset 0 0 0 1px var(--line)}.btn-ghost:hover{box-shadow:inset 0 0 0 1px var(--ink);color:var(--ink)}.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}section.block{padding:4rem 0;border-top:1px solid var(--line)}section.block:first-of-type{border-top:none;padding-top:0}h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.7rem,2vw + .9rem,2.1rem);line-height:1.18;letter-spacing:-.015em;color:var(--ink);margin-bottom:1.25rem;text-wrap:balance}h3{font-family:var(--sans);font-weight:600;font-size:1.02rem;color:var(--ink);margin-bottom:.45rem;letter-spacing:-.005em}.section-intro{font-size:1.02rem;color:var(--ink2);max-width:36rem;margin-bottom:2.25rem}.code-block{margin-top:1.5rem;background:var(--code-bg);color:var(--code-ink);font-family:var(--mono);font-size:.82rem;line-height:1.65;border-radius:10px;padding:1.25rem 1.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(255,255,255,.06)}.code-block .prompt{color:var(--code-accent)}.code-block .com{color:#9c9c94}.code-block .strong{color:#fff;font-weight:500}.code-block pre{margin:0;font:inherit;color:inherit;white-space:pre}.quick-start-ol{margin-top:1.5rem;list-style:none;counter-reset:step;padding-left:0}.quick-start-ol li{counter-increment:step}.quick-start-ol li::before{content:counter(step);position:absolute;left:0;top:.1rem;width:1.6rem;height:1.6rem;border-radius:50%;background:var(--ink);color:#fdfcfa;font-size:.82rem;font-weight:600;display:flex;align-items:center;justify-content:center;font-family:var(--mono)}.code-with-copy{position:relative;margin-top:.4rem}.code-with-copy code{display:block;background:var(--code-bg);color:var(--code-ink);font-family:var(--mono);font-size:.82rem;padding:.75rem 5.5rem .75rem 1rem;border-radius:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:pre}.copy-btn{position:absolute;top:7px;right:7px;display:inline-flex;align-items:center;gap:5px;padding:5px 10px 5px 8px;background:rgba(244,241,232,.07);color:var(--code-ink);border:1px solid rgba(244,241,232,.16);border-radius:5px;cursor:pointer;font-family:var(--sans);font-size:.74rem;font-weight:500;letter-spacing:.01em;transition:background .15s,border-color .15s,color .15s,transform .1s}.copy-btn:hover{background:rgba(244,241,232,.14);border-color:rgba(244,241,232,.3)}.copy-btn:active{transform:scale(.96)}.copy-btn.copied{background:rgba(95,217,122,.18);border-color:rgba(95,217,122,.5);color:#bce5c6}.copy-btn svg{flex-shrink:0;width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.copy-btn.copied svg{display:none}.copy-btn.copied::before{content:'✓';font-size:.85rem;line-height:1}@media(max-width:520px){.copy-btn .copy-label{display:none}.copy-btn{padding:5px}}.step-label{font-size:.94rem;color:var(--ink2)}.step-note{font-size:.88rem;color:var(--ink3);margin-top:.6rem}.step-note strong{color:var(--ink)}.expected{font-size:.88rem;color:var(--ink3);margin:.9rem 0 .3rem}.callout{margin-top:2rem;padding:1.5rem 1.6rem 1.4rem;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:0 8px 8px 0}.callout h3{font-family:var(--serif);font-weight:400;font-style:italic;font-size:1.15rem;color:var(--ink);margin-bottom:.7rem}.callout ul{margin-top:.6rem;padding-left:1.2rem;font-size:.94rem;color:var(--ink2)}.callout ul li+li{margin-top:.4rem}.callout p{font-size:.94rem;color:var(--ink2)}.callout p+p{margin-top:.6rem}.callout a{color:var(--ink);font-weight:500}.callout blockquote{font-family:var(--serif);font-style:italic;font-size:1.18rem;line-height:1.45;color:var(--ink);margin-bottom:.6rem;text-wrap:balance}.callout .attrib{font-size:.86rem;color:var(--ink3)}.stack-list{list-style:none;padding:0;margin:0 0 2rem}.stack-list li{display:flex;flex-wrap:wrap;align-items:baseline;gap:.25rem 1rem;padding:.85rem 0;border-bottom:1px solid var(--line)}.stack-list li:last-child{border-bottom:none}.stack-list strong{color:var(--ink);font-weight:600;font-size:1.02rem;min-width:14rem}.stack-list span{color:var(--ink2);font-size:.95rem;flex:1}.stack-plus{margin:1.5rem 0 0;padding:1rem 1.25rem;background:var(--accent-soft);border-radius:8px;font-size:.95rem;line-height:1.6;color:var(--ink2)}.stack-plus .plus-tag{font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-text);margin-right:.4rem}.stack-plus strong{color:var(--ink);font-weight:600}.further ul{list-style:none;padding-left:0;margin-top:1.25rem}.further li{padding:.55rem 0;border-bottom:1px solid var(--line)}.further li:last-child{border-bottom:none}.further a{display:flex;align-items:center;justify-content:space-between;gap:1rem;color:var(--ink);text-decoration:none;font-weight:500;font-size:.96rem}.further a:hover{color:var(--accent)}.further a span.arr{color:var(--ink3);font-family:var(--mono);font-size:.85rem;transition:transform .2s var(--ease),color .2s ease}.further a:hover span.arr{color:var(--accent);transform:translateX(3px)}.further a small{display:block;font-weight:400;font-size:.82rem;color:var(--ink3);margin-top:.15rem}footer{margin-top:5rem;border-top:1px solid var(--line);padding:3rem clamp(1.5rem,5vw,3rem);text-align:center}footer p{font-size:.78rem;color:var(--ink3);max-width:42rem;margin-left:auto;margin-right:auto;line-height:1.65}footer p+p{margin-top:.75rem}footer a{color:var(--ink3);text-decoration:underline;text-underline-offset:0.22em}footer a:hover{color:var(--ink)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.breadcrumb{margin-top:1.5rem;font-size:.85rem;color:var(--ink3)}.breadcrumb .container{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.breadcrumb a{color:var(--accent-text);text-decoration:none;font-weight:500}.breadcrumb a:hover{color:var(--ink);text-decoration:underline;text-underline-offset:.2em}.breadcrumb .sep{color:var(--ink4)}.breadcrumb [aria-current]{color:var(--ink);font-weight:600}.scroll-nav{position:fixed;left:clamp(20px,2.4vw,40px);top:50%;transform:translateY(-50%);z-index:60;display:flex;flex-direction:column;gap:16px;opacity:0;animation:.9s .6s forwards scrollnav-in}@keyframes scrollnav-in{to{opacity:1}}@media(prefers-reduced-motion:reduce){body{animation:none}.scroll-nav{animation:none;opacity:1}.nav-cta,.nav-cta *{animation:none!important}}.scroll-nav a{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink4);font-family:var(--serif);font-style:italic;font-size:.72rem;letter-spacing:.04em;transition:color .35s,gap .35s;position:relative;padding:4px 0}.scroll-nav a::before{content:'';width:14px;height:1px;background:currentColor;opacity:.7;transition:width .45s var(--ease),opacity .35s ease;flex-shrink:0}.scroll-nav a:hover{color:var(--ink2);gap:14px}.scroll-nav a:hover::before{width:22px;opacity:1}.scroll-nav a.is-active{color:var(--accent);gap:16px}.scroll-nav a.is-active::before{width:36px;opacity:1}.scroll-nav .label{white-space:nowrap}@media(max-width:1120px){.scroll-nav{display:none}}.endcontact{border-top:1px solid var(--line);padding:3.5rem 0 0}.endcontact-grid{display:flex;flex-wrap:wrap;gap:1.75rem 4rem}.endcontact-col{min-width:13rem}.endcontact-label{font-family:var(--sans);font-size:.74rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:.55rem}.endcontact-phone{font-family:var(--serif);font-size:1.7rem;line-height:1.1;color:var(--ink);text-decoration:none;display:inline-block}.endcontact-phone:hover{color:var(--accent)}.endcontact-mail{font-family:var(--serif);font-size:1.4rem;line-height:1.1;color:var(--ink);text-decoration:none;display:inline-block;margin-bottom:.55rem;word-break:break-word}.endcontact-mail:hover{color:var(--accent)}.endcontact-sub{font-size:.9rem;color:var(--ink3);margin-top:.35rem}.endcontact-sub strong{color:var(--accent-text);font-weight:600}.video-wrap{margin-top:2rem;max-width:880px;border-radius:12px;overflow:hidden;position:relative;background:#0a0a0a;box-shadow:0 1px 3px rgba(25,25,24,.05),0 20px 60px rgba(25,25,24,.12)}.video-facade{position:relative;width:100%;aspect-ratio:16/9;cursor:pointer;display:block;border:none;padding:0;background:#0a0a0a;overflow:hidden}.video-facade img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),opacity .35s ease}.video-facade::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.45) 100%);transition:opacity .35s;pointer-events:none}.video-facade:hover img{transform:scale(1.025)}.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.96);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(0,0,0,.35);transition:transform .35s var(--ease),background .35s ease;z-index:2}.video-play svg{width:28px;height:28px;fill:var(--ink);margin-left:4px}.video-facade:hover .video-play{transform:translate(-50%,-50%) scale(1.08);background:#fff}.video-label{position:absolute;bottom:24px;left:24px;z-index:2;color:#fff;font-family:var(--serif);font-size:1.1rem;font-style:italic;letter-spacing:-.005em;max-width:60%;line-height:1.3;text-shadow:0 2px 12px rgba(0,0,0,.4)}.video-meta{position:absolute;top:20px;right:20px;z-index:2;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:999px;color:#fff;font-size:.72rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.video-meta svg{width:13px;height:13px;color:#fff;fill:currentColor}.video-wrap iframe{width:100%;height:100%;border:none;display:block;aspect-ratio:16/9}@media(max-width:600px){main{padding:3rem 0 0}footer{margin-top:3rem}.video-play{width:64px;height:64px}.video-play svg{width:22px;height:22px}.video-label{font-size:.95rem;max-width:75%;bottom:18px;left:18px}}nav#nav{position:fixed;top:0;left:0;right:0;height:var(--nav);background:rgba(253,252,250,.78);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid transparent;z-index:100;display:flex;align-items:center;transition:border-color .3s,background-color .3s}nav#nav.scrolled{border-bottom-color:var(--line-l);background:rgba(253,252,250,.92)}.nav-in{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,48px);width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}.nav-logo{font-family:var(--serif);font-size:1.2rem;color:var(--ink);letter-spacing:-.01em;display:flex;align-items:center;gap:10px;text-decoration:none}.nav-logo .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block}.nav-links{display:flex;gap:32px;align-items:center}.nav-links a{font-size:.875rem;font-weight:400;color:var(--ink3);position:relative;padding:6px 0;text-decoration:none;transition:color .2s}.nav-links a:not(.nav-cta)::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left center;transition:transform .45s var(--ease)}.nav-links a:hover{color:var(--ink)}.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1)}.nav-cta{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 20px 10px 22px;background:var(--ink);color:var(--bg)!important;border-radius:999px;font-size:.82rem;font-weight:500;letter-spacing:.01em;overflow:hidden;isolation:isolate;box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 0 0 1px rgba(25,25,24,.04),0 1px 2px rgba(25,25,24,.12),0 6px 16px -4px rgba(25,25,24,.18);transition:transform .35s var(--ease),box-shadow .35s var(--ease),padding .35s var(--ease)}.nav-cta::after{display:none}.nav-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#1a1a18 0,#2a2925 50%,#1a1a18 100%);z-index:-2;transition:opacity .35s}.nav-cta .nav-cta-glow{position:absolute;inset:0;background:radial-gradient(120px 60px at var(--mx,50%) var(--my,50%),rgba(217,119,87,.55),transparent 70%);opacity:0;z-index:-1;transition:opacity .4s;pointer-events:none}.nav-cta .nav-cta-shine{position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(110deg,transparent 0,rgba(255,255,255,.18) 50%,transparent 100%);transform:skewX(-18deg);z-index:-1;transition:left .7s var(--ease);pointer-events:none}.nav-cta .nav-cta-dot{width:6px;height:6px;border-radius:50%;background:#5fd97a;box-shadow:0 0 0 2px rgba(95,217,122,.18),0 0 8px rgba(95,217,122,.5);flex-shrink:0;animation:2.4s ease-in-out infinite cta-pulse}@keyframes cta-pulse{0%,100%{box-shadow:0 0 0 2px rgba(95,217,122,.18),0 0 8px rgba(95,217,122,.5)}50%{box-shadow:0 0 0 3px rgba(95,217,122,.28),0 0 14px rgba(95,217,122,.75)}}.nav-cta .nav-cta-arrow{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .35s var(--ease);margin-left:2px}.nav-cta:hover{transform:translateY(-1px);padding:10px 22px 10px 24px;box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 0 0 1px rgba(25,25,24,.06),0 2px 4px rgba(25,25,24,.14),0 12px 28px -6px rgba(217,119,87,.35),0 16px 36px -8px rgba(25,25,24,.25)}.nav-cta:hover .nav-cta-glow{opacity:1}.nav-cta:hover .nav-cta-shine{left:120%}.nav-cta:hover .nav-cta-arrow{transform:translateX(3px)}.nav-cta:active{transform:translateY(0)}.nav-dd{position:relative;display:flex;align-items:center}.nav-dd-trigger{display:inline-flex;align-items:center;gap:4px}.nav-dd-caret{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s var(--ease);flex-shrink:0}.nav-dd:focus-within .nav-dd-caret,.nav-dd:hover .nav-dd-caret{transform:rotate(180deg)}.nav-dd-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-6px);min-width:248px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:2px;box-shadow:0 4px 12px rgba(25,25,24,.06),0 18px 44px -14px rgba(25,25,24,.22);opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s var(--ease),visibility .2s;z-index:130}.nav-dd:focus-within .nav-dd-menu,.nav-dd:hover .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.nav-links .nav-dd-menu a{padding:9px 12px;border-radius:7px;font-size:.9rem;color:var(--ink2);white-space:nowrap}.nav-links .nav-dd-menu a::after{content:none;display:none}.nav-links .nav-dd-menu a:hover{background:var(--accent-soft);color:var(--ink)}.hb{display:none;background:0 0;border:none;cursor:pointer;width:24px;height:18px;position:relative;z-index:110;touch-action:manipulation}.hb::before{content:'';position:absolute;inset:-13px -10px}.hb span{display:block;width:100%;height:1.5px;background:var(--ink);position:absolute;left:0;transition:all .25s var(--ease);border-radius:1px}.hb span:first-child{top:0}.hb span:nth-child(2){top:8px}.hb span:nth-child(3){top:16px}.hb.on span:first-child{top:8px;transform:rotate(45deg)}.hb.on span:nth-child(2){opacity:0}.hb.on span:nth-child(3){top:8px;transform:rotate(-45deg)}.mm{position:fixed;inset:0;background:var(--bg);z-index:105;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:88px 24px 48px;overflow-y:auto;transform:translateX(100%);transition:transform .35s var(--ease)}.mm.open{transform:none}.mm a{font-family:var(--serif);font-size:1.7rem;color:var(--ink);text-decoration:none}.mm .mm-label{font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:-8px}.mm a.mm-sub{font-size:1.15rem;color:var(--ink2)}@media(max-width:900px){.nav-links{display:none}.hb{display:block}}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.in{opacity:1;transform:none}.reveal.d1{transition-delay:.05s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.19s}.reveal.d4{transition-delay:.26s}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}