
  :root{
    --ink:#0c0a08; --ink2:#14110d; --paper:#f4efe6; --bone:#cbbfa9;
    --ember:#e8462a; --ember-deep:#b22d18; --brass:#c8a661;
    --line:rgba(203,191,169,.16); --line-strong:rgba(203,191,169,.34);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{background:var(--ink);color:var(--paper);
        font-family:"Archivo",system-ui,sans-serif;line-height:1.6;overflow-x:hidden}
  ::selection{background:var(--ember);color:#fff}

  /* ---- grain + blueprint atmosphere ---- */
  body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.42'/%3E%3C/svg%3E");
    mix-blend-mode:overlay}
  .blueprint{position:fixed;inset:0;z-index:0;pointer-events:none;
    background-image:
      linear-gradient(var(--line) 1px,transparent 1px),
      linear-gradient(90deg,var(--line) 1px,transparent 1px);
    background-size:64px 64px;
    mask-image:radial-gradient(ellipse 90% 70% at 70% 0%,#000 0%,transparent 75%)}

  .wrap{max-width:1280px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
  @media(max-width:760px){.wrap{padding:0 22px}}

  .mono{font-family:"Archivo Narrow","Archivo",sans-serif;text-transform:uppercase;
        letter-spacing:.28em;font-size:11.5px;font-weight:600;color:var(--bone)}
  .tick{display:inline-flex;align-items:center;gap:10px}
  .tick::before{content:"";width:24px;height:1px;background:var(--ember)}

  /* ---- scroll-reveal choreography ----
     Reveal only hides when JS is confirmed running (html.js). If JS fails
     or is slow, content is always visible — no blank-space dead zones. */
  .js .reveal{opacity:0;transform:translateY(34px);
    transition:opacity 1s cubic-bezier(.16,1,.3,1),
               transform 1s cubic-bezier(.16,1,.3,1)}
  .reveal.in,.reveal{opacity:1;transform:none}
  .js .reveal:not(.in){opacity:0;transform:translateY(34px)}
  .reveal[data-d="1"]{transition-delay:.09s}
  .reveal[data-d="2"]{transition-delay:.18s}
  .reveal[data-d="3"]{transition-delay:.27s}
  .reveal[data-d="4"]{transition-delay:.36s}
  @media(prefers-reduced-motion:reduce){
    .reveal{opacity:1!important;transform:none!important}}

  /* ---- custom architectural cursor (fine pointer only) ---- */
  @media(pointer:fine){
    .cur,.cur-dot{position:fixed;top:0;left:0;z-index:9999;
      pointer-events:none;mix-blend-mode:difference;will-change:transform}
    .cur{width:34px;height:34px;margin:-17px 0 0 -17px;
      border:1px solid #f4efe6;border-radius:50%;
      transition:width .25s,height .25s,margin .25s,border-color .25s}
    .cur::before,.cur::after{content:"";position:absolute;background:#f4efe6}
    .cur::before{left:50%;top:-7px;width:1px;height:7px;transform:translateX(-50%)}
    .cur::after{left:-7px;top:50%;height:1px;width:7px;transform:translateY(-50%)}
    .cur-dot{width:4px;height:4px;margin:-2px 0 0 -2px;border-radius:50%;
      background:#f4efe6}
    .cur.hot{width:54px;height:54px;margin:-27px 0 0 -27px;
      border-color:var(--ember)}
    body.has-cur,body.has-cur a,body.has-cur button,
    body.has-cur .zone-grp{cursor:none}}

  /* ---- mobile menu ---- */
  .burger{display:none;width:42px;height:42px;border:1px solid var(--line-strong);
    background:transparent;cursor:pointer;position:relative;flex:none}
  .burger span{position:absolute;left:11px;right:11px;height:1.5px;
    background:var(--paper);transition:transform .35s,opacity .25s}
  .burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:20px}
  .burger span:nth-child(3){top:25px}
  body.nav-open .burger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
  body.nav-open .burger span:nth-child(2){opacity:0}
  body.nav-open .burger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
  .mobnav{position:fixed;inset:0;z-index:39;background:var(--ink);
    display:flex;flex-direction:column;justify-content:center;padding:40px;
    gap:6px;opacity:0;pointer-events:none;transition:opacity .4s;
    border-left:1px solid var(--line)}
  body.nav-open .mobnav{opacity:1;pointer-events:auto}
  .mobnav a{font-family:"Archivo Black",sans-serif;font-size:clamp(30px,9vw,52px);
    color:var(--paper);text-decoration:none;letter-spacing:-.04em;
    padding:8px 0;border-bottom:1px solid var(--line);
    transform:translateX(-30px);opacity:0;transition:transform .5s,opacity .5s,color .3s}
  .mobnav a:hover{color:var(--ember)}
  body.nav-open .mobnav a{transform:none;opacity:1}
  body.nav-open .mobnav a:nth-child(1){transition-delay:.08s}
  body.nav-open .mobnav a:nth-child(2){transition-delay:.14s}
  body.nav-open .mobnav a:nth-child(3){transition-delay:.20s}
  body.nav-open .mobnav a:nth-child(4){transition-delay:.26s}
  body.nav-open .mobnav a:nth-child(5){transition-delay:.32s}
  body.nav-open .mobnav a:nth-child(6){transition-delay:.38s}
  @media(max-width:920px){.burger{display:block}}

  /* ---- sticky mobile call bar ---- */
  .stickybar{position:fixed;left:0;right:0;bottom:0;z-index:38;display:none;
    grid-template-columns:1fr 1fr;background:var(--ink);
    border-top:1px solid var(--line-strong);
    transform:translateY(110%);transition:transform .45s cubic-bezier(.16,1,.3,1)}
  .stickybar.show{transform:none}
  .stickybar a{padding:17px;text-align:center;text-decoration:none;
    font-family:"Archivo Narrow",sans-serif;text-transform:uppercase;
    letter-spacing:.16em;font-size:13px;font-weight:700}
  .stickybar a.call{color:var(--paper)}
  .stickybar a.quote{background:var(--ember);color:#fff}
  @media(max-width:760px){.stickybar{display:grid}}

  /* ---- reviews ---- */
  .rev{padding:130px 0;position:relative;z-index:2;border-top:1px solid var(--line)}
  .rev .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    border:1px solid var(--line);margin-top:64px}
  .rev figure{padding:42px 36px;border-right:1px solid var(--line);
    display:flex;flex-direction:column;gap:20px}
  .rev figure:last-child{border-right:0}
  .rev .stars{color:var(--ember);letter-spacing:4px;font-size:14px}
  .rev blockquote{font-family:"Archivo",sans-serif;font-size:17px;
    line-height:1.6;color:var(--paper)}
  .rev figcaption{margin-top:auto;font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.14em;font-size:11.5px;
    color:var(--bone)}
  .rev figcaption b{color:var(--paper);font-weight:700}
  @media(max-width:820px){.rev .grid{grid-template-columns:1fr}
    .rev figure{border-right:0;border-bottom:1px solid var(--line)}}

  /* ---- process timeline ---- */
  .proc .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
    margin-top:64px;border-top:1px solid var(--line)}
  .proc .step{padding:40px 30px 40px 0;position:relative}
  .proc .step::before{content:"";position:absolute;left:0;top:-1px;width:0;
    height:2px;background:var(--ember);transition:width 1.1s ease}
  .proc .step.in::before{width:72%}
  .proc .step .pn{font-family:"Archivo Black",sans-serif;font-size:54px;
    color:transparent;-webkit-text-stroke:1px var(--line-strong);
    line-height:1;letter-spacing:-.04em;margin-bottom:22px}
  .proc .step h3{font-family:"Archivo Black",sans-serif;font-size:20px;
    letter-spacing:-.02em;margin-bottom:10px}
  .proc .step p{font-size:14px;color:var(--bone);line-height:1.6}
  @media(max-width:820px){.proc .steps{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.proc .steps{grid-template-columns:1fr}}

  /* ---- top + nav ---- */
  .meta{border-bottom:1px solid var(--line);position:relative;z-index:3}
  .meta .wrap{display:flex;justify-content:space-between;align-items:center;
    height:46px;font-size:11px}
  .meta .mono{font-size:10.5px;letter-spacing:.22em;color:var(--bone)}
  .meta a{color:var(--paper);text-decoration:none}

  nav{position:sticky;top:0;z-index:40;
      background:rgba(12,10,8,.72);backdrop-filter:blur(14px) saturate(140%);
      border-bottom:1px solid var(--line)}
  nav .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
  .brand{display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--paper)}
  .brand .glyph{width:42px;height:42px;flex:none}
  .brand .glyph svg{width:100%;height:100%}
  .brand .name{font-family:"Archivo Black",sans-serif;font-weight:900;font-size:19px;
    line-height:1.05;letter-spacing:-.02em}
  .brand .name small{display:block;font-family:"Archivo Narrow",sans-serif;
    font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;
    color:var(--bone);font-weight:600;margin-top:3px}
  .navlinks{display:flex;gap:38px;font-size:14px;font-weight:500;align-items:center}
  .navlinks a{color:var(--paper);text-decoration:none;opacity:.74;
    transition:opacity .25s;position:relative;padding:6px 0}
  .navlinks a:hover{opacity:1}
  .navlinks a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
    background:var(--ember);transition:width .3s ease}
  .navlinks a:hover::after{width:100%}
  .book{font-family:"Archivo Narrow",sans-serif;text-transform:uppercase;
    letter-spacing:.14em;font-weight:700;font-size:12px;color:#fff;
    background:var(--ember);padding:13px 22px;text-decoration:none;
    box-shadow:0 6px 20px -6px rgba(232,70,42,.6);
    transition:background .3s,letter-spacing .3s,box-shadow .3s,transform .2s;
    white-space:nowrap}
  .book:hover{background:var(--ember-deep);letter-spacing:.18em;
    transform:translateY(-1px);box-shadow:0 10px 26px -6px rgba(232,70,42,.7)}
  @media(max-width:920px){.navlinks{display:none}}

  /* ---- hero ---- */
  .hero{position:relative;padding:88px 0 0;overflow:hidden}
  .hero::after{content:"";position:absolute;right:-12%;top:-18%;width:780px;height:780px;
    background:radial-gradient(circle,rgba(232,70,42,.22),transparent 62%);
    z-index:0;filter:blur(8px)}
  .hero .wrap{display:grid;grid-template-columns:1.25fr .92fr;gap:30px;align-items:end}
  .hcoord{position:absolute;left:40px;top:60px;z-index:5}
  .htext{position:relative;z-index:5;padding-bottom:120px}
  .htext .mono{margin-bottom:30px;display:block}
  h1{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:clamp(50px,8.8vw,134px);line-height:.88;letter-spacing:-.05em;
    margin-bottom:34px}
  h1 .em{font-weight:900;color:var(--ember);position:relative;display:inline-block}
  h1 .em::after{content:"";position:absolute;left:0;right:0;bottom:.08em;
    height:.09em;background:var(--ember);opacity:.45}
  h1 .ln{display:block;overflow:hidden}
  h1 .ln span{display:block;transform:translateY(108%);
    animation:rise 1.05s cubic-bezier(.16,1,.3,1) forwards}
  h1 .ln:nth-child(2) span{animation-delay:.12s}
  h1 .ln:nth-child(3) span{animation-delay:.24s}
  @keyframes rise{to{transform:translateY(0)}}
  .fade{opacity:0;animation:fade 1s ease forwards .6s}
  .fade.d2{animation-delay:.78s}
  @keyframes fade{to{opacity:1}}
  .lead{font-size:18px;color:var(--bone);max-width:33em;margin-bottom:40px;
    line-height:1.7}
  .lead b{color:var(--paper);font-weight:600}
  .actions{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
  .primary{display:inline-flex;align-items:center;gap:14px;background:var(--ember);
    color:#fff;text-decoration:none;font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.16em;font-weight:600;font-size:14px;
    padding:19px 30px;transition:background .3s,gap .3s}
  .primary:hover{background:var(--ember-deep);gap:22px}
  .primary svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
  .secondary{color:var(--paper);text-decoration:none;font-size:14px;font-weight:500;
    border-bottom:1px solid var(--line-strong);padding-bottom:5px;
    transition:border-color .3s}
  .secondary:hover{border-color:var(--ember)}

  /* hero blueprint house panel */
  .hpanel{position:relative;z-index:5;border:1px solid var(--line-strong);
    aspect-ratio:3/3.7;padding:26px;overflow:hidden;
    background:linear-gradient(155deg,rgba(20,17,13,.9),rgba(12,10,8,.6));
    display:flex;flex-direction:column;justify-content:space-between}
  /* drop-in AI hero photo layer — duotone + grain + blueprint */
  .hpanel .hphoto{position:absolute;inset:0;z-index:0;overflow:hidden}
  .hpanel .hphoto img{width:100%;height:100%;object-fit:cover;
    filter:saturate(1.18) contrast(1.06) brightness(1.05);
    transform:scale(1.04);transition:transform 8s ease}
  .hpanel:hover .hphoto img{transform:scale(1.08)}
  .hpanel .hphoto::before{content:"";position:absolute;inset:0;
    background:linear-gradient(180deg,
      rgba(12,10,8,.10),rgba(12,10,8,.04) 45%,rgba(12,10,8,.28));
    mix-blend-mode:normal}
  .hpanel .hphoto::after{content:"";position:absolute;inset:0;opacity:.5;
    background-image:
      linear-gradient(rgba(203,191,169,.10) 1px,transparent 1px),
      linear-gradient(90deg,rgba(203,191,169,.10) 1px,transparent 1px);
    background-size:32px 32px;
    -webkit-mask-image:radial-gradient(ellipse 90% 80% at 70% 10%,#000,transparent 78%);
    mask-image:radial-gradient(ellipse 90% 80% at 70% 10%,#000,transparent 78%)}
  .hpanel .hphoto.empty{background:
    repeating-linear-gradient(135deg,rgba(203,191,169,.05) 0 14px,
      transparent 14px 28px),linear-gradient(155deg,#1a140f,#0c0a08)}
  .hpanel .hphoto.empty .ph-note{position:absolute;left:0;right:0;bottom:18px;
    text-align:center;font-family:"Archivo Narrow",sans-serif;font-size:10px;
    letter-spacing:.2em;text-transform:uppercase;color:var(--bone);opacity:.5}
  .hpanel>:not(.hphoto){position:relative;z-index:2}
  .hpanel .corner{position:absolute;width:14px;height:14px;border:1px solid var(--brass)}
  .hpanel .corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
  .hpanel .corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
  .hpanel .corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
  .hpanel .corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0}
  .hpanel .ph{display:flex;justify-content:space-between;align-items:flex-start}
  .hpanel .ph .mono{font-size:9.5px;letter-spacing:.2em;color:var(--brass)}
  .hpanel svg.house{width:100%;flex:1;margin:14px 0;overflow:visible}
  .hpanel svg.house [class]{fill:none;stroke:var(--bone);stroke-width:1.4;
    vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}
  .hpanel svg.house .grid{stroke:var(--line-strong);stroke-width:1}
  .hpanel svg.house .frame{stroke:var(--bone);
    stroke-dasharray:1400;stroke-dashoffset:1400;
    animation:draw 2.4s cubic-bezier(.7,0,.3,1) forwards 1s}
  .hpanel svg.house .studs line{stroke:var(--bone);stroke-width:.8;opacity:0;
    animation:fadeStud .5s ease forwards}
  .hpanel svg.house .studs line:nth-child(1){animation-delay:2.6s}
  .hpanel svg.house .studs line:nth-child(2){animation-delay:2.7s}
  .hpanel svg.house .studs line:nth-child(3){animation-delay:2.8s}
  .hpanel svg.house .studs line:nth-child(4){animation-delay:2.9s}
  .hpanel svg.house .studs line:nth-child(5){animation-delay:3s}
  .hpanel svg.house .studs line:nth-child(6){animation-delay:3.1s}
  .hpanel svg.house .glass{stroke:var(--bone);fill:rgba(203,191,169,.06);
    stroke-dasharray:160;stroke-dashoffset:160;
    animation:draw 1s ease forwards 3.2s}
  .hpanel svg.house .door{stroke:var(--bone);
    stroke-dasharray:200;stroke-dashoffset:200;
    animation:draw 1s ease forwards 3.4s}
  .hpanel svg.house .accent{stroke:var(--ember);stroke-width:1.8;
    stroke-dasharray:60;stroke-dashoffset:60;
    animation:draw .6s ease forwards 2.4s}
  .hpanel svg.house .dot{fill:var(--ember);stroke:none;opacity:0;
    animation:pulseDot 2s ease-in-out 3s infinite}
  .hpanel svg.house .dim,.hpanel svg.house .dimtick{stroke:var(--brass);
    stroke-width:.9;opacity:0;animation:fadeStud .6s ease forwards 3.6s}
  .hpanel svg.house .dimtxt{fill:var(--brass);stroke:none;
    font-family:"Archivo Narrow",sans-serif;font-size:9px;letter-spacing:.18em;
    text-anchor:middle;opacity:0;animation:fadeStud .6s ease forwards 3.8s}
  .hpanel svg.house .sweep{opacity:0;
    animation:sweepDown 3.4s cubic-bezier(.45,0,.55,1) infinite 4s}
  @keyframes draw{to{stroke-dashoffset:0}}
  @keyframes fadeStud{to{opacity:1}}
  @keyframes pulseDot{0%,100%{opacity:0;r:2}50%{opacity:1;r:4}}
  @keyframes sweepDown{
    0%{opacity:0;transform:translateY(0)}
    8%{opacity:1}
    92%{opacity:1}
    100%{opacity:0;transform:translateY(216px)}}
  @media(prefers-reduced-motion:reduce){
    .hpanel svg.house *{animation:none!important;stroke-dashoffset:0!important;
      opacity:1!important}}
  .hpanel .pf{border-top:1px solid var(--line);padding-top:16px}
  .hpanel .pf b{font-family:"Archivo Black",sans-serif;font-size:15px;font-weight:900}
  .hpanel .pf p{font-size:11.5px;color:var(--bone);margin-top:3px}
  @media(max-width:920px){.hero .wrap{grid-template-columns:1fr}
    .htext{padding-bottom:60px}.hpanel{aspect-ratio:3/2.4;margin-bottom:40px}
    .hcoord{display:none}}

  /* ---- marquee ---- */
  .marq{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    overflow:hidden;background:var(--ink2);position:relative;z-index:3}
  .marq .track{display:flex;gap:60px;padding:22px 0;width:max-content;
    animation:slide 32s linear infinite;align-items:center}
  .marq:hover .track{animation-play-state:paused}
  @keyframes slide{to{transform:translateX(-50%)}}
  .marq .item{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:20px;text-transform:uppercase;letter-spacing:.02em;
    color:var(--bone);display:flex;align-items:center;gap:60px;
    white-space:nowrap}
  .marq .item::after{content:"✦";color:var(--ember);font-style:normal;font-size:12px}

  /* ---- section frame ---- */
  section.blk{padding:130px 0;position:relative;z-index:2}
  .shead{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:start;
    margin-bottom:80px}
  .shead .idx{font-family:"Archivo Black",sans-serif;font-size:15px;color:var(--ember);
    padding-top:8px}
  .shead h2{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:clamp(36px,4.8vw,66px);line-height:.98;letter-spacing:-.045em}
  .shead h2 i{color:var(--ember)}
  .shead .sub{margin-top:22px;color:var(--bone);max-width:34em;font-size:16px}
  @media(max-width:760px){.shead{grid-template-columns:1fr;gap:18px}}

  /* services — blueprint cards */
  .svc .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    border:1px solid var(--line)}
  .svc a{position:relative;display:flex;flex-direction:column;
    padding:42px 36px;min-height:300px;text-decoration:none;color:var(--paper);
    border-right:1px solid var(--line);border-bottom:1px solid var(--line);
    background:linear-gradient(160deg,rgba(20,17,13,.5),transparent);
    transition:background .4s,transform .4s;overflow:hidden}
  .svc .cards a:nth-child(3n){border-right:0}
  .svc a::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;
    background:var(--ember);transition:width .45s ease}
  .svc a:hover{background:var(--ink2);transform:translateY(-3px)}
  .svc a:hover::before{width:100%}
  .svc .no{font-family:"Archivo Narrow",sans-serif;font-size:12px;
    color:var(--brass);letter-spacing:.24em;text-transform:uppercase;
    margin-bottom:auto}
  .svc h3{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:clamp(22px,2.4vw,28px);line-height:1.05;
    letter-spacing:-.03em;margin:30px 0 12px;transition:color .35s}
  .svc a:hover h3{color:var(--ember)}
  .svc .desc{font-size:14px;color:var(--bone);font-family:"Archivo",sans-serif;
    line-height:1.65}
  .svc .arrow{margin-top:24px;font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:600;
    color:var(--bone);display:inline-flex;align-items:center;gap:10px;
    transition:color .35s,gap .35s}
  .svc .arrow::after{content:"→";font-size:15px}
  .svc a:hover .arrow{color:var(--ember);gap:16px}
  @media(max-width:920px){.svc .cards{grid-template-columns:repeat(2,1fr)}
    .svc .cards a:nth-child(3n){border-right:1px solid var(--line)}
    .svc .cards a:nth-child(2n){border-right:0}}
  @media(max-width:600px){.svc .cards{grid-template-columns:1fr}
    .svc .cards a{border-right:0!important;min-height:auto}}

  /* ---- interactive blueprint ---- */
  .scan{background:var(--paper);color:var(--ink);position:relative;z-index:2}
  .scan::before{content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(12,10,8,.05) 1px,transparent 1px),
      linear-gradient(90deg,rgba(12,10,8,.05) 1px,transparent 1px);
    background-size:46px 46px}
  .scan .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;
    align-items:center;padding:130px 40px}
  .scan .mono{color:var(--ember-deep)}
  .scan h2{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:clamp(34px,4.6vw,62px);line-height:.98;letter-spacing:-.045em;
    margin:24px 0 20px;color:var(--ink)}
  .scan h2 i{color:var(--ember)}
  .scan p{color:#5b5345;font-size:16px;max-width:32em;margin-bottom:26px}
  .legend{display:flex;flex-wrap:wrap;gap:10px}
  .legend span{font-family:"Archivo Narrow",sans-serif;font-size:12px;
    text-transform:uppercase;letter-spacing:.12em;color:#5b5345;
    border:1px solid rgba(12,10,8,.18);padding:8px 14px}
  .scan .stage{position:relative;border:1px solid rgba(12,10,8,.2);
    background:rgba(255,255,255,.4);padding:30px}
  .house2{width:100%;height:auto;display:block;
    font-family:"Archivo Narrow",sans-serif;overflow:visible;cursor:crosshair}
  .house2 .paper{fill:rgba(255,255,255,.5);stroke:rgba(12,10,8,.14)}
  .house2 .struct{stroke:var(--ink);fill:none;stroke-width:1.6;
    stroke-linejoin:round;vector-effect:non-scaling-stroke}
  .house2 .hatch{stroke:rgba(12,10,8,.16);stroke-width:.8}
  /* zones */
  .house2 .zone-grp{cursor:pointer;outline:none}
  .house2 .zone{fill:rgba(232,70,42,0);stroke:rgba(232,70,42,0);
    stroke-width:1.5;transition:fill .35s,stroke .35s}
  .house2 .zone-grp:hover .zone{fill:rgba(232,70,42,.10);
    stroke:rgba(232,70,42,.4)}
  .house2 .zone-grp.active .zone{fill:rgba(232,70,42,.18);
    stroke:var(--ember);stroke-width:2}
  .house2 .zone-grp:focus-visible .zone{stroke:var(--ember-deep);
    stroke-dasharray:5 4}
  .house2 .znum{fill:var(--ink);stroke:none;font-size:10px;font-weight:700;
    letter-spacing:.1em;opacity:.35;transition:opacity .35s,fill .35s}
  .house2 .zone-grp:hover .znum,.house2 .zone-grp.active .znum{
    opacity:1;fill:var(--ember-deep)}
  /* defect markers */
  .house2 .defect{opacity:0;transition:opacity .4s}
  .house2 .zone-grp.active .defect{opacity:1}
  .house2 .defect circle{fill:none;stroke:var(--ember);stroke-width:1.4}
  .house2 .defect .core{fill:var(--ember);stroke:none}
  .house2 .defect .ring{transform-origin:center;transform-box:fill-box;
    animation:ping 2s ease-out infinite}
  @keyframes ping{0%{transform:scale(.4);opacity:.9}
    70%,100%{transform:scale(2.4);opacity:0}}
  /* callout leader line + chip */
  .house2 .leader{stroke:var(--ember-deep);stroke-width:1;
    stroke-dasharray:3 3;opacity:0;transition:opacity .4s}
  .house2 .zone-grp.active .leader{opacity:1}
  /* live scan line */
  .house2 .scanline{stroke:var(--ember);stroke-width:1.4;opacity:.0;
    filter:drop-shadow(0 0 6px rgba(232,70,42,.7));
    animation:scanY 5s linear infinite}
  @keyframes scanY{0%{transform:translateY(0);opacity:0}
    6%{opacity:.85}94%{opacity:.85}
    100%{transform:translateY(286px);opacity:0}}
  /* readout panel — driven by JS */
  .scan .readout{margin-top:22px;border-top:1px solid rgba(12,10,8,.16);
    padding-top:20px;display:grid;grid-template-columns:auto 1fr;gap:22px;
    align-items:start}
  .scan .readout .rcode{font-family:"Archivo Black",sans-serif;font-size:30px;
    color:var(--ember);line-height:1;letter-spacing:-.03em}
  .scan .readout .rtitle{font-family:"Archivo Black",sans-serif;font-size:17px;
    color:var(--ink);letter-spacing:-.02em;margin-bottom:5px}
  .scan .readout .rdesc{font-family:"Archivo",sans-serif;font-size:14px;
    color:#5b5345;line-height:1.6;max-width:40em;text-transform:none;
    letter-spacing:0}
  .scan .readout .rmeta{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
  .scan .readout .rmeta b{font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;
    font-weight:700;color:var(--ember-deep);
    border:1px solid rgba(178,45,24,.35);padding:5px 10px}
  .scan .readout .rprog{grid-column:1/-1;height:3px;
    background:rgba(12,10,8,.1);margin-top:6px;overflow:hidden}
  .scan .readout .rprog i{display:block;height:100%;width:0;
    background:var(--ember);transition:width .6s cubic-bezier(.7,0,.3,1)}
  @media(max-width:920px){.scan .wrap{grid-template-columns:1fr;gap:46px;
    padding:90px 22px}}

  /* ---- coverage / cities ---- */
  .cov .grid{display:grid;grid-template-columns:repeat(4,1fr);
    border:1px solid var(--line)}
  .cov .cell{padding:30px 26px;border-right:1px solid var(--line);
    border-bottom:1px solid var(--line);transition:background .3s;cursor:default}
  .cov .cell:hover{background:var(--ink2)}
  .cov .cell .mono{font-size:10px;color:var(--brass);display:block;margin-bottom:10px}
  .cov .cell b{font-family:"Archivo Black",sans-serif;font-weight:900;font-size:22px;
    display:block;letter-spacing:-.03em}
  .cov .cell span{font-size:12.5px;color:var(--bone)}
  @media(max-width:920px){.cov .grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.cov .grid{grid-template-columns:1fr}}

  /* ---- closing CTA ---- */
  .close{position:relative;z-index:2;text-align:center;padding:150px 0;
    border-top:1px solid var(--line)}
  .close::before{content:"";position:absolute;left:50%;top:0;
    transform:translateX(-50%);width:1px;height:80px;
    background:linear-gradient(var(--ember),transparent)}
  .close .mono{display:block;margin-bottom:30px}
  .close h2{font-family:"Archivo Black",sans-serif;font-weight:900;
    font-size:clamp(42px,7.4vw,108px);line-height:.9;letter-spacing:-.05em;
    margin-bottom:18px}
  .close h2 i{font-weight:900;color:var(--ember)}
  .close p{color:var(--bone);font-size:17px;margin-bottom:46px}
  .close .primary{font-size:15px;padding:22px 40px}
  .quotebox{max-width:880px;margin:54px auto 0;border:1px solid var(--line-strong);
    padding:14px;background:rgba(20,17,13,.6);position:relative}
  .quotebox .corner{position:absolute;width:14px;height:14px;border:1px solid var(--brass)}
  .quotebox .corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
  .quotebox .corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
  .quotebox .corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
  .quotebox .corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0}
  .quotebox iframe{display:block;width:100%;min-height:900px;height:900px;
    border:none;border-radius:6px;background:#f4efe6}
  /* Quote widget must NEVER be hidden by the reveal animation */
  .quotebox.reveal,.js .quotebox.reveal,.js .quotebox.reveal:not(.in){
    opacity:1!important;transform:none!important}
  .quotecap{font-family:"Archivo Narrow",sans-serif;text-transform:uppercase;
    letter-spacing:.2em;font-size:10.5px;color:var(--bone);
    display:flex;justify-content:space-between;padding:0 6px 12px}

  footer{border-top:1px solid var(--line);position:relative;z-index:2;
    padding:60px 0}
  footer .wrap{display:flex;justify-content:space-between;align-items:center;
    flex-wrap:wrap;gap:24px}
  footer .mono{color:var(--bone);font-size:10px}
  footer .fbrand{font-family:"Archivo Black",sans-serif;font-size:18px}

  .flag{background:rgba(232,70,42,.1);border-bottom:1px solid rgba(232,70,42,.3);
    color:var(--bone);font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.18em;font-size:11px;text-align:center;
    padding:11px;position:relative;z-index:5}
  .flag b{color:var(--ember)}

  /* ============================================================
     MOBILE + TABLET HARDENING — 100% responsive, all page types
     Additive: only narrows; never alters desktop ≥921px.
     ============================================================ */
  *,*::before,*::after{min-width:0}
  img,svg,iframe,video{max-width:100%;height:auto}
  .quotebox iframe{max-width:100%}
  html,body{overflow-x:hidden;max-width:100vw}

  @media(max-width:1024px){
    .wrap{padding-left:28px;padding-right:28px}
    .shead{grid-template-columns:1fr;gap:16px}
    section.blk{padding:84px 0}
  }

  @media(max-width:820px){
    .hero .wrap{grid-template-columns:1fr;gap:32px}
    .hpanel{aspect-ratio:16/11;margin-bottom:24px}
    .hcoord{display:none}
    h1{font-size:clamp(44px,12vw,84px);line-height:.94}
    .marq .item{font-size:15px;gap:34px}
    .cards{grid-template-columns:1fr 1fr!important}
    .grid{grid-template-columns:1fr 1fr!important}
    .rev .grid,.proc .steps{grid-template-columns:1fr!important}
  }

  @media(max-width:600px){
    .wrap{padding-left:18px;padding-right:18px}
    .meta .wrap{flex-direction:column;height:auto;gap:4px;padding:8px 18px}
    .meta .mono{font-size:9px;letter-spacing:.12em}
    nav .wrap{height:66px}
    .brand .name{font-size:16px}
    .brand .name small{font-size:9px;letter-spacing:.18em}
    h1{font-size:clamp(38px,13vw,60px);letter-spacing:-.03em}
    .lead,.scan p{font-size:16px}
    section.blk,.rev,.scan .wrap{padding-top:60px;padding-bottom:60px}
    .shead h2,.scan h2,.close h2{font-size:clamp(28px,9vw,40px)}
    .cards{grid-template-columns:1fr!important}
    .grid{grid-template-columns:1fr!important}
    .svc a,.cov .cell{padding:26px 20px}
    .primary,.book{width:100%;justify-content:center;text-align:center}
    .actions{flex-direction:column;align-items:stretch;gap:12px}
    .actions .secondary{text-align:center}
    .quotebox iframe{height:1100px;min-height:1100px}
    .close{padding:80px 0 110px}
    /* keep tap targets ≥44px */
    nav a,.navlinks a,.mobnav a,.svc a,.cov .cell a,footer a{
      min-height:44px;display:flex;align-items:center}
    .burger{width:46px;height:46px}
    /* sticky call bar never overlaps content */
    body{padding-bottom:0}
    .stickybar a{padding:16px;font-size:12px}
  }

  @media(max-width:380px){
    h1{font-size:clamp(32px,14vw,46px)}
    .wrap{padding-left:14px;padding-right:14px}
    .marq .item{font-size:13px}
  }

  /* Tablet portrait: 2-up grids, comfortable spacing */
  @media(min-width:601px) and (max-width:1024px){
    .cards{grid-template-columns:1fr 1fr!important}
    .cov .grid{grid-template-columns:1fr 1fr!important}
    .navlinks{display:none}
    .burger{display:block}
  }

  /* ---- field-record gallery ---- */
  .gallery .ggrid{display:grid;grid-template-columns:repeat(3,1fr);
    gap:14px;margin-top:56px}
  .gallery .gcell{position:relative;overflow:hidden;
    border:1px solid var(--line);aspect-ratio:3/2;margin:0}
  .gallery .gcell img{width:100%;height:100%;object-fit:cover;
    filter:saturate(1.12) contrast(1.04);
    transform:scale(1.02);transition:transform .8s ease,filter .4s}
  .gallery .gcell:hover img{transform:scale(1.09)}
  .gallery .gcell figcaption{position:absolute;left:0;right:0;bottom:0;
    padding:30px 18px 14px;
    background:linear-gradient(transparent,rgba(12,10,8,.86));
    font-family:"Archivo Narrow",sans-serif;text-transform:uppercase;
    letter-spacing:.16em;font-size:11px;font-weight:700;color:var(--paper)}
  .gallery .gcell::after{content:"";position:absolute;left:0;top:0;
    width:0;height:3px;background:var(--ember);transition:width .5s ease}
  .gallery .gcell:hover::after{width:100%}
  @media(max-width:820px){.gallery .ggrid{grid-template-columns:1fr 1fr}}
  @media(max-width:600px){.gallery .ggrid{grid-template-columns:1fr;gap:10px}}

  /* ---- visible breadcrumb ---- */
  .crumb{position:relative;z-index:2;font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.16em;font-size:11px;
    padding:18px 0 0}
  .crumb .wrap{display:flex;gap:10px;flex-wrap:wrap;color:var(--bone)}
  .crumb a{color:var(--bone);text-decoration:none}
  .crumb a:hover{color:var(--ember)}
  .crumb span{color:var(--line-strong)}
  .crumb b{color:var(--paper);font-weight:700}

  /* ---- before/after defect slider ---- */
  .ba{position:relative;z-index:2;max-width:920px;margin:56px auto 0;
    border:1px solid var(--line-strong);user-select:none}
  .ba .ba-stage{position:relative;aspect-ratio:16/10;overflow:hidden}
  .ba .ba-stage img{position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover}
  .ba .ba-after{clip-path:inset(0 0 0 50%);will-change:clip-path}
  .ba .ba-tag{position:absolute;top:14px;font-family:"Archivo Narrow",sans-serif;
    text-transform:uppercase;letter-spacing:.16em;font-size:10px;font-weight:700;
    background:rgba(12,10,8,.7);color:var(--paper);padding:6px 10px}
  .ba .ba-tag.l{left:14px}.ba .ba-tag.r{right:14px}
  .ba input[type=range]{position:absolute;inset:auto 0 0 0;width:100%;
    margin:0;appearance:none;background:transparent;height:48px;cursor:ew-resize}
  .ba input[type=range]::-webkit-slider-thumb{appearance:none;width:4px;
    height:1000px;background:var(--ember);box-shadow:0 0 0 1px rgba(0,0,0,.3)}
  .ba input[type=range]::-moz-range-thumb{width:4px;height:1000px;border:0;
    background:var(--ember)}
  .ba .ba-handle{position:absolute;top:50%;left:50%;width:42px;height:42px;
    margin:-21px;border:2px solid var(--ember);border-radius:50%;
    background:rgba(12,10,8,.6);pointer-events:none;
    display:grid;place-items:center;color:var(--ember);font-size:14px}

  /* ---- smart FAQ search ---- */
  .faqx{position:relative;z-index:2}
  .faqx input{width:100%;max-width:520px;background:transparent;
    border:1px solid var(--line-strong);color:var(--paper);
    font-family:"Archivo",sans-serif;font-size:15px;padding:14px 18px;
    margin-bottom:30px}
  .faqx input::placeholder{color:var(--bone)}
  .faqx input:focus{outline:none;border-color:var(--ember)}
  .faqx .fitem{border-top:1px solid var(--line);padding:22px 0}
  .faqx .fitem[hidden]{display:none}
  .faqx .fq{font-family:"Archivo Black",sans-serif;font-size:18px;
    letter-spacing:-.02em;cursor:pointer;display:flex;justify-content:space-between;
    gap:16px;color:var(--paper)}
  .faqx .fq::after{content:"+";color:var(--ember);flex:none}
  .faqx .fitem.open .fq::after{content:"–"}
  .faqx .fa{color:var(--bone);font-size:15px;line-height:1.7;
    max-height:0;overflow:hidden;transition:max-height .35s ease,
    padding .35s ease}
  .faqx .fitem.open .fa{max-height:340px;padding-top:14px}
  .faqx .nomatch{color:var(--bone);font-style:italic;padding:22px 0}

  /* ---- hero trust stats ---- */
  .hstats{display:flex;gap:36px;margin-top:34px;flex-wrap:wrap}
  .hstats span{font-family:"Archivo Narrow",sans-serif;text-transform:uppercase;
    letter-spacing:.14em;font-size:11px;color:var(--bone);
    display:flex;flex-direction:column;gap:4px}
  .hstats b{font-family:"Archivo Black",sans-serif;font-size:30px;
    letter-spacing:-.03em;color:var(--paper);text-transform:none}
  @media(max-width:600px){.hstats{gap:24px}.hstats b{font-size:24px}}

  /* ---- high-end animated service glyphs ---- */
  .glyphbox{display:block;width:48px;height:48px;margin-bottom:auto}
  .glyphbox svg{width:100%;height:100%}
  .glyphbox svg [stroke],.glyphbox svg path,.glyphbox svg rect,
  .glyphbox svg circle,.glyphbox svg ellipse{
    stroke:var(--brass);stroke-width:1.6;fill:none;
    stroke-linecap:round;stroke-linejoin:round;
    vector-effect:non-scaling-stroke}
  .svc a .glyphbox svg *{stroke-dasharray:240;stroke-dashoffset:240;
    transition:stroke-dashoffset 1.1s cubic-bezier(.7,0,.3,1),stroke .4s}
  .svc a.in .glyphbox svg *,.reveal.in .glyphbox svg *{stroke-dashoffset:0}
  .svc a:hover .glyphbox svg *{stroke:var(--ember)}
  @media(prefers-reduced-motion:reduce){
    .glyphbox svg *{stroke-dashoffset:0!important}}

  /* ---- feature band: refined editorial split ---- */
  .fband{position:relative;z-index:2;padding:40px 0}
  .fbgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);
    align-items:center;max-width:1080px;margin:0 auto}
  .fbtext{max-width:30em}
  .fbtext .mono{margin-bottom:16px;display:block}
  .fbtext h2{font-family:"Archivo Black",sans-serif;
    font-size:clamp(26px,3vw,38px);line-height:1.05;
    letter-spacing:-.03em;margin-bottom:14px}
  .fbtext h2 i{color:var(--ember);font-style:normal}
  .fbtext p{color:var(--bone);font-size:15.5px;line-height:1.7;
    margin-bottom:26px}
  .fbtext .primary{display:inline-flex}
  /* Image: constrained, refined, never oversized */
  .fbimg{position:relative;margin:0;overflow:hidden;
    aspect-ratio:4/3;max-height:380px;width:100%;
    border-radius:4px;
    box-shadow:0 24px 60px -28px rgba(0,0,0,.7)}
  .fbimg::after{content:"";position:absolute;inset:0;
    border:1px solid rgba(203,191,169,.18);border-radius:4px;
    pointer-events:none}
  .fbimg img{width:100%;height:100%;object-fit:cover;display:block;
    filter:saturate(1.08) contrast(1.03);
    transform:scale(1.01);transition:transform 1.2s cubic-bezier(.16,1,.3,1)}
  .fbimg:hover img{transform:scale(1.05)}
  /* subtle accent corner — single, restrained (not 4 boxes) */
  .fbimg .corner{display:none}
  .fbimg::before{content:"";position:absolute;left:14px;bottom:14px;
    width:34px;height:34px;border-left:1px solid var(--ember);
    border-bottom:1px solid var(--ember);opacity:.65;z-index:2}
  @media(max-width:860px){
    .fbgrid{grid-template-columns:1fr;gap:28px;direction:ltr!important;
      max-width:520px}
    .fbtext{max-width:none}
    .fbimg{aspect-ratio:16/10;max-height:300px;order:-1}}
