:root{
    --paper:#F1ECE3; --paper-2:#EAE3D6; --paper-3:#F7F3EC;
    --ink:#1B1813; --ink-soft:#5C544A; --ink-faint:#6E6960; --ink-ghost:#8C8479;
    --accent:#D8451C; --accent-deep:#B5340F;
    --line:rgba(27,24,19,.14); --line-soft:rgba(27,24,19,.07);
    --serif:"Fraunces", Georgia, serif;
    --sans:"Hanken Grotesk", system-ui, sans-serif;
    --mono:"Space Mono", ui-monospace, monospace;
    --gutter:clamp(20px,5vw,80px); --maxw:1480px;
    --sh-soft:0 18px 40px -30px rgba(27,24,19,.45);
    --sh-lift:0 40px 70px -34px rgba(27,24,19,.55);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
  body{background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.5;overflow-x:hidden;position:relative;}
  body.loading{overflow:hidden;height:100vh;}
  ::selection{background:var(--accent);color:var(--paper);}
  a{color:inherit;text-decoration:none;}

  /* ---------- ambient ---------- */
  .grid-lines{position:fixed;inset:0;z-index:0;pointer-events:none;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);display:grid;grid-template-columns:repeat(12,1fr);height:100%;}
  .grid-lines span{border-left:1px solid var(--line-soft);}
  .grid-lines span:last-child{border-right:1px solid var(--line-soft);}
  @media (max-width:760px){.grid-lines{display:none;}}
  .glow{position:fixed;z-index:0;pointer-events:none;width:60vw;height:60vw;max-width:780px;max-height:780px;border-radius:50%;filter:blur(90px);opacity:.5;background:radial-gradient(circle, rgba(216,69,28,.14), transparent 70%);top:-12vw;right:-10vw;}
  .grain{position:fixed;inset:0;z-index:9997;pointer-events:none;opacity:.045;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

  /* ---------- scroll progress ---------- */
  .progress{position:fixed;top:0;left:0;height:2px;width:100%;z-index:9996;transform:scaleX(0);transform-origin:0 50%;background:var(--accent);}

  /* ---------- preloader ---------- */
  .loader{position:fixed;inset:0;z-index:10000;background:var(--ink);display:flex;align-items:center;justify-content:center;transition:transform 1s cubic-bezier(.76,0,.24,1);}
  .loader.done{transform:translateY(-101%);}
  .loader__inner{display:flex;flex-direction:column;align-items:center;gap:22px;width:min(78vw,420px);}
  .loader__name{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--paper);opacity:.9;}
  .loader__bar{width:100%;height:1px;background:rgba(241,236,227,.18);overflow:hidden;}
  .loader__bar i{display:block;height:100%;width:0;background:var(--accent);}
  .loader__pct{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:330;color:var(--paper);font-variation-settings:"opsz" 90;}
  .loader__pct::after{content:"%";font-size:.4em;color:var(--accent);vertical-align:super;margin-left:2px;}

  /* ---------- custom cursor ---------- */
  .cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;width:9px;height:9px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;transition:width .25s cubic-bezier(.2,.8,.2,1),height .25s cubic-bezier(.2,.8,.2,1),background .25s;}
  .cursor.is-link{width:54px;height:54px;background:rgba(216,69,28,.12);border:1px solid var(--accent);}
  .cursor.is-view{width:78px;height:78px;background:var(--accent);}
  .cursor__label{color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;opacity:0;transition:opacity .2s;white-space:nowrap;}
  .cursor.is-view .cursor__label{opacity:1;}
  @media (hover:none),(pointer:coarse){.cursor{display:none;}}
  html.cursor-custom, html.cursor-custom *{cursor:none;}

  /* ---------- atoms ---------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);position:relative;z-index:2;}
  .label{font-family:var(--mono);font-size:11px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
  .accent{color:var(--accent);}
  .sec-head{display:flex;align-items:baseline;gap:18px;padding-bottom:26px;margin-bottom:54px;border-bottom:1px solid var(--line);}
  .sec-head .num{font-family:var(--mono);font-size:12px;color:var(--accent-deep);letter-spacing:.1em;}
  .sec-head h2{font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);}
  .reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1);}
  .reveal.in{opacity:1;transform:none;}

  /* ---------- top bar ---------- */
  header.bar{position:fixed;top:0;left:0;width:100%;z-index:9000;background:var(--paper);transition:border-color .4s;border-bottom:1px solid transparent;}
  header.bar.scrolled{border-bottom:1px solid var(--line);}
  .bar__inner{max-width:var(--maxw);margin:0 auto;padding:16px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px;}
  .bar__name{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;}
  .bar__name b{font-weight:700;}
  .bar__nav{display:flex;gap:8px;}
  .bar__nav a{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding:6px 10px;display:inline-block;transition:color .3s;}
  .bar__nav a::after{content:"";position:absolute;left:10px;right:10px;bottom:2px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:0 50%;transition:transform .3s;}
  .bar__nav a:hover,.bar__nav a.is-current{color:var(--ink);}
  .bar__nav a:hover::after,.bar__nav a.is-current::after{transform:scaleX(1);}
  .bar__loc{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);}
  @media (max-width:820px){.bar__nav,.bar__inner .bar__loc{display:none;}}

  /* ---- mobile menu ---- */
  .bar__burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:40px;height:40px;background:none;border:0;padding:0;margin:-4px -8px -4px 0;cursor:pointer;}
  .bar__burger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform .35s cubic-bezier(.16,1,.3,1);}
  .bar__burger.open span:first-child{transform:translateY(3.75px) rotate(45deg);}
  .bar__burger.open span:last-child{transform:translateY(-3.75px) rotate(-45deg);}
  .mnav{position:fixed;inset:0;z-index:8990;background:var(--paper);padding:92px var(--gutter) 36px;display:none;flex-direction:column;visibility:hidden;opacity:0;transition:opacity .35s ease,visibility 0s linear .35s;}
  .mnav.open{visibility:visible;opacity:1;transition:opacity .35s ease;}
  .mnav__links{display:flex;flex-direction:column;border-top:1px solid var(--line);}
  .mnav__links a{font-family:var(--serif);font-weight:340;font-size:clamp(1.9rem,8.5vw,2.8rem);line-height:1;letter-spacing:-.015em;color:var(--ink);display:flex;align-items:baseline;gap:16px;padding:22px 0;border-bottom:1px solid var(--line);opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s cubic-bezier(.16,1,.3,1);}
  .mnav.open .mnav__links a{opacity:1;transform:none;}
  .mnav.open .mnav__links a:nth-child(2){transition-delay:.06s;}
  .mnav.open .mnav__links a:nth-child(3){transition-delay:.12s;}
  .mnav.open .mnav__links a:nth-child(4){transition-delay:.18s;}
  .mnav__n{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--accent-deep);}
  .mnav__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:18px;}
  body.menu-open{overflow:hidden;}
  @media (max-width:820px){
    .bar__burger{display:inline-flex;}
    .mnav{display:flex;}
  }

  /* ============ HERO ============ */
  .hero{position:relative;padding-top:clamp(140px,20vh,220px);}
  .hero__canvas{position:absolute;inset:0;z-index:0;pointer-events:none;}
  .hero .wrap{position:relative;z-index:2;}
  .hero__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:clamp(40px,7vh,80px);}
  .hero__eyebrow::before{content:"";width:42px;height:1px;background:var(--accent);transform-origin:0 50%;transform:scaleX(0);transition:transform .9s cubic-bezier(.16,1,.3,1) .2s;}
  .hero__eyebrow.in::before{transform:scaleX(1);}
  .h-mask{overflow:hidden;display:block;}
  .hero h1{font-family:var(--serif);font-weight:330;font-size:clamp(2.7rem,8.6vw,9.2rem);line-height:.96;letter-spacing:-.02em;max-width:16ch;padding-bottom:.12em;font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0;transform:translateY(108%);transition:transform 1.15s cubic-bezier(.16,1,.3,1);}
  .h-mask.in h1{transform:none;}
  .hero h1 .light{color:var(--ink-ghost);font-weight:300;}
  .hero h1 em{font-style:normal;font-weight:360;color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 0,"WONK" 0;}
  .hero__bottom{margin-top:clamp(46px,8vh,92px);}
  .hero__lede{font-size:clamp(1rem,1.35vw,1.18rem);line-height:1.55;color:var(--ink-soft);max-width:46ch;font-weight:380;}
  .hero__foot{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:clamp(40px,7vh,78px);padding:17px 0;border-top:1px solid var(--line);}
  .hero__scroll{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);display:inline-flex;align-items:center;gap:9px;transition:gap .3s,color .3s;}
  .hero__scroll:hover{color:var(--ink);gap:13px;}
  .hero__scroll .dot{display:inline-block;color:var(--accent);animation:bob 1.8s ease-in-out infinite;}
  @keyframes bob{0%,100%{transform:translateY(0);opacity:1;}50%{transform:translateY(4px);opacity:.5;}}
  @media (max-width:560px){.hero__foot .label{display:none;}}

  /* marquee */
  .marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:15px 0;background:var(--paper);position:relative;z-index:4;}
  .marquee__track{display:flex;white-space:nowrap;width:max-content;will-change:transform;}
  .marquee__track span{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);padding:0 26px;display:inline-flex;align-items:center;gap:26px;}
  .marquee__track span::after{content:"\25CF";color:var(--accent);font-size:7px;}

  /* ============ STATS ============ */
  .stats{padding:clamp(70px,11vh,140px) 0 clamp(40px,6vh,80px);}
  .stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
  .stat{background:var(--paper);padding:clamp(26px,3vw,44px) clamp(20px,2vw,34px);}
  .stat .v{font-family:var(--serif);font-size:clamp(2.6rem,5vw,4.3rem);line-height:1;font-weight:340;letter-spacing:-.02em;}
  .stat .v .accent{font-style:italic;}
  .stat .k{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:14px;line-height:1.5;}
  @media (max-width:760px){.stats__grid{grid-template-columns:repeat(2,1fr);}}

  /* ============ MANIFESTO ============ */
  .manifesto{padding:clamp(80px,16vh,200px) 0;}
  .manifesto__line{font-family:var(--serif);font-weight:320;font-size:clamp(2rem,5.6vw,5.4rem);line-height:1.08;letter-spacing:-.02em;max-width:18ch;}
  .manifesto__line em{font-style:italic;color:var(--accent);}

  /* ============ ABOUT ============ */
  .about{padding:clamp(40px,6vh,80px) 0 clamp(80px,12vh,150px);}
  .about__grid{display:grid;grid-template-columns:1.7fr 1fr;gap:clamp(40px,6vw,110px);align-items:start;}
  .about__lead{font-family:var(--serif);font-weight:330;font-size:clamp(1.6rem,3vw,2.7rem);line-height:1.18;letter-spacing:-.01em;margin-bottom:clamp(36px,5vh,60px);max-width:20ch;}
  .about__lead b{color:var(--accent);font-weight:340;font-style:italic;}
  .about p{font-size:clamp(1rem,1.2vw,1.12rem);line-height:1.65;color:var(--ink-soft);margin-bottom:22px;max-width:54ch;font-weight:380;}
  .about p b{color:var(--ink);font-weight:600;}
  .spec{border-top:1px solid var(--ink);padding-top:8px;}
  .spec__row{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--line);}
  .spec__row dt{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);}
  .spec__row dd{font-size:.95rem;text-align:right;color:var(--ink);font-weight:500;}
  @media (max-width:860px){.about__grid{grid-template-columns:1fr;gap:54px;}}

  /* ============ WORK ============ */
  .work{padding:clamp(40px,6vh,80px) 0 clamp(80px,12vh,150px);}
  .project{position:relative;display:grid;grid-template-columns:1fr 1.08fr;gap:clamp(30px,5vw,80px);align-items:center;padding:clamp(48px,7vh,96px) 0;border-top:1px solid var(--line);}
  .project:last-child{border-bottom:1px solid var(--line);}
  .project.rev .project__txt{order:2;}
  .project__meta{display:flex;gap:14px;align-items:baseline;margin-bottom:24px;}
  .project__meta .pn{font-family:var(--mono);font-size:12px;color:var(--accent-deep);letter-spacing:.1em;}
  .project__meta .pc{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.08em;text-transform:uppercase;}
  .project h3{font-family:var(--serif);font-weight:350;font-size:clamp(1.9rem,3.6vw,3.3rem);line-height:1.04;letter-spacing:-.015em;margin-bottom:22px;}
  .project__desc{font-size:1.02rem;line-height:1.6;color:var(--ink-soft);max-width:46ch;margin-bottom:28px;font-weight:380;}
  .project__tags{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px;}
  .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);padding:6px 12px;border-radius:100px;transition:border-color .3s;}
  .project:hover .tag{border-color:rgba(27,24,19,.3);}
  .project__cta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:9px;}
  .project__cta::after{content:"";position:absolute;inset:0;cursor:pointer;}
  .project__cta .ar{color:var(--accent);transition:transform .3s;display:inline-block;}
  .project:hover .project__cta .ar{transform:translateX(5px);}

  /* device frame */
  .stage{perspective:1300px;}
  .frame{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper-3);box-shadow:var(--sh-soft);transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .5s;transform-style:preserve-3d;}
  .project:hover .frame{box-shadow:var(--sh-lift);}
  .frame__chrome{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line);background:var(--paper);}
  .frame__chrome i{width:9px;height:9px;border-radius:50%;background:var(--line);}
  .frame__chrome i:first-child{background:rgba(216,69,28,.5);}
  .frame__chrome .url{margin-left:12px;font-family:var(--mono);font-size:10px;color:var(--ink-faint);letter-spacing:.02em;}
  .frame__body{aspect-ratio:16/10.4;position:relative;overflow:hidden;background:var(--paper-3);}

  /* ---- shared mock UI ---- */
  .ui{position:absolute;inset:0;font-family:var(--sans);color:var(--ink);}
  .ui-greek{display:block;height:7px;border-radius:3px;background:rgba(27,24,19,.13);}
  .ui-greek.w1{width:62%;} .ui-greek.w2{width:80%;} .ui-greek.w3{width:46%;} .ui-greek.num{width:38px;height:7px;}
  .play .anim{opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease;}
  .play.go .anim{opacity:1;transform:none;}
  .play.go .anim.d1{transition-delay:.08s;} .play.go .anim.d2{transition-delay:.16s;} .play.go .anim.d3{transition-delay:.24s;} .play.go .anim.d4{transition-delay:.32s;} .play.go .anim.d5{transition-delay:.4s;}

  /* P1 design system */
  .ui--ds{display:grid;grid-template-columns:30% 1fr;}
  .ui-side{background:var(--paper);border-right:1px solid var(--line);padding:14px 13px;display:flex;flex-direction:column;gap:14px;}
  .ui-logo{width:18px;height:18px;border-radius:5px;background:var(--accent);}
  .ui-snav{display:flex;flex-direction:column;gap:7px;}
  .ui-sitem{display:flex;align-items:center;gap:8px;font-size:9px;color:var(--ink-faint);padding:5px 6px;border-radius:5px;font-weight:500;}
  .ui-sitem i{width:9px;height:9px;border-radius:2px;background:rgba(27,24,19,.22);}
  .ui-sitem.is-active{background:rgba(216,69,28,.1);color:var(--ink);}
  .ui-sitem.is-active i{background:var(--accent);}
  .ui-main{padding:14px 15px;display:flex;flex-direction:column;gap:12px;}
  .ui-top{display:flex;align-items:center;gap:10px;}
  .ui-h{font-family:var(--serif);font-size:15px;font-weight:380;}
  .ui-search{flex:1;height:20px;border-radius:6px;background:var(--paper);border:1px solid var(--line);}
  .ui-ava{width:20px;height:20px;border-radius:50%;background:rgba(27,24,19,.16);}
  .ui-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
  .ui-kpi{border:1px solid var(--line);border-radius:7px;padding:8px 9px;background:var(--paper);display:flex;flex-direction:column;gap:5px;}
  .ui-kpi.accent{background:var(--accent);border-color:var(--accent);}
  .ui-kpi-l{font-size:7.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);}
  .ui-kpi.accent .ui-kpi-l{color:rgba(255,255,255,.8);}
  .ui-kpi-n{font-family:var(--serif);font-size:17px;font-weight:380;}
  .ui-kpi.accent .ui-kpi-n{color:#fff;}
  .ui-table{border:1px solid var(--line);border-radius:7px;overflow:hidden;background:var(--paper);flex:1;}
  .ui-tr{display:grid;grid-template-columns:1fr 70px 56px;gap:10px;align-items:center;padding:8px 11px;border-bottom:1px solid var(--line-soft);}
  .ui-tr:last-child{border-bottom:none;}
  .ui-th{background:var(--paper-2);}
  .ui-th span{font-size:7.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;}
  .ui-pill{font-size:8px;font-weight:600;text-align:center;padding:3px 0;border-radius:100px;background:rgba(27,24,19,.1);color:var(--ink-soft);}
  .ui-pill.ok{background:rgba(216,69,28,.12);color:var(--accent-deep);}
  .ui-pill.warn{background:rgba(27,24,19,.08);color:var(--ink-soft);}

  /* P2 portal */
  .ui--portal{display:flex;flex-direction:column;}
  .ui-ptop{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border-bottom:1px solid var(--line);background:var(--paper);}
  .ui-brand{display:flex;align-items:center;gap:8px;font-family:var(--serif);font-size:14px;font-weight:400;}
  .ui-brand i{width:16px;height:16px;border-radius:50%;background:var(--accent);}
  .ui-roles{display:flex;gap:5px;}
  .ui-role{font-size:8.5px;font-weight:600;padding:5px 8px;border-radius:6px;color:var(--ink-faint);}
  .ui-role.is-active{background:var(--ink);color:var(--paper);}
  .ui-pbody{padding:14px 15px;display:flex;flex-direction:column;gap:12px;flex:1;}
  .ui-pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;}
  .ui-pcard{border:1px solid var(--line);border-radius:8px;padding:11px;background:var(--paper);display:flex;flex-direction:column;gap:4px;}
  .ui-pcard.accent{background:var(--accent);border-color:var(--accent);}
  .ui-pc-n{font-family:var(--serif);font-size:20px;font-weight:380;}
  .ui-pcard.accent .ui-pc-n{color:#fff;}
  .ui-pc-l{font-size:8px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);}
  .ui-pcard.accent .ui-pc-l{color:rgba(255,255,255,.82);}
  .ui-list{border:1px solid var(--line);border-radius:8px;background:var(--paper);overflow:hidden;flex:1;}
  .ui-li{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--line-soft);}
  .ui-li:last-child{border-bottom:none;}
  .ui-dot{width:14px;height:14px;border-radius:50%;background:rgba(27,24,19,.16);flex:none;}
  .ui-dot.accent{background:var(--accent);}
  .ui-li .ui-greek{flex:1;}
  .ui-time{font-family:var(--mono);font-size:9px;color:var(--ink-soft);}

  /* P3 gov wizard */
  .ui--gov{padding:15px 16px;display:flex;flex-direction:column;gap:14px;background:var(--paper);}
  .ui-steps{display:flex;gap:6px;}
  .ui-step{flex:1;font-size:7.5px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;text-align:center;padding:6px 0;border-radius:6px;background:rgba(27,24,19,.06);color:var(--ink-faint);position:relative;}
  .ui-step.done{background:rgba(216,69,28,.12);color:var(--accent-deep);}
  .ui-step.active{background:var(--ink);color:var(--paper);}
  .ui-formwrap{display:grid;grid-template-columns:1fr 96px;gap:14px;flex:1;}
  .ui-form{display:flex;flex-direction:column;gap:11px;}
  .ui-field{display:flex;flex-direction:column;gap:5px;}
  .ui-field>span:first-child{font-size:8px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);font-weight:600;}
  .ui-input{height:24px;border-radius:6px;background:var(--paper-3);border:1px solid var(--line);}
  .ui-field2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  .ui-btn{margin-top:2px;align-self:flex-start;font-size:9px;font-weight:700;color:#fff;background:var(--accent);padding:8px 16px;border-radius:7px;letter-spacing:.04em;}
  .ui-summary{border:1px solid var(--line);border-radius:8px;background:var(--paper-3);padding:11px;display:flex;flex-direction:column;gap:8px;}
  .ui-sum-t{font-size:8px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:600;}

  /* P4 dashboard */
  .ui--dash{padding:15px 16px;display:flex;flex-direction:column;gap:13px;background:var(--paper);}
  .ui-dtop{display:flex;align-items:center;justify-content:space-between;}
  .ui-tag{font-family:var(--mono);font-size:9px;color:var(--accent);border:1px solid rgba(216,69,28,.4);padding:3px 9px;border-radius:100px;}
  .ui-dgrid{display:grid;grid-template-columns:32% 1fr;gap:12px;flex:1;}
  .ui-dkpis{display:flex;flex-direction:column;gap:10px;}
  .ui-dkpi{border:1px solid var(--line);border-radius:8px;padding:11px;background:var(--paper-3);display:flex;flex-direction:column;gap:4px;flex:1;justify-content:center;}
  .ui-dk-n{font-family:var(--serif);font-size:21px;font-weight:380;}
  .ui-dk-l{font-size:8px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);}
  .ui-chart{border:1px solid var(--line);border-radius:8px;background:var(--paper-3);padding:12px;display:flex;align-items:flex-end;}
  .ui-bars{display:flex;align-items:flex-end;gap:8px;width:100%;height:100%;}
  .ui-bars b{flex:1;border-radius:4px 4px 0 0;background:rgba(27,24,19,.2);transform:scaleY(.06);transform-origin:50% 100%;transition:transform .7s cubic-bezier(.2,.8,.2,1);}
  .ui-bars b.hi{background:var(--accent);}
  .play.go .ui-bars b{transform:scaleY(1);}
  .ui-bars b:nth-child(1){height:42%;transition-delay:.05s;} .ui-bars b:nth-child(2){height:60%;transition-delay:.1s;} .ui-bars b:nth-child(3){height:50%;transition-delay:.15s;} .ui-bars b:nth-child(4){height:82%;transition-delay:.2s;} .ui-bars b:nth-child(5){height:66%;transition-delay:.25s;} .ui-bars b:nth-child(6){height:90%;transition-delay:.3s;} .ui-bars b:nth-child(7){height:54%;transition-delay:.35s;} .ui-bars b:nth-child(8){height:72%;transition-delay:.4s;}

  @media (max-width:860px){
    .project{grid-template-columns:1fr;gap:36px;}
    .project .stage{order:-1;}
    .project.rev .project__txt{order:0;}
  }

  /* ============ CAPABILITIES ============ */
  .caps{padding:clamp(80px,12vh,150px) 0;background:var(--paper-2);position:relative;z-index:2;}
  .caps__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(40px,6vw,90px);}
  .capblock{border-top:1px solid var(--ink);padding:30px 0 38px;}
  .capblock h3{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:20px;}
  .capblock ul{list-style:none;}
  .capblock li{font-family:var(--serif);font-weight:340;font-size:clamp(1.15rem,1.7vw,1.55rem);line-height:1.5;color:var(--ink);}
  .capblock li span{color:var(--ink-faint);font-size:.8em;}
  @media (max-width:760px){.caps__grid{grid-template-columns:1fr;}}

  /* process */
  .method{margin-top:clamp(50px,7vh,80px);border-top:1px solid var(--ink);padding-top:34px;}
  .method__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:34px;}
  .method__steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
  .method__line{position:absolute;top:-1px;left:0;height:2px;background:var(--accent);width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1);z-index:3;}
  .method.go .method__line{width:100%;}
  .mstep{background:var(--paper-2);padding:26px 22px;opacity:.4;transition:opacity .6s ease;}
  .method.go .mstep{opacity:1;}
  .method.go .mstep:nth-child(2){transition-delay:.25s;} .method.go .mstep:nth-child(3){transition-delay:.55s;} .method.go .mstep:nth-child(4){transition-delay:.85s;} .method.go .mstep:nth-child(5){transition-delay:1.15s;}
  .mstep .n{font-family:var(--mono);font-size:12px;color:var(--accent-deep);letter-spacing:.08em;}
  .mstep .t{font-family:var(--serif);font-size:clamp(1.3rem,2vw,1.8rem);font-weight:350;margin:14px 0 8px;}
  .mstep .d{font-size:.85rem;color:var(--ink-soft);line-height:1.45;}
  @media (max-width:760px){.method__steps{grid-template-columns:repeat(2,1fr);}}

  /* ============ CONTACT ============ */
  .contact{background:var(--ink);color:var(--paper);padding:clamp(90px,15vh,180px) 0 0;position:relative;z-index:2;}
  .contact .label{color:rgba(241,236,227,.55);}
  .contact__head{padding-bottom:30px;margin-bottom:60px;border-bottom:1px solid rgba(241,236,227,.16);display:flex;gap:18px;align-items:baseline;}
  .contact__head .num{font-family:var(--mono);font-size:12px;color:#E85A2E;letter-spacing:.1em;}
  .contact__head h2{font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(241,236,227,.55);}
  .contact h3{font-family:var(--serif);font-weight:320;font-size:clamp(3rem,11vw,9rem);line-height:.95;letter-spacing:-.02em;margin-bottom:clamp(40px,6vh,70px);}
  .contact h3 em{font-style:italic;color:var(--accent);font-weight:360;}
  .contact__sub{font-size:clamp(1.05rem,1.4vw,1.25rem);color:rgba(241,236,227,.72);max-width:42ch;margin-bottom:clamp(50px,7vh,80px);font-weight:380;line-height:1.5;}
  .contact__links{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(241,236,227,.16);border-top:1px solid rgba(241,236,227,.16);border-bottom:1px solid rgba(241,236,227,.16);}
  .clink{background:var(--ink);padding:30px 4px 30px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:padding-left .35s,background .35s;}
  .clink:hover{padding-left:18px;background:#231f19;}
  .clink__k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(241,236,227,.5);}
  .clink__v{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,2.1rem);font-weight:340;}
  .clink__v .arr{display:inline-block;color:var(--accent);transition:transform .35s;}
  .clink:hover .clink__v .arr{transform:translate(5px,-5px);}
  @media (max-width:680px){.contact__links{grid-template-columns:1fr;}}
  footer{padding:42px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;}
  footer span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(241,236,227,.6);}

  /* ============ ACCESSIBILITY ============ */
  :focus{outline:none;}
  :focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px;}
  .contact :focus-visible{outline-color:#fff;}
  .skip{position:absolute;left:-9999px;top:0;z-index:10001;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12px;padding:12px 18px;border-radius:0 0 8px 0;}
  .skip:focus{left:0;}

  /* ============ CV BUTTON / NAV ============ */
  .bar__right{display:flex;align-items:center;gap:18px;}
  .btn-cv{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);padding:8px 14px;border-radius:100px;display:inline-flex;align-items:center;gap:8px;transition:background .3s,color .3s;}
  .btn-cv:hover{background:var(--ink);color:var(--paper);}
  .btn-cv .dl{font-size:13px;line-height:1;}
  @media (max-width:820px){.bar__right .btn-cv{display:none;}}

  /* ============ CTA EN PREPARACIÓN ============ */
  .project__soon{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);display:inline-flex;align-items:center;gap:9px;}
  .project__soon::before{content:"";width:7px;height:7px;border-radius:50%;border:1px solid var(--ink-faint);}

  /* ============ CASE STUDY PAGE ============ */
  .case{padding-top:clamp(110px,16vh,170px);}
  .case-back{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);display:inline-flex;align-items:center;gap:9px;margin-bottom:clamp(40px,7vh,70px);transition:gap .3s,color .3s;}
  .case-back:hover{color:var(--ink);gap:13px;}
  .case-back .ar{color:var(--accent);}
  .case-hero__meta{display:flex;gap:14px;align-items:baseline;margin-bottom:26px;}
  .case-hero__meta .pn{font-family:var(--mono);font-size:12px;color:var(--accent-deep);letter-spacing:.1em;}
  .case-hero__meta .pc{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.08em;text-transform:uppercase;}
  .case-hero h1{font-family:var(--serif);font-weight:340;font-size:clamp(2.4rem,6.5vw,6rem);line-height:1;letter-spacing:-.02em;max-width:16ch;font-variation-settings:"opsz" 144;}
  .case-hero__lede{font-size:clamp(1.1rem,1.6vw,1.4rem);line-height:1.5;color:var(--ink-soft);max-width:52ch;margin-top:clamp(28px,4vh,44px);font-weight:380;}
  .case-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(46px,7vh,80px);}
  .case-fact{background:var(--paper);padding:24px 22px;}
  .case-fact dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;}
  .case-fact dd{font-size:1rem;font-weight:500;line-height:1.4;}
  @media (max-width:760px){.case-facts{grid-template-columns:repeat(2,1fr);}}

  .imgslot{border:1px dashed var(--line);border-radius:12px;background:repeating-linear-gradient(135deg,transparent,transparent 12px,var(--line-soft) 12px,var(--line-soft) 13px),var(--paper-3);display:flex;align-items:center;justify-content:center;color:var(--ink-faint);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;text-align:center;padding:24px;min-height:120px;}
  .imgslot.cover{aspect-ratio:16/8.5;margin-top:clamp(46px,7vh,80px);}
  .imgslot.tall{aspect-ratio:4/3;}
  .imgslot.wide{aspect-ratio:16/7;}

  .case-block{padding:clamp(64px,10vh,120px) 0;border-top:1px solid var(--line);}
  .case-block:first-of-type{border-top:none;}
  .case-block__grid{display:grid;grid-template-columns:0.9fr 1.4fr;gap:clamp(34px,5vw,80px);align-items:start;}
  .case-block__grid.flip .case-block__media{order:-1;}
  .case-step{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:18px;}
  .case-block h2{font-family:var(--serif);font-weight:350;font-size:clamp(1.7rem,3vw,2.6rem);line-height:1.1;letter-spacing:-.01em;margin-bottom:24px;}
  .case-block p{font-size:1.05rem;line-height:1.65;color:var(--ink-soft);margin-bottom:18px;max-width:56ch;font-weight:380;}
  .case-block p b{color:var(--ink);font-weight:600;}
  .case-block ul{list-style:none;margin-top:8px;}
  .case-block li{font-size:1.02rem;line-height:1.6;color:var(--ink-soft);padding-left:20px;position:relative;margin-bottom:8px;}
  .case-block li::before{content:"";position:absolute;left:0;top:11px;width:7px;height:1px;background:var(--accent);}
  @media (max-width:860px){.case-block__grid{grid-template-columns:1fr;gap:34px;}.case-block__grid.flip .case-block__media{order:0;}}

  .case-metrics{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:30px;}
  .case-metric{background:var(--paper);padding:28px 24px;}
  .case-metric .mv{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:340;line-height:1;letter-spacing:-.02em;}
  .case-metric .mv .accent{font-style:italic;}
  .case-metric .ml{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-top:12px;line-height:1.4;}
  @media (max-width:760px){.case-metrics{grid-template-columns:1fr;}}

  .case-next{border-top:1px solid var(--line);padding:clamp(60px,9vh,110px) 0;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
  .case-next__l{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);}
  .case-next a{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.6rem);font-weight:340;display:inline-flex;align-items:center;gap:14px;}
  .case-next a .ar{color:var(--accent);transition:transform .3s;}
  .case-next a:hover .ar{transform:translateX(6px);}

  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
    .reveal{opacity:1;transform:none;}
    .h-mask h1{transform:none;}
    .hero__eyebrow::before{transform:scaleX(1);}
    .method__line{width:100%;}.mstep{opacity:1;}
    .ui-bars b{transform:scaleY(1);}.play .anim{opacity:1;transform:none;}
    .loader{display:none;}
  }
