:root{
  --ink:#0b0b0d;
  --ink-soft:#141417;
  --ink-2:#1c1c20;
  --bone:#f4f1ea;
  --bone-2:#ece7dc;
  --white:#ffffff;
  --orange:#ff5a18;
  --orange-deep:#e2470c;
  --orange-glow:rgba(255,90,24,.5);
  --steel:#8a8a92;
  --steel-d:#5a5a62;
  --line:rgba(255,255,255,.12);
  --line-d:rgba(11,11,13,.12);
  --maxw:1320px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Archivo',sans-serif;
  background:var(--ink);
  color:var(--bone);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.5;
}
::selection{background:var(--orange);color:#fff}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;line-height:.98;letter-spacing:-.02em}
.mono{font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;font-weight:500}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--orange);z-index:1000;box-shadow:0 0 14px var(--orange-glow)}

/* grain overlay */
.grain{position:fixed;inset:0;z-index:998;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* top utility bar */
.util{background:#000;border-bottom:1px solid var(--line);position:relative;z-index:100;transform-origin:top center;transition:transform .45s var(--ease),background .4s}
.util:hover{transform:scale(1.04);background:#0d0d10}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.util .mono{font-size:.66rem;color:var(--steel)}
.util a:hover{color:var(--orange)}
.util .r{display:flex;gap:18px;align-items:center}
.util .r.left{gap:14px}
.util .dot{color:var(--orange);margin:0 2px}
.util .hours{color:var(--steel)}
.status{display:inline-flex;align-items:center;gap:8px}
.status .sdot{width:8px;height:8px;border-radius:50%;background:#ff4d4d;box-shadow:0 0 0 0 rgba(255,77,77,.6);animation:pulseR 2s infinite}
.status #stxt{color:#ff7a7a;font-size:.66rem}
.status.open .sdot{background:#3ad07a;box-shadow:0 0 0 0 rgba(58,208,122,.6);animation:pulseG 2s infinite}
.status.open #stxt{color:#5fe39b}
@keyframes pulseG{0%{box-shadow:0 0 0 0 rgba(58,208,122,.55)}70%{box-shadow:0 0 0 6px rgba(58,208,122,0)}100%{box-shadow:0 0 0 0 rgba(58,208,122,0)}}
@keyframes pulseR{0%{box-shadow:0 0 0 0 rgba(255,77,77,.5)}70%{box-shadow:0 0 0 6px rgba(255,77,77,0)}100%{box-shadow:0 0 0 0 rgba(255,77,77,0)}}
.langs{display:flex;align-items:center;gap:9px}
.langs .lang{display:inline-flex;line-height:0;opacity:.45;filter:saturate(.6);transition:.3s var(--ease);border-radius:2px;overflow:hidden}
.langs .lang svg{display:block;border-radius:2px}
.langs .lang:hover{opacity:1;filter:none;transform:translateY(-1px)}
.langs .lang.act{opacity:1;filter:none;box-shadow:0 0 0 1.5px var(--orange)}

/* header */
header{position:sticky;top:0;z-index:90;background:rgba(11,11,13,.0);transition:.5s var(--ease);border-bottom:1px solid transparent}
header.scrolled{background:rgba(11,11,13,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
header .wrap{display:flex;align-items:center;justify-content:space-between;height:84px;transition:.4s var(--ease)}
header.scrolled .wrap{height:66px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.45rem;letter-spacing:-.02em}
.brand .mk{width:34px;height:34px;border:2px solid var(--orange);display:grid;place-items:center;position:relative;transition:.4s var(--ease)}
.brand .mk::before{content:"";position:absolute;inset:5px;background:var(--orange)}
.brand:hover .mk{transform:rotate(45deg)}
.brandlogo{height:42px;width:auto;display:block;transition:height .4s var(--ease)}
header.scrolled .brandlogo{height:34px}
header.scrolled .brand .mk{width:28px;height:28px}
.brand b{color:var(--orange)}
.brand span.sub{font-family:'JetBrains Mono';font-size:.55rem;letter-spacing:.3em;color:var(--steel);display:block;font-weight:500;margin-top:2px}
nav{display:flex;gap:34px;align-items:center}
nav a.lnk{font-size:.82rem;font-weight:600;letter-spacing:.01em;position:relative;padding:6px 0;color:var(--bone)}
nav a.lnk::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--orange);transition:.35s var(--ease)}
nav a.lnk:hover::after{width:100%}
nav a.lnk:hover{color:#fff}
.btn{font-family:'Archivo';font-weight:700;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;padding:14px 26px;background:var(--orange);color:#fff;border:none;cursor:pointer;position:relative;overflow:hidden;transition:.4s var(--ease);display:inline-flex;align-items:center;gap:10px}
.btn::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:.45s var(--ease);z-index:0}
.btn:hover::before{transform:translateY(0)}
.btn span,.btn svg{position:relative;z-index:1}
.btn:hover{color:#fff}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--bone)}
.btn.ghost::before{background:var(--orange)}
.btn.dark{background:var(--ink)}
.btn-arrow{transition:.4s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(5px)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--bone);transition:.3s}

/* side rail */
.rail{position:fixed;left:0;top:0;height:100vh;width:46px;z-index:70;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:120px 0 40px;pointer-events:none;mix-blend-mode:difference}
.rail .vert{writing-mode:vertical-rl;font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.4em;color:#fff;text-transform:uppercase}
.rail .socials{display:flex;flex-direction:column;gap:16px;pointer-events:auto}
.rail .socials a{font-family:'JetBrains Mono';font-size:.6rem;color:#fff;writing-mode:vertical-rl;letter-spacing:.2em}
.rail .socials a:hover{color:var(--orange)}
.rail .line{width:1px;height:60px;background:#fff;opacity:.4}

/* HERO */
.hero{position:relative;background:var(--ink);overflow:hidden;padding-top:70px}
.hero .blueprint{position:absolute;inset:0;opacity:.5;
  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(circle at 70% 40%,#000,transparent 80%)}
.hero .glow{position:absolute;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(255,90,24,.22),transparent 65%);top:-180px;right:-120px;filter:blur(20px)}
.hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1.15fr .95fr;gap:50px;align-items:center;min-height:calc(100vh - 122px);padding-top:60px;padding-bottom:80px}
.hk{display:flex;align-items:center;gap:14px;margin-bottom:30px;overflow:hidden}
.hk .mono{color:var(--orange)}
.hk .bar{width:48px;height:1px;background:var(--orange)}
.hero h1{font-size:clamp(2.8rem,6.6vw,6.2rem);color:#fff}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln i{display:block;font-style:normal;transform:translateY(110%)}
.hero h1 em{font-style:normal;color:var(--orange);position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;bottom:.08em;width:100%;height:.09em;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:1s var(--ease) 1.1s}
.loaded .hero h1 em::after{transform:scaleX(1)}
.hero .lead{font-size:1.12rem;color:var(--steel);max-width:30em;margin:32px 0 38px;line-height:1.55}
.hero .lead b{color:var(--bone);font-weight:600}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:46px}
.hchips{display:flex;gap:14px;flex-wrap:wrap}
.chip{border:1px solid var(--line);padding:14px 18px;display:flex;flex-direction:column;gap:3px;min-width:150px;background:rgba(255,255,255,.02)}
.chip .v{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.15rem;color:#fff}
.chip .v b{color:var(--orange)}
.chip .k{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.15em;color:var(--steel);text-transform:uppercase}

/* hero visual */
.hvis{position:relative}
.hvis .frame{position:relative;border:1px solid var(--line);background:linear-gradient(180deg,var(--ink-soft),#0d0d10);padding:14px;overflow:hidden}
.hvis .frame::before{content:"";position:absolute;top:0;left:0;width:60px;height:60px;border-top:2px solid var(--orange);border-left:2px solid var(--orange);z-index:4}
.hvis .frame::after{content:"";position:absolute;bottom:0;right:0;width:60px;height:60px;border-bottom:2px solid var(--orange);border-right:2px solid var(--orange);z-index:4}
.hvis .ph{position:relative;height:520px;background:#0d0d10 url('../img/hero-cantilever.webp') center/cover;filter:grayscale(.05) contrast(1.03)}
.hvis .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,13,.15),rgba(11,11,13,.6))}
.hvis .tag{position:absolute;top:30px;left:30px;z-index:5;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.2em;color:#fff;background:rgba(0,0,0,.5);border:1px solid var(--line);padding:8px 12px;backdrop-filter:blur(6px)}
.spec-card{position:absolute;bottom:34px;right:34px;z-index:6;background:rgba(11,11,13,.78);backdrop-filter:blur(12px);border:1px solid var(--line);padding:22px 24px;width:230px}
.spec-card .h{font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.2em;color:var(--orange);margin-bottom:10px}
.spec-card .price{font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;color:#fff;line-height:1}
.spec-card .price small{font-size:.8rem;color:var(--steel);font-family:'Archivo'}
.spec-card .row{display:flex;justify-content:space-between;font-size:.72rem;color:var(--steel);margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.spec-card .row b{color:var(--bone)}

/* marquee strip */
.strip{background:var(--orange);color:#fff;border-top:1px solid rgba(0,0,0,.2);overflow:hidden;position:relative;z-index:4}
.marquee{display:flex;gap:0;white-space:nowrap;animation:scrollx 30s linear infinite}
.marquee span{font-family:'Bricolage Grotesque';font-weight:700;font-size:1rem;padding:16px 0;display:inline-flex;align-items:center;letter-spacing:.02em}
.marquee span::after{content:"✦";margin:0 30px;font-size:.7rem;opacity:.6}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* section base */
section{position:relative}
.smark{display:flex;align-items:baseline;gap:18px;margin-bottom:48px}
.smark .num{font-family:'JetBrains Mono';font-size:.72rem;color:var(--orange);letter-spacing:.1em}
.smark .ttl{font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.25em;text-transform:uppercase}
.smark .fill{flex:1;height:1px;background:var(--line)}

/* reveal */
.rv{opacity:0;transform:translateY(40px);transition:1s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-2{transition-delay:.12s}.rv-3{transition-delay:.24s}.rv-4{transition-delay:.36s}

/* STATS */
.stats{background:var(--bone);color:var(--ink);padding:90px 0;border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:0 36px;border-left:1px solid var(--line-d)}
.stat:first-child{border-left:none;padding-left:0}
.stat .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.6rem,4.5vw,4rem);color:var(--ink);line-height:1}
.stat .n b{color:var(--orange-deep)}
.stat .l{font-size:.86rem;color:var(--steel-d);margin-top:12px;max-width:14em;line-height:1.4}

/* ABOUT/manifesto */
.about{padding:130px 0;background:#fff;color:var(--ink)}
.about .grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:70px;align-items:start}
.about .smark .num{color:var(--orange-deep)}
.about .smark .fill{background:var(--line-d)}
.about h2{font-size:clamp(2.2rem,4vw,3.4rem);color:var(--ink)}
.about h2 em{font-style:normal;color:var(--orange-deep)}
.about .body p{color:var(--steel-d);font-size:1.05rem;line-height:1.7;margin-bottom:22px;max-width:46em}
.about .body p b{color:var(--ink);font-weight:600}
.about .sig{margin-top:34px;font-family:'Bricolage Grotesque';font-weight:700;font-size:1.1rem;color:var(--ink)}
.about .sig span{display:block;font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.2em;color:var(--orange-deep);margin-top:6px;text-transform:uppercase}

/* PRODUCTS — editorial asymmetric grid */
.products{padding:130px 0;background:var(--bone);color:var(--ink)}
.products .smark .ttl,.products .smark .num{color:var(--ink)}
.products .smark .num{color:var(--orange-deep)}
.products .smark .fill{background:var(--line-d)}
.phead{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:54px;flex-wrap:wrap}
.phead h2{font-size:clamp(2.4rem,4.6vw,4rem);color:var(--ink);max-width:11em}
.phead h2 em{font-style:normal;color:var(--orange-deep)}
.phead p{color:var(--steel-d);max-width:26em;font-size:1rem}
.pgrid{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:auto auto;gap:24px}
.card{position:relative;background:var(--white);border:1px solid var(--line-d);overflow:hidden;transition:.5s var(--ease);cursor:pointer;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(11,11,13,.4)}
.card .ref{position:absolute;top:18px;left:18px;z-index:3;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.15em;color:var(--steel-d)}
.card .badge{position:absolute;top:16px;right:16px;z-index:3;background:var(--orange);color:#fff;font-family:'JetBrains Mono';font-size:.56rem;letter-spacing:.12em;padding:6px 10px;text-transform:uppercase}
.card .imgwrap{position:relative;overflow:hidden;background:linear-gradient(135deg,#f7f4ee,#e9e4d8);flex:1;display:grid;place-items:center}
.card .imgwrap img{transition:.7s var(--ease);width:100%;height:100%;object-fit:contain;padding:24px;mix-blend-mode:multiply}
.card:hover .imgwrap img{transform:scale(1.06)}
.card .body{padding:28px 30px 30px}
.card h3{font-size:1.7rem;color:var(--ink);margin-bottom:8px}
.card p{color:var(--steel-d);font-size:.92rem;line-height:1.5;margin-bottom:18px}
.card .meta{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--line-d);padding-top:16px}
.card .price{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.4rem;color:var(--ink)}
.card .price small{font-size:.7rem;color:var(--steel-d);font-weight:400;font-family:'Archivo'}
.card .price .from{font-family:'JetBrains Mono';font-size:.55rem;letter-spacing:.1em;color:var(--orange-deep);display:block;text-transform:uppercase}
.card .go{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:.1em;color:var(--ink);text-transform:uppercase;font-weight:500}
.card .go svg{transition:.4s var(--ease)}
.card:hover .go svg{transform:translateX(5px);color:var(--orange-deep)}
/* feature card spans tall left */
.card.feat{grid-row:span 2}
.card.feat .imgwrap{min-height:340px}
.card.feat h3{font-size:2.4rem}
.card.feat .body{padding:34px 38px 38px}
.card.feat p{font-size:1rem;max-width:32em}
.feat-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.feat-pills span{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.08em;border:1px solid var(--line-d);padding:6px 11px;color:var(--steel-d);text-transform:uppercase}

/* CONFIGURATOR */
.config{padding:130px 0;background:var(--ink);position:relative;overflow:hidden}
.config .blueprint{position:absolute;inset:0;opacity:.4;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(circle at 20% 30%,#000,transparent 75%)}
.config .wrap{position:relative;z-index:2}
.chead{max-width:40em;margin-bottom:54px}
.chead h2{font-size:clamp(2.3rem,4.4vw,3.8rem);color:#fff;margin-top:18px}
.chead h2 em{font-style:normal;color:var(--orange)}
.chead p{color:var(--steel);margin-top:18px;font-size:1.05rem;line-height:1.6}
.cfg{display:grid;grid-template-columns:1.15fr .85fr;gap:0;border:1px solid var(--line);background:rgba(255,255,255,.02)}
.cfg .controls{padding:46px 48px}
.cfg .field{margin-bottom:34px}
.cfg .field:last-child{margin-bottom:0}
.cfg .flabel{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cfg .flabel .mono{color:var(--bone)}
.cfg .flabel .hint{font-family:'JetBrains Mono';font-size:.6rem;color:var(--steel);letter-spacing:.1em}
.opts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt{border:1px solid var(--line);padding:18px 18px;cursor:pointer;transition:.35s var(--ease);position:relative;background:rgba(255,255,255,.01)}
.opt:hover{border-color:var(--steel)}
.opt.act{border-color:var(--orange);background:rgba(255,90,24,.08)}
.opt .name{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.05rem;color:#fff}
.opt .dim{font-size:.74rem;color:var(--steel);margin-top:5px;font-family:'JetBrains Mono';letter-spacing:.04em}
.opt .pr{font-family:'JetBrains Mono';font-size:.7rem;color:var(--orange);margin-top:10px}
.opt .fdesc{font-size:.8rem;color:var(--steel);margin-top:7px;line-height:1.5;font-family:'Archivo'}
.opt .check{position:absolute;top:14px;right:14px;width:16px;height:16px;border:1px solid var(--steel);border-radius:50%;transition:.3s}
.opt.act .check{border-color:var(--orange);background:var(--orange);box-shadow:0 0 0 4px rgba(255,90,24,.18)}
/* stepper */
.steps{display:flex;gap:10px;flex-wrap:wrap}
.step{flex:1;min-width:54px;border:1px solid var(--line);padding:14px 0;text-align:center;cursor:pointer;transition:.3s var(--ease);font-family:'Bricolage Grotesque';font-weight:700;font-size:1.1rem;color:var(--steel)}
.step:hover{border-color:var(--steel);color:#fff}
.step.act{border-color:var(--orange);color:#fff;background:rgba(255,90,24,.08)}
.qty{display:flex;align-items:center;gap:0;border:1px solid var(--line);width:fit-content}
.qty button{width:54px;height:54px;background:transparent;border:none;color:var(--bone);font-size:1.4rem;cursor:pointer;font-family:'Bricolage Grotesque';transition:.3s}
.qty button:hover{background:var(--orange);color:#fff}
.qty .val{width:70px;text-align:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.5rem;color:#fff;border-left:1px solid var(--line);border-right:1px solid var(--line);line-height:54px}
/* summary panel */
.cfg .summary{background:var(--ink-soft);border-left:1px solid var(--line);padding:46px 44px;display:flex;flex-direction:column}
.summary .stitle{font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.2em;color:var(--orange);text-transform:uppercase;margin-bottom:24px}
.summary .line{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:.86rem}
.summary .line span:first-child{color:var(--steel)}
.summary .line span:last-child{color:var(--bone);font-weight:600;text-align:right}
.summary .total{margin-top:26px;padding-top:22px;border-top:2px solid var(--orange)}
.summary .total .mono{color:var(--steel);font-size:.6rem}
.summary .total .amt{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.4rem,4vw,3.2rem);color:#fff;line-height:1;margin:8px 0;transition:.3s}
.summary .total .amt b{color:var(--orange)}
.summary .total .ht{font-size:.8rem;color:var(--steel)}
.summary .note{font-size:.68rem;color:var(--steel-d);margin-top:16px;line-height:1.5;font-style:italic}
/* configurator additions */
.addrow{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line);flex-wrap:wrap}
.draftprice{display:flex;flex-direction:column;gap:3px}
.draftprice .mono{color:var(--steel);font-size:.6rem}
.draftprice b{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.35rem;color:#fff}
.addbtn{background:transparent;border:1px solid var(--orange);color:var(--orange)}
.addbtn::before{background:var(--orange)}
.addbtn:hover{color:#fff}
.qitems{display:flex;flex-direction:column;margin-bottom:8px}
.qline{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);animation:qin .4s var(--ease)}
@keyframes qin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.qinfo .qn{font-family:'Bricolage Grotesque';font-weight:700;font-size:.98rem;color:#fff}
.qinfo .qm{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.04em;color:var(--steel);margin-top:3px}
.qside{display:flex;align-items:center;gap:12px}
.qside .qp{font-family:'Bricolage Grotesque';font-weight:700;font-size:.95rem;color:var(--bone)}
.qx{width:24px;height:24px;border:1px solid var(--line);background:transparent;color:var(--steel);cursor:pointer;font-size:.7rem;transition:.3s;display:grid;place-items:center;flex-shrink:0}
.qx:hover{border-color:#ff5a5a;color:#ff5a5a}
.qempty{padding:18px 0;color:var(--steel-d);font-size:.86rem;border-bottom:1px solid var(--line)}
.tierhint{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.06em;color:var(--orange);margin-top:14px;text-transform:uppercase}
.summary .btn{margin-top:22px;width:100%;justify-content:center}

/* SECTORS */
.sectors{padding:120px 0;background:var(--bone);color:var(--ink);border-top:1px solid var(--line-d)}
.sectors .smark .num{color:var(--orange-deep)}
.sectors .smark .fill{background:var(--line-d)}
.sectors h2{font-size:clamp(2rem,3.6vw,3rem);color:var(--ink);max-width:14em;margin-bottom:46px}
.sectors h2 em{font-style:normal;color:var(--orange-deep)}
.secgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d)}
.sec{background:#fff;padding:38px 34px;transition:.4s var(--ease);position:relative;overflow:hidden}
.sec::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:.4s var(--ease)}
.sec:hover{background:var(--bone)}
.sec:hover::before{transform:scaleY(1)}
.sec .ic{color:var(--orange-deep);margin-bottom:22px}
.sec h3{font-size:1.3rem;color:var(--ink);margin-bottom:10px}
.sec p{color:var(--steel-d);font-size:.88rem;line-height:1.5}

/* ENGAGEMENTS */
.engage{padding:110px 0;background:#fff;color:var(--ink)}
.engage .smark .num{color:var(--orange-deep)}
.engage .smark .fill{background:var(--line-d)}
.eggrid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.eg{border-top:2px solid var(--orange);padding-top:24px}
.eg .ic{color:var(--orange-deep);margin-bottom:18px}
.eg h3{font-size:1.15rem;color:var(--ink);margin-bottom:10px;font-family:'Bricolage Grotesque'}
.eg p{color:var(--steel-d);font-size:.86rem;line-height:1.55}

/* CLIENTS marquee */
.clients{padding:80px 0;background:var(--bone);overflow:hidden}
.clients .lbl{text-align:center;font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.3em;color:var(--steel-d);text-transform:uppercase;margin-bottom:40px}
.logos{display:flex;gap:30px;align-items:center;animation:scrollx 28s linear infinite;width:max-content}
.logos .chip{background:#fff;border:1px solid var(--line-d);height:96px;width:190px;display:grid;place-items:center;padding:22px;flex-shrink:0;border-radius:2px}
.logos img{max-height:100%;max-width:100%;object-fit:contain;filter:none;opacity:1;transition:.4s}
.logos .chip{transition:.4s var(--ease)}
.logos .chip:hover{transform:translateY(-3px);box-shadow:0 16px 30px -18px rgba(11,11,13,.4)}
.logos .chip:hover img{filter:none;opacity:1}

/* CTA */
.cta{padding:130px 0;background:var(--orange);color:#fff;position:relative;overflow:hidden}
.cta .bg{position:absolute;inset:0;opacity:.12;background-image:linear-gradient(#000 1px,transparent 1px),linear-gradient(90deg,#000 1px,transparent 1px);background-size:50px 50px}
.cta .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr .7fr;gap:60px;align-items:center}
.cta h2{font-size:clamp(2.1rem,4.2vw,3.7rem);color:#fff;line-height:1}
.cta p{margin-top:22px;font-size:1.1rem;max-width:24em;color:rgba(255,255,255,.92)}
.cta .info{display:flex;flex-direction:column;gap:22px}
.cta .info a{display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.3);padding-top:16px;transition:.3s}
.cta .info a:hover{padding-left:8px}
.cta .info .k{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;opacity:.8}
.cta .info .v{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.5rem;margin-top:4px}
.cta .btn{background:#fff;color:var(--ink);margin-top:36px}
.cta .btn::before{background:var(--ink)}
.cta .btn:hover{color:#fff}

/* GROUPE / CZN */
.group{padding:130px 0;background:var(--bone);color:var(--ink);overflow:hidden}
.group .smark .num{color:var(--orange-deep)}
.group .smark .fill{background:var(--line-d)}
.ggrid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center}
.gtag{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--orange-deep);margin-bottom:20px}
.gtag::before{content:"";width:26px;height:1px;background:var(--orange-deep)}
.group h2{font-size:clamp(2.6rem,5vw,4.4rem);color:var(--ink);line-height:.95}
.group h2 em{font-style:normal;color:var(--orange-deep)}
.gsub{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.25rem;color:var(--ink);margin:14px 0 18px}
.gdesc{color:var(--steel-d);font-size:1rem;line-height:1.65;max-width:36em;margin-bottom:28px}
.gstats{display:flex;margin-bottom:32px;flex-wrap:wrap;gap:16px 0}
.gstats .gs{padding-right:28px;margin-right:28px;border-right:1px solid var(--line-d)}
.gstats .gs:last-child{border:none;margin:0;padding:0}
.gstats .gv{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.45rem;color:var(--ink);line-height:1}
.gstats .gv b{color:var(--orange-deep)}
.gstats .gk{font-family:'JetBrains Mono';font-size:.56rem;letter-spacing:.1em;color:var(--steel-d);text-transform:uppercase;margin-top:6px}
.gext{width:15px;height:15px}
.gvis{position:relative}
.gvis .frame{position:relative;border:1px solid var(--line-d);background:#fff;padding:14px;overflow:hidden;max-width:440px;margin:0 auto}
.gvis .frame::before{content:"";position:absolute;top:0;left:0;width:54px;height:54px;border-top:2px solid var(--orange);border-left:2px solid var(--orange);z-index:4}
.gvis .frame::after{content:"";position:absolute;bottom:0;right:0;width:54px;height:54px;border-bottom:2px solid var(--orange);border-right:2px solid var(--orange);z-index:4}
.gvis .gimg{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center;background:#f2efe8}
.gvis .gtagimg{position:absolute;top:30px;left:30px;z-index:5;font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.18em;color:#fff;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.2);padding:8px 12px;backdrop-filter:blur(6px)}
@media(max-width:1080px){.ggrid{grid-template-columns:1fr;gap:40px}.gvis .gimg{height:auto}}

/* FOOTER */
footer{background:#060607;padding:90px 0 0;border-top:1px solid var(--line)}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:50px;padding-bottom:70px}
.fcol h4{font-family:'JetBrains Mono';font-size:.64rem;letter-spacing:.2em;color:var(--orange);text-transform:uppercase;margin-bottom:24px}
.fcol a{display:block;color:var(--steel);font-size:.9rem;margin-bottom:13px;transition:.3s;width:fit-content}
.fcol a:hover{color:#fff;transform:translateX(4px)}
.fcol p{color:var(--steel);font-size:.9rem;line-height:1.6;margin-bottom:10px}
.fcol .brand{font-size:1.6rem;margin-bottom:18px}
.fcol .desc{color:var(--steel);font-size:.92rem;line-height:1.6;max-width:24em}
.fbar{border-top:1px solid var(--line);padding:26px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.fbar .mono{color:var(--steel-d);font-size:.64rem}
.fbar .legal{display:flex;gap:24px}
.fbar .legal a{color:var(--steel);font-size:.74rem}
.fbar .legal a:hover{color:var(--orange)}

/* responsive */
@media(max-width:1080px){
  .rail{display:none}
  .hero .wrap{grid-template-columns:1fr;gap:50px;min-height:auto;padding-top:50px}
  .hvis .ph{height:420px}
  .pgrid{grid-template-columns:1fr 1fr}
  .card.feat{grid-row:auto;grid-column:span 2}
  .cfg{grid-template-columns:1fr}
  .cfg .summary{border-left:none;border-top:1px solid var(--line)}
  .cta .wrap{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .wrap{padding:0 22px}
  nav{position:fixed;inset:0;top:0;background:rgba(8,8,10,.98);backdrop-filter:blur(16px);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:.5s var(--ease);z-index:200}
  nav.open{transform:none}
  nav a.lnk{font-size:1.4rem}
  .burger{display:flex;z-index:201}
  .util .r .hide{display:none}
  .stats .grid{grid-template-columns:1fr 1fr;gap:40px 0}
  .stat{padding:0 20px}.stat:nth-child(odd){border-left:none;padding-left:0}
  .about .grid{grid-template-columns:1fr;gap:36px}
  .pgrid{grid-template-columns:1fr}
  .card.feat{grid-column:auto}
  .phead{flex-direction:column;align-items:flex-start}
  .secgrid{grid-template-columns:1fr}
  .eggrid{grid-template-columns:1fr 1fr;gap:36px}
  .opts{grid-template-columns:1fr}
  .hero h1{font-size:13vw}
  .spec-card{position:static;width:auto;margin-top:14px}
  .hvis .frame{padding:10px}
}

/* ============================================================
   INNER PAGES — shared components
   ============================================================ */
.band{padding:110px 0}
.band-dark{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.band-light{background:var(--bone);color:var(--ink)}
.band-white{background:#fff;color:var(--ink)}
.band-light .smark .num,.band-white .smark .num{color:var(--orange-deep)}
.band-light .smark .fill,.band-white .smark .fill{background:var(--line-d)}
.band-dark .smark .ttl{color:var(--bone)}
.center{text-align:center}
.mw{max-width:860px;margin:0 auto}

/* page hero (inner) */
.phero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:120px 0 76px}
.phero .blueprint{position:absolute;inset:0;opacity:.5;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(circle at 75% 30%,#000,transparent 80%)}
.phero .glow{position:absolute;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(255,90,24,.2),transparent 65%);top:-200px;right:-140px;filter:blur(20px)}
.phero .wrap{position:relative;z-index:2}
.crumb{display:flex;gap:9px;align-items:center;font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel);margin-bottom:28px;flex-wrap:wrap}
.crumb a{color:var(--steel)}.crumb a:hover{color:var(--orange)}
.crumb .sep{color:var(--steel-d)}.crumb .cur{color:var(--orange)}
.pk{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.pk .bar{width:46px;height:1px;background:var(--orange)}
.pk .mono{color:var(--orange)}
.phero h1{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.4rem,5.6vw,4.6rem);line-height:.98;letter-spacing:-.02em;max-width:15em}
.phero h1 em{font-style:normal;color:var(--orange)}
.phero .sub{color:var(--steel);font-size:1.18rem;margin-top:24px;max-width:40em;line-height:1.55}
.phero .sub b{color:var(--bone);font-weight:600}
.phero .hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px}

/* prose / SEO content */
.prose{max-width:780px}
.prose.mw{margin:0 auto}
.prose p{color:var(--steel-d);font-size:1.06rem;line-height:1.78;margin-bottom:22px}
.prose p b,.prose p strong{color:var(--ink);font-weight:600}
.prose h2{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.7rem,3vw,2.5rem);color:var(--ink);margin:40px 0 18px;line-height:1.04;letter-spacing:-.02em}
.prose h2:first-child{margin-top:0}
.prose h2 em{font-style:normal;color:var(--orange-deep)}
.prose h3{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.3rem;color:var(--ink);margin:32px 0 12px}
.prose a{color:var(--orange-deep);text-decoration:underline;text-underline-offset:3px}
.prose ul{list-style:none;margin:0 0 26px;padding:0}
.prose ul li{position:relative;padding-left:32px;margin-bottom:13px;color:var(--steel-d);line-height:1.6}
.prose ul li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border:1.5px solid var(--orange-deep);border-radius:4px}
.prose ul li::after{content:"";position:absolute;left:6px;top:6px;width:5px;height:9px;border-right:2px solid var(--orange-deep);border-bottom:2px solid var(--orange-deep);transform:rotate(45deg)}
.prose ul li b{color:var(--ink);font-weight:600}

/* product intro split */
.pintro .grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.mediaframe{position:relative;border:1px solid var(--line-d);background:#fff;padding:14px;overflow:hidden}
.band-dark .mediaframe{border-color:var(--line);background:#0d0d10}
.mediaframe::before{content:"";position:absolute;top:0;left:0;width:54px;height:54px;border-top:2px solid var(--orange);border-left:2px solid var(--orange);z-index:4}
.mediaframe::after{content:"";position:absolute;bottom:0;right:0;width:54px;height:54px;border-bottom:2px solid var(--orange);border-right:2px solid var(--orange);z-index:4}
.mediaframe .mi{display:block;width:100%;height:440px;object-fit:contain;background:linear-gradient(135deg,#f7f4ee,#e9e4d8);padding:24px;mix-blend-mode:multiply}
.mediaframe.cover .mi{object-fit:cover;padding:0;mix-blend-mode:normal}
.mediaframe .mtag{position:absolute;top:28px;left:28px;z-index:5;font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.18em;color:var(--ink);background:rgba(255,255,255,.7);border:1px solid var(--line-d);padding:8px 12px;backdrop-filter:blur(6px)}
.band-dark .mediaframe .mtag{color:#fff;background:rgba(0,0,0,.5);border-color:var(--line)}
.priceblock .from{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-deep)}
.priceblock .pp{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.4rem,4vw,3.2rem);color:var(--ink);line-height:1;margin:6px 0 4px}
.priceblock .pp small{font-size:.9rem;color:var(--steel-d);font-weight:400;font-family:'Archivo'}
.kv{margin:24px 0}
.kv div{display:flex;justify-content:space-between;border-top:1px solid var(--line-d);padding:12px 0;font-size:.92rem;color:var(--steel-d)}
.kv div b{color:var(--ink);font-weight:600}

/* variant cards */
.variants{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.variant{background:#fff;border:1px solid var(--line-d);overflow:hidden;display:flex;flex-direction:column;transition:.45s var(--ease)}
.variant:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(11,11,13,.35)}
.variant .vimg{background:linear-gradient(135deg,#f7f4ee,#e9e4d8);height:300px;display:grid;place-items:center;padding:26px;position:relative}
.variant .vimg img{max-height:100%;max-width:100%;object-fit:contain;mix-blend-mode:multiply}
.variant .vtag{position:absolute;top:16px;left:16px;font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.12em;color:var(--steel-d)}
.variant .vb{padding:30px 32px 32px;display:flex;flex-direction:column;flex:1}
.variant .vn{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.55rem;color:var(--ink)}
.variant .vprice{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.8rem;color:var(--orange-deep);margin:8px 0 4px}
.variant .vprice small{font-size:.78rem;color:var(--steel-d);font-weight:400;font-family:'Archivo'}
.variant .vsub{font-size:.84rem;color:var(--steel-d);margin-bottom:14px}
.variant .vspecs{margin-top:auto}
.variant .vspecs div{display:flex;justify-content:space-between;border-top:1px solid var(--line-d);padding:10px 0;font-size:.85rem;color:var(--steel-d)}
.variant .vspecs b{color:var(--ink);font-weight:600}

/* spec strip */
.specstrip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.band-light .specstrip,.band-white .specstrip{background:var(--line-d);border-color:var(--line-d)}
.specstrip .sp{padding:30px 28px;background:var(--ink-soft)}
.band-light .specstrip .sp,.band-white .specstrip .sp{background:#fff}
.specstrip .sp .sv{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.7rem;color:#fff}
.band-light .specstrip .sp .sv,.band-white .specstrip .sp .sv{color:var(--ink)}
.specstrip .sp .sv b{color:var(--orange)}
.band-light .specstrip .sp .sv b,.band-white .specstrip .sp .sv b{color:var(--orange-deep)}
.specstrip .sp .sk{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel);margin-top:8px}
.band-light .specstrip .sp .sk,.band-white .specstrip .sp .sk{color:var(--steel-d)}

/* FAQ accordion */
.faq{max-width:840px;margin:0 auto}
.faq .qa{border-bottom:1px solid var(--line-d)}
.faq .qa:first-child{border-top:1px solid var(--line-d)}
.faq .q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:26px 46px 26px 0;position:relative;font-family:'Bricolage Grotesque';font-weight:700;font-size:1.14rem;color:var(--ink)}
.faq .q::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--orange-deep);transition:.3s var(--ease)}
.faq .qa.open .q::after{transform:translateY(-50%) rotate(45deg)}
.faq .a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq .a-inner{padding-bottom:26px}
.faq .a p{color:var(--steel-d);line-height:1.7;max-width:62em;margin-bottom:12px}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery .gi{aspect-ratio:1;background:#fff;border:1px solid var(--line-d);display:grid;place-items:center;padding:18px;overflow:hidden}
.gallery .gi img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply;transition:.5s var(--ease)}
.gallery .gi:hover img{transform:scale(1.08)}

/* cross-link / related */
.xgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.xcard{display:block;background:#fff;border:1px solid var(--line-d);padding:30px 30px 26px;transition:.4s var(--ease);position:relative}
.band-dark .xcard{background:var(--ink-soft);border-color:var(--line)}
.xcard:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(11,11,13,.4)}
.xcard .xr{font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.12em;color:var(--orange-deep);text-transform:uppercase}
.xcard h3{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.4rem;color:var(--ink);margin:14px 0 8px}
.band-dark .xcard h3{color:#fff}
.xcard p{color:var(--steel-d);font-size:.9rem;line-height:1.5;margin-bottom:18px}
.xcard .go{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);font-weight:500}
.band-dark .xcard .go{color:#fff}
.xcard:hover .go{color:var(--orange-deep)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:start}
.form .frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field-f{margin-bottom:18px}
.field-f label{display:block;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-d);margin-bottom:8px}
.field-f input,.field-f textarea,.field-f select{width:100%;background:#fff;border:1px solid var(--line-d);padding:14px 16px;font-family:'Archivo';font-size:.95rem;color:var(--ink);transition:.3s;border-radius:0}
.field-f textarea{min-height:140px;resize:vertical}
.field-f input:focus,.field-f textarea:focus,.field-f select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,24,.12)}
.cinfo{display:flex;flex-direction:column;gap:0}
.cinfo .ci{display:flex;gap:18px;padding:22px 0;border-top:1px solid var(--line-d)}
.cinfo .ci:last-child{border-bottom:1px solid var(--line-d)}
.cinfo .ci .ic{color:var(--orange-deep);flex-shrink:0}
.cinfo .ci .ck{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-d);margin-bottom:5px}
.cinfo .ci .cv{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.15rem;color:var(--ink)}
.cinfo .ci .cv a:hover{color:var(--orange-deep)}
.map-embed{width:100%;height:340px;border:1px solid var(--line-d);filter:grayscale(.3)}

@media(max-width:1080px){
  .pintro .grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:44px}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .variants{grid-template-columns:1fr}
  .specstrip{grid-template-columns:1fr}
  .xgrid{grid-template-columns:1fr}
  .form .frow{grid-template-columns:1fr}
  .band{padding:80px 0}
  .phero{padding:104px 0 60px}
}

.lnk.active{color:#fff}
.lnk.active::after{width:100%}

/* ---- pages internes : compléments (form .fld, cinfo .cblock, kv-dark, mapframe) ---- */
.kv.kv-dark div{border-top:1px solid rgba(244,241,234,.14);color:var(--steel)}
.kv.kv-dark div b{color:var(--bone)}
.form .fld{display:block;margin-bottom:18px}
.form .fld>span{display:block;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel-d);margin-bottom:8px}
.form .fld input,.form .fld textarea,.form .fld select{width:100%;background:#fff;border:1px solid var(--line-d);padding:14px 16px;font-family:'Archivo';font-size:.95rem;color:var(--ink);transition:.3s;border-radius:0;-webkit-appearance:none;appearance:none}
.form .fld textarea{min-height:150px;resize:vertical}
.form .fld input:focus,.form .fld textarea:focus,.form .fld select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,24,.12)}
.form .frow .fld{margin-bottom:0}
.form .btn{margin-top:22px}
.form .note{margin-top:14px;font-size:.82rem;color:var(--steel-d)}
.cinfo .cblock{padding:20px 0;border-top:1px solid var(--line-d)}
.cinfo .cblock:last-child{border-bottom:1px solid var(--line-d)}
.cinfo .cblock .k{display:block;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-d);margin-bottom:6px}
.cinfo .cblock .v{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.12rem;color:var(--ink);line-height:1.35;display:block}
.cinfo .cblock a.v:hover{color:var(--orange-deep)}
.mapframe{width:100%;border:1px solid var(--line-d);filter:grayscale(.25);line-height:0}
.mapframe iframe{display:block;width:100%}

/* ---- Hero des pages internes (.phero) : contenu centré (la Home utilise .hero, non concernée) ---- */
.phero .wrap{text-align:center}
.phero .crumb{justify-content:center}
.phero .pk{justify-content:center}
.phero h1{margin-left:auto;margin-right:auto}
.phero .sub{margin-left:auto;margin-right:auto}
.phero .hero-cta{justify-content:center}

/* ---- Bloc Livraison en France ---- */
.livraison .liv-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center;margin-top:10px}
.liv-map{position:relative;background:radial-gradient(60% 55% at 50% 45%,rgba(255,255,255,.07),transparent 72%)}
.liv-map img{display:block;width:100%;height:auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}
.liv-h2{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.9rem,3.4vw,2.9rem);letter-spacing:-.02em;line-height:1.05;color:#fff}
.liv-h2 em{font-style:normal;color:var(--orange)}
.liv-sub{font-size:1.05rem;line-height:1.65;margin:16px 0 30px;max-width:42em;color:var(--steel)}
.liv-sub b{color:var(--bone)}
.zones{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,auto);grid-auto-flow:column;gap:12px 26px;margin-bottom:16px}
.zrow{display:grid;grid-template-columns:128px 1fr;gap:18px;align-items:center;transition:transform .35s var(--ease)}
.zlabel{padding:12px 16px;font-family:'Bricolage Grotesque';font-weight:700;font-size:1rem;color:#fff;text-align:center;letter-spacing:.01em;transition:transform .35s var(--ease),box-shadow .35s var(--ease),filter .35s var(--ease)}
.zprice{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.2rem;color:#fff;transition:color .3s var(--ease)}
.zprice.muted{font-weight:600;font-size:1rem;color:var(--steel)}
.zrow:hover{transform:translateX(6px)}
.zrow:hover .zlabel{filter:brightness(1.12) saturate(1.05);box-shadow:0 10px 26px -10px rgba(0,0,0,.7);transform:scale(1.03)}
.zrow:hover .zprice{color:var(--orange)}
.zfoot{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:6px;padding:14px 18px;border:1.5px solid rgba(244,241,234,.22);transition:border-color .35s var(--ease),background .35s var(--ease)}
.zfoot:hover{border-color:var(--orange);background:rgba(255,90,24,.06)}
.zfoot .zfoot-l{font-family:'Bricolage Grotesque';font-weight:700;font-size:1rem;color:#fff}
.zfoot .zfoot-r{font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel);white-space:nowrap}
.zfoot:hover .zfoot-r{color:var(--orange)}
.livraison .btn{margin-top:28px}
@media(max-width:1080px){.livraison .liv-grid{grid-template-columns:1fr;gap:40px}.liv-map{max-width:560px;margin:0 auto}}
@media(max-width:760px){.zones{grid-template-columns:1fr;grid-template-rows:none;grid-auto-flow:row;gap:10px}.zrow{grid-template-columns:120px 1fr;gap:14px}.zlabel{font-size:.9rem;padding:10px 12px}.zprice{font-size:1.05rem}.zfoot{flex-direction:column;align-items:flex-start;gap:6px}}

/* ---- Photos réelles dans les cartes (home + variantes) ---- */
.card .imgwrap.photo{background:#0d0d10}
.card .imgwrap.photo img{object-fit:cover;padding:0;mix-blend-mode:normal;width:100%;height:100%}
.variant .vimg.photo{background:#0d0d10;padding:0}
.variant .vimg.photo img{width:100%;height:100%;max-width:none;max-height:none;object-fit:cover;mix-blend-mode:normal}

/* ---- Tarif dégressif ---- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.tier{background:#fff;border:1px solid var(--line-d);padding:34px 28px;text-align:center;transition:.4s var(--ease)}
.tier:hover{transform:translateY(-5px);box-shadow:0 26px 54px -30px rgba(11,11,13,.4)}
.tier .tq{font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel-d);margin-bottom:14px}
.tier .td{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.4rem,5vw,3.4rem);color:var(--ink);line-height:1;letter-spacing:-.02em}
.tier.featured{background:var(--ink);border-color:var(--ink)}
.tier.featured .tq{color:var(--orange)}
.tier.featured .td{color:#fff}
.tnotes{display:flex;gap:16px;flex-wrap:wrap;margin-top:22px}
.tnote{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line-d);padding:16px 22px;font-size:.95rem;color:var(--steel-d);flex:1;min-width:240px}
.tnote b{color:var(--ink)}
.tnote .tic{display:grid;place-items:center;width:30px;height:30px;flex-shrink:0;background:var(--orange);color:#fff;border-radius:50%;font-size:.85rem;font-weight:700}
@media(max-width:760px){.tiers{grid-template-columns:1fr}}

/* ---- Visuels agrandis (montage / cotes) ---- */
.cant-visuals{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:48px}
.cant-visuals .cv{margin:0}
.cant-visuals .cv img{display:block;width:100%;height:360px;object-fit:contain;background:#fff;border:1px solid var(--line-d);padding:20px}
.cant-visuals .cv figcaption{font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel-d);margin-top:12px;text-align:center}
@media(max-width:760px){.cant-visuals{grid-template-columns:1fr}.cant-visuals .cv img{height:300px}}

/* ---- Boutons à l'intérieur d'un bloc .prose : forcer texte blanc lisible ---- */
.prose a.btn,.prose a.btn:hover,.prose a.btn span{color:#fff;text-decoration:none}
.prose a.btn.ghost{color:var(--ink)}
.prose a.btn.ghost span{color:var(--ink)}

/* ---- Pages légales ---- */
.legaldoc{max-width:860px;margin:0 auto}
.legaldoc h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-top:46px}
.legaldoc h3{font-size:1.15rem;margin-top:26px}
.legaldoc p,.legaldoc li{font-size:1rem}
.legaldoc .upd{font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel-d);margin-bottom:30px}

/* ---- Signature agence (footer) ---- */
.fsign{border-top:1px solid var(--line);padding:24px 0 34px;display:flex;justify-content:center}
.madeby{display:inline-flex;align-items:center;gap:13px;opacity:.6;transition:opacity .35s var(--ease)}
.madeby:hover{opacity:1}
.madeby .mono{font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-d)}
.madeby img{height:30px;width:auto;display:block}
@media(max-width:560px){.madeby{flex-direction:column;gap:9px;text-align:center}}

/* ---- Message de confirmation formulaire ---- */
.form-success{text-align:center;padding:34px 14px;animation:fsIn .5s var(--ease)}
.form-success .fs-ic{width:64px;height:64px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;margin:0 auto 22px;box-shadow:0 16px 40px -14px rgba(255,90,24,.6)}
.form-success h3{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.55rem;color:var(--ink);margin-bottom:10px}
.form-success p{color:var(--steel-d);max-width:32em;margin:0 auto;line-height:1.6}
.form-success a{color:var(--orange-deep);font-weight:600}
@keyframes fsIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ---- Configurateur : champ ville de livraison ---- */
.cfg .cityfield{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);color:#fff;font-family:'Archivo';font-size:1rem;padding:15px 16px;transition:.3s var(--ease)}
.cfg .cityfield::placeholder{color:var(--steel-d)}
.cfg .cityfield:focus{outline:none;border-color:var(--orange);background:rgba(255,90,24,.06)}
.cfg .zoneout{margin-top:11px;min-height:1.1em;font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:.03em;color:var(--steel)}
.cfg .zoneout.ok{color:var(--bone)}
.cfg .zoneout b{color:var(--orange);font-weight:700}

/* ---- Bloc hero cantilever : photo portrait, pleine hauteur, sans bandes ---- */
.mediaframe.cover.fit{width:fit-content;max-width:100%;background:#fff;padding:0}
.mediaframe.cover.fit .mi{display:block;height:560px;width:auto;max-width:100%;object-fit:contain;mix-blend-mode:normal;padding:0}
@media(max-width:760px){.mediaframe.cover.fit{width:100%}.mediaframe.cover.fit .mi{height:auto;width:100%;max-height:520px}}

/* ---- Lightbox : zoom des photos de cotes ---- */
.cant-visuals .cv img{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,8,10,.92);display:flex;align-items:center;justify-content:center;padding:30px;opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;backdrop-filter:blur(4px)}
.lightbox.on{opacity:1;visibility:visible}
.lightbox img{max-width:94vw;max-height:90vh;object-fit:contain;background:#fff;box-shadow:0 30px 90px -20px rgba(0,0,0,.85);cursor:zoom-out}
.lb-close{position:absolute;top:22px;right:26px;width:46px;height:46px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.35);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;border-radius:50%;transition:.3s var(--ease)}
.lb-close:hover{background:var(--orange);border-color:var(--orange)}
.lb-hint{position:absolute;bottom:24px;left:0;right:0;text-align:center;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* ===================== RESPONSIVE MOBILE — HOME (≤760px) ===================== */
@media(max-width:760px){
  /* 1. Hero : tout le texte centré */
  .hero-text{text-align:center}
  .hero .hk{justify-content:center}
  .hero .lead{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  /* 2. Hero : les 3 encadrés sur une seule ligne */
  .hchips{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .hchips .chip{min-width:0;padding:10px 6px;gap:2px;text-align:center;align-items:center}
  .hchips .chip .v{font-size:.78rem;line-height:1.15}
  .hchips .chip .k{font-size:.5rem;letter-spacing:.05em}

  /* 3. Bandeau défilant "cibles" : un peu plus rapide */
  .marquee{animation-duration:18s}

  /* 4. Stats : texte centré */
  .stat{text-align:center;padding:0 10px}
  .stat .l{margin-left:auto;margin-right:auto}

  /* 5. Livraison : zones en 2 colonnes de 3 + bouton centré */
  .zones{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,auto);grid-auto-flow:column;gap:10px}
  .zrow{grid-template-columns:1fr;gap:5px;justify-items:center;text-align:center}
  .zlabel{width:100%;padding:9px 6px;font-size:.82rem}
  .zprice{font-size:1rem}
  .zfoot{flex-direction:column;align-items:center;text-align:center;gap:6px}
  .livraison .btn{display:flex;width:fit-content;margin-left:auto;margin-right:auto}

  /* 6. Clients : mosaïque empilée (3/ligne), sans défilement */
  .clients .logos{animation:none;width:auto;flex-wrap:wrap;justify-content:center;gap:10px}
  .clients .logos .chip{flex:0 0 30%;width:auto;height:72px;padding:12px}
  .clients .logos .chip:nth-child(n+11){display:none}

  /* 7. Groupe : photo de la mini-pelle remontée sous le titre/sous-titre */
  .ggrid{display:flex;flex-direction:column;gap:0}
  .gtext{display:contents}
  .ggrid .gtag{order:1}
  .ggrid h2{order:2}
  .ggrid .gsub{order:3}
  .ggrid .gvis{order:4;margin:4px 0 28px}
  .ggrid .gdesc{order:5}
  .ggrid .gstats{order:6}
  .ggrid .btn{order:7}
  .gvis .gimg{height:auto}

  /* 8. CTA "Parlons de votre projet" : texte + bouton centrés */
  .cta .wrap{text-align:center}
  .cta .wrap>div{display:flex;flex-direction:column;align-items:center}
  .cta .wrap>div .btn{margin-left:auto;margin-right:auto}
  .cta .info a{align-items:center;text-align:center}

  /* 9. Footer : éléments centrés */
  .fgrid{grid-template-columns:1fr;gap:34px;text-align:center}
  .fcol{display:flex;flex-direction:column;align-items:center}
  .fcol .brand{justify-content:center}
  .fbar{flex-direction:column;text-align:center;gap:12px}
  .fbar .legal{justify-content:center;flex-wrap:wrap;gap:12px 20px}
}

/* Top bar : icône tél + sélecteur de langue (cachés en desktop) */
.util .telico{display:none}
.langsel{display:none}

/* ===== Compléments responsive mobile (≤760px) ===== */
@media(max-width:760px){
  /* Top bar : tél en icône, langue en menu déroulant, statut sur une ligne */
  .util .dot{display:none}
  .util .telnum{display:none}
  .util .telico{display:inline-flex;vertical-align:middle}
  .util .tel{display:inline-flex;align-items:center}
  .util .langs{display:none}
  .langsel{display:inline-block;background:#0d0d10;color:var(--steel);border:1px solid var(--line);font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:.06em;padding:4px 7px;border-radius:3px;cursor:pointer}
  .util .r{gap:12px}
  .util .wrap{height:38px;flex-wrap:nowrap}
  .status #stxt{white-space:nowrap}

  /* Hero : header → kicker = kicker → titre (~30px) */
  .hero{padding-top:0}
  .hero .wrap{padding-top:30px;padding-bottom:50px}

  /* Bandeau défilant "cibles" : plus rapide (override garanti) */
  .strip .marquee{animation:scrollx 15s linear infinite}

  /* Espaces verticaux des blocs réduits (haut + bas) */
  .about,.products,.config,.sectors,.engage,.group{padding:62px 0}
  .cta{padding:64px 0}
  .stats{padding:54px 0}
  .clients{padding:54px 0}
  .band{padding:60px 0}
}

/* "Appeler" : libellé masqué en desktop (le numéro suffit) */
.tellabel{display:none}
@media(max-width:760px){
  .util .tel{display:inline-flex;align-items:center;gap:6px;background:var(--orange);color:#fff;padding:5px 11px;border-radius:4px}
  .util .tel:hover{color:#fff;background:var(--orange-deep)}
  .util .tel .telico{display:inline-flex}
  .tellabel{display:inline;font-family:'JetBrains Mono';font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
}

/* ===== Corrections mobile complémentaires (≤760px) ===== */
@media(max-width:760px){
  /* Menu burger lisible après scroll : le header scrollé ne doit pas créer de bloc englobant (backdrop-filter) qui confine le menu fixed */
  header.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(11,11,13,.97)}

  /* Bloc 1 (Le produit / Caractéristiques) : CTA centré */
  .pintro .btn{display:flex;width:fit-content;margin-left:auto;margin-right:auto}

  /* Cartes variantes : cadrage fiable (photo en cover, rendu produit en contain) */
  .variant .vimg{height:auto;overflow:hidden}
  .variant .vimg.photo{display:block;aspect-ratio:4 / 3;padding:0;background:#0d0d10}
  .variant .vimg.photo img{display:block;width:100%;height:100%;max-width:none;max-height:none;object-fit:cover;object-position:center;mix-blend-mode:normal}
  .variant .vimg:not(.photo){aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;padding:18px}
  .variant .vimg:not(.photo) img{width:auto;height:100%;max-width:100%;object-fit:contain;mix-blend-mode:multiply}

  /* En chiffres : 2 stats côte à côte, prix dessous, le tout centré */
  .specstrip{grid-template-columns:1fr 1fr}
  .specstrip .sp{text-align:center;padding:26px 14px}
  .specstrip .sp:last-child{grid-column:1 / -1}
}

/* Bloc groupe à-propos : texte à gauche, image carrée à droite */
.gsplit{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.mediaframe.cover.sq{padding:0;max-width:440px;margin:0 auto}
.mediaframe.cover.sq .mi{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;object-position:center;background:#0d0d10;mix-blend-mode:normal;padding:0}
@media(max-width:900px){.gsplit{grid-template-columns:1fr;gap:34px}}
