  :root{
    --ink:#0b0f0d;
    --paper:#f3efe6;
    --paper-2:#ebe5d6;
    --rule:#1a1f1c;
    --muted:#6b6a62;
    --accent:#ff5a1f;     /* signal orange */
    --accent-2:#1f3b2d;   /* deep forest */
    --gold:#c9a24a;
    --serif:'DM Serif Display', ui-serif, Georgia, serif;
    --sans:'Inter Tight', system-ui, sans-serif;
    --mono:'JetBrains Mono', ui-monospace, monospace;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h,80px)}
  html,body{background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%}
  body{
    background-image:
      radial-gradient(circle at 1px 1px, rgba(11,15,13,.07) 1px, transparent 0);
    background-size:22px 22px;
  }
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--accent);color:var(--paper)}

  .wrap{max-width:1360px;margin:0 auto;padding:0 32px}

  /* ───── NAV ───── */
  nav.top{
    display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;
    padding:22px 32px;border-bottom:1px solid var(--rule);
    position:sticky;top:0;z-index:50;
    background:rgba(243,239,230,.86);backdrop-filter:blur(10px);
  }
  .brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:400;letter-spacing:-.01em}
  .brand .mark{width:36px;height:36px;display:block;flex-shrink:0}
  .brand span.name{font-size:20px}
  .brand small{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;display:block;margin-top:-2px}
  .navlinks{display:flex;gap:34px;justify-content:center;font-size:13.5px}
  .navlinks a{position:relative;padding:6px 0}
  .navlinks a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.7,0,.2,1)}
  .navlinks a:hover::after{transform:scaleX(1)}
  .cta{
    font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;
    border:1px solid var(--ink);padding:11px 18px;border-radius:999px;
    display:inline-flex;align-items:center;gap:10px;transition:all .3s;
  }
  .cta:hover{background:var(--ink);color:var(--paper)}
  .cta .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(255,90,31,.18)}
  .nav-right{display:flex;align-items:center;gap:12px;justify-self:end}

  /* hamburger */
  .hamburger{
    display:none;width:42px;height:42px;border:1px solid var(--ink);border-radius:50%;
    background:transparent;cursor:pointer;padding:0;
    align-items:center;justify-content:center;
  }
  .hamburger .bars{position:relative;display:block;width:16px;height:12px}
  .hamburger .bars::before,.hamburger .bars::after{
    content:"";position:absolute;left:0;width:16px;height:1.5px;background:var(--ink);
    transition:top .3s, transform .3s;
  }
  .hamburger .bars::before{top:2px}
  .hamburger .bars::after{top:9px}
  .hamburger.open .bars::before{top:5px;transform:rotate(45deg)}
  .hamburger.open .bars::after{top:5px;transform:rotate(-45deg)}

  /* mobile menu overlay */
  .mobile-menu{
    position:fixed;
    top:var(--nav-h,80px);left:0;right:0;bottom:0;
    z-index:45;
    background:var(--paper);
    background-image:radial-gradient(circle at 1px 1px, rgba(11,15,13,.07) 1px, transparent 0);
    background-size:22px 22px;
    padding:28px 32px 40px;
    display:flex;flex-direction:column;
    opacity:0;pointer-events:none;transform:translateY(-8px);
    transition:opacity .35s cubic-bezier(.2,.7,.2,1), transform .35s cubic-bezier(.2,.7,.2,1);
    overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  }
  .mobile-menu.open{opacity:1;pointer-events:auto;transform:none}
  .mobile-menu .mm-links{display:flex;flex-direction:column}
  .mobile-menu .mm-links a{
    font-family:var(--serif);font-weight:400;font-size:clamp(30px,8vw,44px);
    letter-spacing:-.02em;padding:22px 0;border-bottom:1px solid var(--rule);
    display:flex;justify-content:space-between;align-items:baseline;gap:14px;
    transition:color .3s, padding-left .3s;
  }
  .mobile-menu .mm-links a:hover,.mobile-menu .mm-links a:active{color:var(--accent);padding-left:10px}
  .mobile-menu .mm-links a .num{
    font-family:var(--mono);font-size:11px;font-weight:400;letter-spacing:.18em;color:var(--muted);
  }
  .mobile-menu .mm-cta{
    margin-top:32px;background:var(--ink);color:var(--paper);
    padding:20px 26px;border-radius:999px;align-self:flex-start;
    font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;
    display:inline-flex;align-items:center;gap:14px;
  }
  .mobile-menu .mm-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(255,90,31,.18)}
  .mobile-menu .mm-foot{
    margin-top:auto;padding-top:32px;
    font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
    display:flex;flex-direction:column;gap:6px;
  }
  html.menu-open,body.menu-open{overflow:hidden;height:100%}

  /* ───── TICKER ───── */
  .ticker{
    border-bottom:1px solid var(--rule);
    background:var(--ink);color:var(--paper);
    overflow:hidden;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  }
  .ticker-track{display:flex;gap:60px;padding:11px 0;white-space:nowrap;animation:scroll 45s linear infinite}
  .ticker-track span{display:inline-flex;align-items:center;gap:14px}
  .ticker-track span::before{content:"◆";color:var(--accent);font-size:9px}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ───── HERO ───── */
  .hero{position:relative;padding:80px 0 60px;border-bottom:1px solid var(--rule);overflow:hidden}
  .hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
  .hero-bg img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    filter:grayscale(1) contrast(1.05) brightness(1.1);
    opacity:.13;mix-blend-mode:multiply;
  }
  .hero-bg::after{
    content:"";position:absolute;inset:0;
    background:
      linear-gradient(180deg,rgba(243,239,230,.4) 0%,transparent 25%,transparent 70%,var(--paper) 100%),
      linear-gradient(90deg,var(--paper) 0%,transparent 25%,transparent 75%,var(--paper) 100%);
  }
  .hero .wrap{position:relative;z-index:1}
  .hero-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:60px;align-items:start}
  .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px;margin-bottom:34px}
  .eyebrow::before{content:"";width:42px;height:1px;background:var(--ink)}
  h1.display{
    font-family:var(--serif);font-weight:400;
    font-size:clamp(44px,9vw,148px);
    line-height:.88;letter-spacing:-.04em;
    overflow-wrap:break-word;word-wrap:break-word;
  }
  h1.display .it{font-style:italic;font-weight:400}
  h1.display .underline{
    position:relative;display:inline-block;isolation:isolate;
  }
  h1.display .underline::after{
    content:"";position:absolute;left:-2%;right:-2%;bottom:.08em;height:.45em;
    background:var(--accent);z-index:-1;transform:skewX(-6deg);
    opacity:.92;
  }
  .hero-aside{display:flex;flex-direction:column;gap:30px;padding-bottom:14px}
  .hero-aside p.lede{font-size:18px;line-height:1.5;color:#2a2e2b;max-width:38ch}
  .hero-aside p.lede b{font-family:var(--serif);font-weight:400;font-style:italic}
  .savings-chart{margin:0;border:1px solid var(--rule);border-radius:14px;background:var(--paper);padding:18px 18px 14px;box-shadow:6px 6px 0 var(--ink)}
  .savings-chart svg{width:100%;height:auto;display:block}
  .savings-chart .sc-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
  .savings-chart .sc-delta{color:var(--accent);font-weight:500;letter-spacing:.08em}
  .savings-chart .sc-foot{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted);margin-top:6px}
  .savings-chart svg path[fill="none"]{stroke-dasharray:900;stroke-dashoffset:900;animation:draw 2.4s cubic-bezier(.65,0,.35,1) .4s forwards}
  @keyframes draw{to{stroke-dashoffset:0}}
  .hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
  .btn-primary{
    background:var(--ink);color:var(--paper);
    padding:18px 26px;border-radius:999px;
    font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;
    display:inline-flex;align-items:center;gap:14px;transition:all .35s;
  }
  .btn-primary:hover{background:var(--accent);color:var(--ink)}
  .btn-primary svg{transition:transform .35s}
  .btn-primary:hover svg{transform:translateX(4px)}
  .btn-ghost{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;padding:18px 4px;border-bottom:1px solid var(--ink)}

  .hero-meta{
    margin-top:70px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
    border-top:1px solid var(--rule);padding-top:24px;
  }
  .meta{display:flex;flex-direction:column;gap:6px}
  .meta .k{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
  .meta .v{font-family:var(--serif);font-size:clamp(40px,4.2vw,56px);font-weight:400;letter-spacing:-.025em;line-height:.95}
  .meta .v .small{font-size:.55em;color:var(--muted);font-style:normal;margin-left:2px;vertical-align:baseline}
  .meta .v.text{font-family:var(--mono);font-size:12px;font-weight:400;color:var(--ink);letter-spacing:.08em;text-transform:uppercase;line-height:1.4;padding-top:14px;white-space:nowrap}

  /* status chip */
  .chip{
    background:var(--paper-2);border:1px solid var(--rule);border-radius:14px;
    padding:14px 18px;display:inline-flex;align-items:center;gap:14px;
    font-family:var(--mono);font-size:11px;letter-spacing:.08em;
    box-shadow:8px 8px 0 var(--ink);
    animation:float 6s ease-in-out infinite;
    align-self:flex-start;
    margin-bottom:-8px;
  }
  @media (max-width:780px){.chip{padding:12px 16px;font-size:10px;margin-bottom:-6px}}
  .chip .pulse{width:8px;height:8px;border-radius:50%;background:#1f8a4d;box-shadow:0 0 0 0 rgba(31,138,77,.6);animation:pulse 2s infinite}
  @keyframes pulse{70%{box-shadow:0 0 0 12px rgba(31,138,77,0)}100%{box-shadow:0 0 0 0 rgba(31,138,77,0)}}
  @keyframes float{50%{transform:translateY(-8px)}}

  /* ───── SERVICES ───── */
  section.services{padding:120px 0;border-bottom:1px solid var(--rule);position:relative}
  .section-head{display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:start;margin-bottom:80px}
  .section-head .label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
  .section-head .label::before{content:"§ ";color:var(--accent)}
  .section-head h2{
    font-family:var(--serif);font-weight:400;
    font-size:clamp(32px,5.4vw,76px);line-height:.95;letter-spacing:-.025em;
    overflow-wrap:break-word;
  }
  .section-head h2 em{font-weight:400;font-style:italic;color:var(--accent-2)}

  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
  .svc{
    border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
    padding:36px 32px 40px;position:relative;cursor:pointer;
    transition:background .4s;
    min-height:300px;display:flex;flex-direction:column;justify-content:space-between;
  }
  .svc:hover{background:var(--paper-2)}
  .svc:hover .num{color:var(--accent)}
  .svc .num{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.18em;transition:color .3s}
  .svc h3{font-family:var(--serif);font-weight:400;font-size:30px;line-height:1.05;letter-spacing:-.02em;margin-top:14px}
  .svc p{margin-top:14px;font-size:14px;line-height:1.55;color:#3a3e3a;max-width:36ch}
  .svc .arrow{
    margin-top:28px;width:42px;height:42px;border-radius:50%;border:1px solid var(--ink);
    display:grid;place-items:center;transition:all .35s;
  }
  .svc:hover .arrow{background:var(--ink);color:var(--paper);transform:rotate(-45deg)}
  .svc-grid.tiers{grid-template-columns:repeat(3,1fr)}
  .svc.tier{min-height:440px}
  .svc.tier ul.incl{list-style:none;margin:22px 0 18px;padding:18px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:8px}
  .svc.tier ul.incl li{font-family:var(--mono);font-size:12px;letter-spacing:.04em;display:flex;align-items:center;gap:10px}
  .svc.tier ul.incl li::before{content:"→";color:var(--accent);font-family:var(--sans)}
  .svc.tier.feat{background:var(--ink);color:var(--paper)}
  .svc.tier.feat .num,.svc.tier.feat p{color:#bfc3bd}
  .svc.tier.feat ul.incl{border-color:#2a2f2c}
  .svc.tier.feat .arrow{border-color:var(--paper)}
  .svc.tier.feat:hover{background:var(--accent-2)}
  .svc.tier.feat:hover .num{color:var(--accent)}
  .ribbon{position:absolute;top:18px;right:18px;background:var(--accent);color:var(--ink);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:999px;z-index:2}
  .svc.tier.feat{position:relative}
  .custom-line{margin-top:34px;padding:22px 0 0;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
  .custom-line a{color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px}

  /* ───── BIG STAT ───── */
  section.bignum{
    background:var(--ink);color:var(--paper);padding:130px 0;position:relative;overflow:hidden;
    border-bottom:1px solid var(--rule);
  }
  section.bignum::before{
    content:"";position:absolute;inset:0;
    background-image:radial-gradient(circle at 1px 1px, rgba(243,239,230,.06) 1px, transparent 0);
    background-size:28px 28px;
  }
  .bn-orbit{
    position:absolute;right:-180px;top:50%;transform:translateY(-50%);
    width:min(820px,72vw);height:auto;pointer-events:none;
    opacity:.95;mix-blend-mode:screen;
  }
  .bn-orbit .bn-orbiters{transform-origin:400px 400px;animation:bn-spin 38s linear infinite}
  @keyframes bn-spin{to{transform:rotate(360deg)}}
  @media (prefers-reduced-motion:reduce){.bn-orbit .bn-orbiters{animation:none}}
  @media (max-width:980px){.bn-orbit{right:-50%;width:140vw;opacity:.55}}
  .bn-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;z-index:1}
  .bn-grid .label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#9aa098;margin-bottom:30px}
  .bn-grid .label::before{content:"§ ";color:var(--accent)}
  .bn-num{
    font-family:var(--serif);font-weight:400;
    font-size:clamp(96px,22vw,320px);line-height:.82;letter-spacing:-.05em;
  }
  .bn-num .pct{color:var(--accent);font-style:italic}
  .bn-side h3{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.4vw,40px);line-height:1.15;letter-spacing:-.02em;max-width:18ch}
  .bn-side p{margin-top:24px;font-size:15px;line-height:1.6;color:#bfc3bd;max-width:42ch}
  .bn-side .ledger{margin-top:34px;border-top:1px solid #2a2f2c;padding-top:22px;display:grid;gap:8px;font-family:var(--mono);font-size:12px;color:#bfc3bd}
  .bn-side .ledger row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px dashed #2a2f2c}
  .bn-side .ledger row b{color:var(--paper);font-weight:400}

  /* ───── IMAGE BAND ───── */
  section.bandshot{position:relative;height:clamp(320px,46vh,520px);overflow:hidden;border-bottom:1px solid var(--rule);background:#0b0f0d}
  section.bandshot img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.7) brightness(.42) contrast(1.1);transform:scale(1.05);transition:transform 12s ease-out}
  section.bandshot:hover img{transform:scale(1.1)}
  .bandshot-overlay{position:absolute;inset:0;display:flex;align-items:center;padding:60px 0;color:var(--paper);text-shadow:0 1px 24px rgba(0,0,0,.55)}
  .bandshot-overlay::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,15,13,.35) 0%,rgba(11,15,13,.55) 50%,rgba(11,15,13,.88) 100%)}
  .bandshot-overlay .wrap{position:relative;display:grid;gap:14px;max-width:60ch}
  .bandshot-overlay .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#ff5a1f;display:flex;align-items:center;gap:14px;margin:0}
  .bandshot-overlay .eyebrow::before{content:"";width:42px;height:1px;background:#ff5a1f}
  .bandshot-overlay h3{font-family:var(--serif);font-weight:400;font-size:clamp(38px,5.2vw,70px);line-height:.95;letter-spacing:-.025em}
  .bandshot-overlay h3 em{font-style:italic;color:#ff5a1f}
  .bandshot-overlay p{max-width:48ch;line-height:1.55;color:#cfd2cd}

  /* ───── PROCESS ───── */
  section.process{padding:130px 0;border-bottom:1px solid var(--rule)}
  .process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--rule);position:relative}
  .step{padding:34px 22px 50px;border-right:1px solid var(--rule);position:relative}
  .step:last-child{border-right:none}
  .step .dot{
    position:absolute;top:-6px;left:22px;width:11px;height:11px;border-radius:50%;
    background:var(--paper);border:2px solid var(--ink);
  }
  .step .stage{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
  .step h4{font-family:var(--serif);font-weight:400;font-size:24px;line-height:1.1;letter-spacing:-.02em;margin-top:80px}
  .step p{font-size:14px;line-height:1.55;color:#3a3e3a;margin-top:12px}
  .process-grid.seven{grid-template-columns:repeat(7,1fr)}
  .process-grid.seven .step h4{margin-top:60px;font-size:19px;min-height:2.4em;display:flex;align-items:flex-end}

  /* specialties */
  section.specialties{padding:130px 0;border-bottom:1px solid var(--rule)}
  .cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
  .cat{display:block;padding:40px 32px 44px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);transition:background .35s;position:relative}
  .cat:hover{background:var(--ink);color:var(--paper)}
  .cat:hover p{color:#bfc3bd}
  .cat:hover .cn{color:var(--accent)}
  .cat .cn{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted);transition:color .3s}
  .cat h4{font-family:var(--serif);font-weight:400;font-size:30px;line-height:1.05;letter-spacing:-.02em;margin-top:18px}
  .cat-mark{display:block;width:54px;height:54px;margin-top:22px;color:var(--ink);transition:color .35s,transform .6s cubic-bezier(.2,.8,.2,1)}
  .cat:hover .cat-mark{color:var(--accent);transform:rotate(-6deg) scale(1.05)}
  .cat p{margin-top:12px;font-size:14px;line-height:1.55;color:#3a3e3a;max-width:30ch}

  /* contact form */
  section.contact{position:relative;padding:130px 0;border-bottom:1px solid var(--rule);background:var(--paper-2);overflow:hidden}
  .contact-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
  .contact-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1) brightness(1.15);opacity:.08;mix-blend-mode:multiply}
  .contact-bg::after{
    content:"";position:absolute;inset:0;
    background:
      linear-gradient(180deg,var(--paper-2) 0%,transparent 22%,transparent 78%,var(--paper-2) 100%),
      linear-gradient(90deg,var(--paper-2) 0%,transparent 22%,transparent 78%,var(--paper-2) 100%);
  }
  section.contact .wrap{position:relative;z-index:1}
  .contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
  .contact-left h2{font-family:var(--serif);font-weight:400;font-size:clamp(36px,6vw,86px);line-height:.92;letter-spacing:-.03em;overflow-wrap:break-word}
  .contact-left h2 em{font-style:italic;color:var(--accent-2)}
  .contact-left p{margin-top:24px;line-height:1.6;color:#1f231f;max-width:40ch}
  .contact-info{margin-top:40px;display:grid;gap:18px;border-top:1px solid var(--rule);padding-top:26px}
  .contact-info a{display:flex;align-items:baseline;gap:18px;font-family:var(--serif);font-size:28px;font-weight:400;letter-spacing:-.01em}
  .contact-info a:hover{color:var(--accent)}
  .contact-info .lab{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);min-width:60px}
  .contact-info .vanity{font-family:var(--mono);font-size:11px;color:var(--muted);margin-left:6px;letter-spacing:.1em}

  form.fr{
    background:var(--paper);border:1px solid var(--rule);border-radius:18px;
    padding:36px;box-shadow:14px 14px 0 var(--ink);display:grid;gap:18px;
  }
  form.fr .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  form.fr label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
  form.fr input,form.fr textarea{
    width:100%;background:transparent;border:none;border-bottom:1px solid var(--rule);
    padding:8px 0 12px;font-family:var(--sans);font-size:15px;color:var(--ink);
    transition:border-color .3s;
  }
  form.fr input:focus,form.fr textarea:focus{outline:none;border-bottom-color:var(--accent)}
  form.fr textarea{min-height:96px;resize:vertical}
  form.fr button{
    margin-top:8px;background:var(--ink);color:var(--paper);
    padding:18px 26px;border:none;border-radius:999px;cursor:pointer;
    font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;
    display:inline-flex;align-items:center;justify-content:center;gap:14px;transition:background .3s;
  }
  form.fr button:hover{background:var(--accent);color:var(--ink)}
  form.fr button:disabled{opacity:.7;cursor:wait}
  .form-status{font-family:var(--mono);font-size:11px;letter-spacing:.06em;line-height:1.5;margin-top:4px;min-height:1em}
  .form-status.ok{color:#1f8a4d}
  .form-status.err{color:#b3321f}
  .g-recaptcha{margin:6px auto 0;min-height:78px;display:flex;justify-content:center}
  @media (max-width:1100px){
    .process-grid.seven{grid-template-columns:1fr}
    .process-grid.seven .step{border-right:none;border-bottom:1px solid var(--rule);padding:30px 0 34px}
    .process-grid.seven .step:last-child{border-bottom:none}
    .process-grid.seven .step h4{font-size:26px;margin-top:18px;line-height:1.05}
    .process-grid.seven .step .stage{font-size:11px}
    .process-grid.seven .step p{font-size:15px;line-height:1.55;margin-top:10px;max-width:48ch}
  }
  @media (max-width:780px){
    .cat-grid{grid-template-columns:1fr 1fr}
    .contact-grid{grid-template-columns:1fr;gap:40px}
    .cat{border-bottom:1px solid var(--rule)}
  }

  /* ───── PROOF / TEAM ───── */
  section.proof{padding:130px 0;border-bottom:1px solid var(--rule);background:var(--paper-2)}
  .proof-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
  .about-photo{margin:38px 0 0;border:1px solid var(--rule);border-radius:14px;overflow:hidden;background:var(--ink);box-shadow:8px 8px 0 var(--ink)}
  .about-photo img{display:block;width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;filter:grayscale(.4) contrast(1.05)}
  .about-photo figcaption{padding:14px 18px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);background:var(--ink);border-top:1px solid #2a2f2c}
  .quote{
    font-family:var(--serif);font-weight:400;font-size:clamp(30px,3.6vw,48px);
    line-height:1.12;letter-spacing:-.02em;
  }
  .quote::before{content:"“";font-size:1.4em;line-height:0;vertical-align:-.3em;color:var(--accent);margin-right:.05em}
  .quote::after{content:"”";color:var(--accent)}
  .quote em{font-style:italic;color:var(--accent-2)}
  .attrib{margin-top:30px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px}
  .attrib::before{content:"";width:30px;height:1px;background:var(--ink)}
  .team-card{
    background:var(--paper);border:1px solid var(--rule);border-radius:18px;padding:36px;
    box-shadow:14px 14px 0 var(--ink);
  }
  .team-card .label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
  .team-card h3{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3vw,36px);line-height:1.05;letter-spacing:-.02em;margin-top:14px}
  .team-card h3 em{font-style:italic;font-weight:400;color:var(--accent-2)}
  .team-card p{margin-top:18px;line-height:1.6;color:#3a3e3a}
  .yrs{display:flex;align-items:baseline;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
  .yrs .big{font-family:var(--serif);font-size:clamp(72px,9vw,96px);font-weight:400;line-height:.85;letter-spacing:-.04em}
  .yrs .big .plus{color:var(--accent)}
  .yrs .desc{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);max-width:14ch}

  /* ───── CTA ───── */
  section.final{padding:140px 0 120px;position:relative;overflow:hidden;border-bottom:1px solid var(--rule)}
  section.final::before{
    content:"FOCUS";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    font-family:var(--serif);font-weight:400;font-size:48vw;line-height:.8;
    color:transparent;-webkit-text-stroke:1px rgba(11,15,13,.07);
    pointer-events:none;letter-spacing:-.05em;
  }
  .final-inner{position:relative;text-align:center;display:grid;justify-items:center;gap:40px}
  .final-inner h2{font-family:var(--serif);font-weight:400;font-size:clamp(38px,7vw,108px);line-height:.92;letter-spacing:-.03em;max-width:14ch;overflow-wrap:break-word}
  .final-inner h2 em{font-style:italic;color:var(--accent-2)}
  .final-inner p{max-width:50ch;line-height:1.6;color:#3a3e3a}
  .final-actions{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}

  /* ───── FOOTER ───── */
  footer{padding:50px 0 36px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
  .foot-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px;align-items:end}
  .foot-grid .col-mid{text-align:center}
  .foot-grid .col-r{text-align:right;display:flex;gap:22px;justify-content:flex-end}
  .foot-grid a:hover{color:var(--ink)}

  /* ───── MOBILE CTA BAR ───── */
  .mobile-cta{display:none}
  @media (max-width:780px){
    .mobile-cta{
      display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;
      background:var(--paper);border-top:1px solid var(--rule);
      padding:10px 12px calc(10px + env(safe-area-inset-bottom));
      gap:10px;box-shadow:0 -8px 24px rgba(11,15,13,.08);
    }
    .mobile-cta a{display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;border-radius:999px;padding:14px 16px;transition:background .25s,color .25s;text-decoration:none}
    .mc-call{flex:0 0 auto;border:1px solid var(--ink);color:var(--ink);background:var(--paper);min-width:96px}
    .mc-call:active{background:var(--ink);color:var(--paper)}
    .mc-cta{flex:1;background:var(--ink);color:var(--paper)}
    .mc-cta:active{background:var(--accent);color:var(--ink)}
    body{padding-bottom:74px}
  }

  /* ───── REVEAL ───── */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  @media (max-width:980px){
    .hero-grid,.bn-grid,.proof-grid,.section-head{grid-template-columns:1fr;gap:36px}
    .svc-grid,.svc-grid.tiers{grid-template-columns:1fr 1fr}
    .process-grid{grid-template-columns:1fr 1fr}
    .step{border-bottom:1px solid var(--rule)}
    .hero-meta{grid-template-columns:1fr 1fr}
    .navlinks{display:none}
    nav.top .cta{display:none}
    .hamburger{display:inline-flex}
    .foot-grid{grid-template-columns:1fr;text-align:left}
    .foot-grid .col-mid,.foot-grid .col-r{text-align:left;justify-content:flex-start}
  }
  @media (max-width:580px){
    /* Grid stacking */
    .svc-grid,.svc-grid.tiers,.process-grid,.cat-grid{grid-template-columns:1fr}
    .svc-grid,.svc-grid.tiers,.cat-grid{border-left:none}
    .svc,.cat{border-right:none}
    .svc,.svc.tier{min-height:auto}
    .hero-meta{grid-template-columns:1fr;margin-top:40px}
    form.fr .row{grid-template-columns:1fr}

    /* Layout polish */
    .wrap{padding:0 22px}
    nav.top{padding:18px 22px}
    .brand small{display:none}

    /* Component overrides */
    form.fr,.team-card{box-shadow:6px 6px 0 var(--ink);padding:24px}
    .team-card h3{font-size:30px}
    .contact-info a{font-size:20px;flex-wrap:wrap}
    .bn-side h3{font-size:26px}
    .svc h3{font-size:26px}
    .svc.tier ul.incl{margin:18px 0 14px;padding:14px 0}

    /* Tighter vertical rhythm */
    .hero{padding:60px 0 40px}
    section.services,section.bignum,section.process,section.specialties,section.proof,section.contact{padding:80px 0}
    section.final{padding:90px 0 70px}
    .section-head{margin-bottom:48px}
  }
