/* === Theillaud Roffi — Site complet — Style A === */

:root{
  --ink:#000000;
  --ivory:#ece7dc;
  --paper:#f5f2ec;
  --line:#000000;
  --muted:#3d4456;
  --acc:#c87a3d;          /* cuivre */
  --acc2:#e2a772;         /* cuivre clair */
  --grid-step:56px;
  --grid-alpha:.04;
  --anim-mult:1;
  --title-font:'Inter Tight','Manrope',sans-serif;
  --title-stretch:expanded;
}
[data-accent="navy"]{ --acc:#14264a; --acc2:#3a5894 }
[data-accent="gold"]{ --acc:#b78a3c; --acc2:#dcb872 }

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--ivory);color:var(--ink);font-family:'Inter Tight','Manrope',sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

::selection{background:var(--acc);color:var(--ink)}

.serif{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;letter-spacing:-.005em}
.mono{font-family:'JetBrains Mono',monospace}
.acc{color:var(--acc)}
.outl{-webkit-text-stroke:1.5px var(--ink);color:transparent}

/* Background grid (technical, subtle) */
.tech-grid{position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(0,0,0,var(--grid-alpha)) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,var(--grid-alpha)) 1px,transparent 1px);
  background-size:var(--grid-step) var(--grid-step);
  mask-image:linear-gradient(180deg,#000 0%,#000 92%,transparent 100%);
}

/* === Top nav === */
.topbar{position:sticky;top:0;left:0;right:0;background:rgba(236,231,220,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1.5px solid var(--ink);z-index:50}
.topbar-inner{display:flex;justify-content:space-between;align-items:stretch;padding:0 36px;height:70px;position:relative}
.topbar .lg{display:flex;align-items:center;gap:16px;font-weight:700;letter-spacing:.06em;font-size:14px}
.topbar .lg img{height:56px;width:auto}
.topbar .lg .sep{color:var(--acc);font-weight:400}
.topbar .lg .nm{font-weight:800;letter-spacing:.04em;font-size:14px}
.topbar .lg .sub{color:var(--muted);font-weight:500;letter-spacing:.08em;font-size:11.5px;text-transform:uppercase}
.topbar nav.links{display:flex;align-items:stretch;border-left:1px solid rgba(0,0,0,.18);border-right:1px solid rgba(0,0,0,.18);position:absolute;left:50%;transform:translateX(-50%);height:100%}
.topbar nav.links a{padding:0 22px;display:flex;align-items:center;border-right:1px solid rgba(0,0,0,.18);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:background .2s,color .2s;position:relative}
.topbar nav.links a:last-child{border-right:0}
.topbar nav.links a:hover{background:var(--ink);color:var(--ivory)}
.topbar nav.links a.active{color:var(--acc)}
.topbar nav.links a.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--acc)}
.topbar .clock{display:flex;align-items:center;gap:14px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.topbar .clock .dot{width:7px;height:7px;border-radius:50%;background:#3eb959;box-shadow:0 0 0 3px rgba(62,185,89,.18)}

/* === Meta strip below nav === */
.meta-strip{display:flex;justify-content:space-between;padding:11px 36px;border-bottom:1px solid var(--ink);font-family:'JetBrains Mono',monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;background:rgba(236,231,220,.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);position:relative;z-index:5}
.meta-strip b{font-weight:700;color:var(--acc)}

/* === Hero (style A) === */
.hero{position:relative;padding:96px 36px 60px;border-bottom:1.5px solid var(--ink);background:transparent;z-index:2}
.hero h1{font-family:var(--title-font);font-size:clamp(72px,13.5vw,212px);font-weight:800;line-height:.86;letter-spacing:-.05em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0}
.hero h1 .crc{display:inline-block;width:.36em;height:.36em;border-radius:50%;background:var(--acc);vertical-align:-.1em;margin:0 .04em}
.hero h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom}
.hero h1 .word > span{display:inline-block;transform:translateY(110%);transition:transform 1s cubic-bezier(.2,.7,.1,1)}
.hero.in h1 .word > span{transform:translateY(0)}
.hero h1 .word:nth-child(1) > span{transition-delay:.05s}
.hero h1 .word:nth-child(2) > span{transition-delay:.18s}
.hero h1 .word:nth-child(3) > span{transition-delay:.31s}
.hero h1 .word:nth-child(4) > span{transition-delay:.44s}

.hero-cols{margin-top:60px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:1px;background:var(--ink);border:1px solid var(--ink)}
.hero-col{background:var(--ivory);padding:22px 22px 26px;min-height:160px;display:flex;flex-direction:column;justify-content:space-between;gap:16px;opacity:0;transform:translateY(16px);transition:opacity .8s,transform .8s}
.hero.in .hero-col{opacity:1;transform:none}
.hero.in .hero-col:nth-child(1){transition-delay:.5s}
.hero.in .hero-col:nth-child(2){transition-delay:.6s}
.hero.in .hero-col:nth-child(3){transition-delay:.7s}
.hero.in .hero-col:nth-child(4){transition-delay:.8s}
.hero-col .n{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
.hero-col .t{font-size:18px;font-weight:700;letter-spacing:-.01em;line-height:1.2;margin-top:auto}
.hero-col.lead{background:var(--ink);color:var(--ivory)}
.hero-col.lead .n{color:var(--acc2)}
.hero-col.lead p{font-size:13.5px;line-height:1.5;color:rgba(236,231,220,.85)}
.hero-col.lead p b{color:var(--ivory)}

/* CTA buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:transform .2s,background .2s,color .2s;cursor:pointer}
.btn-fill{background:var(--acc);color:var(--ink)}
.btn-fill:hover{background:var(--ink);color:var(--ivory)}
.btn-line{border:1.5px solid var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--ivory)}
.btn-dark{background:var(--ink);color:var(--ivory)}
.btn-dark:hover{background:var(--acc);color:var(--ink)}
.hero-col.lead .btn-dark:hover{background:var(--ivory);color:var(--ink)}
.btn .arr{display:inline-block;transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}

/* === Marquee === */
.marquee{height:62px;background:var(--acc);color:var(--ink);display:flex;align-items:center;overflow:hidden;border-top:1px solid rgba(42,31,16,.22);border-bottom:1.5px solid var(--ink);position:relative;z-index:3}
.marquee-track{display:inline-flex;align-items:center;font-family:'Caveat',cursive;font-size:19px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;animation:marq calc(60s / var(--anim-mult)) linear infinite}
.marquee-track > span{display:inline-flex;align-items:center}
.mq-item{display:inline-flex;align-items:center;padding:0 28px}
.mq-sep{display:inline-flex;align-items:center;flex-shrink:0;opacity:.38;color:var(--ink)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* === Homepage réalisations extract === */
.home-enq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:60px 40px;padding-top:40px}
.home-enq-cta{grid-column:2 / 4;display:flex;align-items:center;gap:28px;padding-left:20px}
.home-enq-arrow{width:130px;height:68px;flex-shrink:0}
.home-enq-btn{font-size:17px !important;padding:22px 40px !important;letter-spacing:.06em;white-space:nowrap}
@media(max-width:900px){.home-enq-grid{grid-template-columns:repeat(2,1fr)}.home-enq-cta{grid-column:auto;grid-row:auto;padding-left:0}}
@media(max-width:600px){.home-enq-grid{grid-template-columns:1fr}.home-enq-arrow{display:none}.home-enq-cta{grid-column:1}}

/* === Section header === */
.sec{position:relative;padding:90px 36px;border-bottom:1.5px solid var(--ink);background:transparent;z-index:2}
.sec.dark{background:var(--ink);color:var(--ivory)}
.sec.dark .sec-head .kicker{color:var(--acc2)}
.sec.dark .sec-head h2{color:var(--ivory)}
.sec.dark .sec-head .sub{color:rgba(236,231,220,.7)}
.sec-head{display:grid;grid-template-columns:200px 1fr 280px;gap:40px;padding-bottom:48px;border-bottom:1px dashed rgba(0,0,0,.25);margin-bottom:48px;align-items:end}
.sec.dark .sec-head{border-color:rgba(236,231,220,.18)}
.sec-head .kicker{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--acc)}
.sec-head h2{font-family:var(--title-font);font-size:clamp(48px,7vw,108px);font-weight:800;line-height:.88;letter-spacing:-.04em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0}
.sec-head .sub{font-family:'Caveat',cursive;font-size:26px;line-height:1.4;color:rgba(42,31,16,.8);transform:rotate(-.4deg)}

/* === Métiers grid === */
.metiers{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink)}
.metiers .card{background:var(--ivory);padding:28px 24px 24px;min-height:240px;display:flex;flex-direction:column;gap:14px;position:relative;transition:background .25s,color .25s;cursor:pointer;overflow:hidden}
.metiers .card:hover{background:var(--acc);color:var(--ink)}
.metiers .card:hover .arr{color:var(--ink)}
.metiers .card:hover .n{color:var(--ink)}
.metiers .card .n{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;transition:color .25s}
.metiers .card .t{font-size:22px;font-weight:800;letter-spacing:-.015em;line-height:1.1}
.metiers .card .d{font-size:13px;line-height:1.5;color:var(--muted);transition:color .25s}
.metiers .card:hover .d{color:rgba(0,0,0,.65)}
.metiers .card .arr{position:absolute;right:20px;top:24px;font-size:18px;font-weight:700;color:var(--acc);transition:transform .25s,color .25s}
.metiers .card:hover .arr{transform:translate(4px,-4px)}
.metiers .card ul{list-style:none;padding:0;margin-top:auto;display:flex;flex-direction:column;gap:4px;font-size:12px;font-family:'JetBrains Mono',monospace;letter-spacing:.04em;color:var(--muted);transition:color .25s}
.metiers .card:hover ul{color:rgba(0,0,0,.6)}

/* === Realisations grid — style bureau d'études === */
.real{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink);position:relative;perspective:1400px}
.real-spotlight{position:absolute;width:640px;height:640px;border-radius:50%;background:radial-gradient(circle,rgba(200,122,61,.11) 0%,transparent 65%);pointer-events:none;z-index:3;transform:translate(-50%,-50%);will-change:transform;top:0;left:0}

/* Card base */
.real .item{background:#0e0e0d;position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/5;will-change:transform;display:block}
/* Photo de fond — sombre + overlay pour garder le rendu technique */
.card-photo{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.05);transition:transform .7s cubic-bezier(.25,.46,.45,.94);will-change:transform;z-index:0}
.card-photo::after{content:'';position:absolute;inset:0;background:rgba(10,9,8,.72);transition:background .5s}
.real .item:hover .card-photo{transform:scale(1.08)}
.real .item:hover .card-photo::after{background:rgba(10,9,8,.55)}

/* Grille millimètre cuivre */
.card-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(200,122,61,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(200,122,61,.06) 1px,transparent 1px);background-size:28px 28px;z-index:0;opacity:.5;transition:opacity .45s;pointer-events:none}
.real .item:hover .card-grid{opacity:1}

/* Marques d'enregistrement */
.corner-mark{position:absolute;width:14px;height:14px;border-style:solid;border-color:rgba(200,122,61,.22);transition:border-color .35s,transform .4s;z-index:2;pointer-events:none}
.corner-mark.tl{top:12px;left:12px;border-width:1px 0 0 1px}
.corner-mark.tr{top:12px;right:12px;border-width:1px 1px 0 0}
.corner-mark.bl{bottom:12px;left:12px;border-width:0 0 1px 1px}
.corner-mark.br{bottom:12px;right:12px;border-width:0 1px 1px 0}
.real .item:hover .corner-mark{border-color:var(--acc)}
.real .item:hover .corner-mark.tl{transform:translate(-3px,-3px)}
.real .item:hover .corner-mark.tr{transform:translate(3px,-3px)}
.real .item:hover .corner-mark.bl{transform:translate(-3px,3px)}
.real .item:hover .corner-mark.br{transform:translate(3px,3px)}

/* Scan vertical */
.scan-line{position:absolute;top:0;bottom:0;left:0;width:1px;background:linear-gradient(to bottom,transparent 0%,rgba(200,122,61,.8) 45%,rgba(200,122,61,.8) 55%,transparent 100%);pointer-events:none;z-index:4;will-change:transform}

/* En-tête */
.card-header{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid rgba(236,231,220,.07);z-index:2}
.card-ref{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(236,231,220,.3)}
.card-tag{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--acc);border:1px solid rgba(200,122,61,.28);padding:3px 8px;transition:background .3s,color .3s}
.real .item:hover .card-tag{background:var(--acc);color:var(--ink)}

/* Numéro outline */
.ghost-num{position:absolute;right:-6px;bottom:32px;font-family:var(--title-font);font-size:clamp(100px,12vw,160px);font-weight:900;color:transparent;-webkit-text-stroke:1px rgba(236,231,220,.055);line-height:1;pointer-events:none;letter-spacing:-.05em;font-stretch:var(--title-stretch);z-index:1;transition:-webkit-text-stroke-color .4s}
.real .item:hover .ghost-num{-webkit-text-stroke-color:rgba(200,122,61,.2)}

/* Corps */
.card-body{position:absolute;left:16px;right:16px;top:50%;transform:translateY(-48%);z-index:2;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}
.real .item:hover .card-body{transform:translateY(-52%)}
.card-title{font-family:var(--title-font);font-size:clamp(17px,1.9vw,24px);font-weight:800;letter-spacing:-.025em;text-transform:uppercase;font-stretch:var(--title-stretch);color:var(--ivory);margin:0 0 9px;line-height:1.05}
.card-meta{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--acc);margin:0 0 10px}
.card-desc{font-size:11.5px;color:rgba(236,231,220,.38);line-height:1.55;transition:color .35s}
.real .item:hover .card-desc{color:rgba(236,231,220,.6)}

/* Pied — ligne de mesure */
.card-footer{position:absolute;bottom:0;left:0;right:0;padding:11px 16px;border-top:1px solid rgba(236,231,220,.07);display:flex;align-items:center;gap:8px;z-index:2}
.measure-line{display:flex;align-items:center;flex:1;gap:0;overflow:hidden}
.measure-tick{width:1px;height:6px;background:rgba(200,122,61,.35);flex-shrink:0;transition:background .3s}
.real .item:hover .measure-tick{background:var(--acc)}
.measure-bar{height:1px;background:linear-gradient(to right,var(--acc),rgba(200,122,61,.4));flex:1;transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.real .item:hover .measure-bar{transform:scaleX(1)}
.measure-yr{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;color:rgba(200,122,61,.45);padding:0 9px;flex-shrink:0;transition:color .3s}
.real .item:hover .measure-yr{color:var(--acc)}
.card-arr{font-size:13px;color:rgba(236,231,220,.2);transition:color .3s,transform .3s;margin-left:auto;flex-shrink:0}
.real .item:hover .card-arr{color:var(--acc);transform:translate(3px,-3px)}

/* === Sectors === */
.sectors{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink)}
.sectors .row{background:var(--ivory);padding:32px 28px;display:grid;grid-template-columns:80px 1fr auto;gap:24px;align-items:center;cursor:pointer;transition:background .25s,color .25s,padding-left .25s}
.sectors .row:hover{background:var(--acc);color:var(--ink);padding-left:40px}
.sectors .row .n{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--muted);transition:color .25s}
.sectors .row:hover .n{color:var(--ink)}
.sectors .row .t{font-family:var(--title-font);font-size:36px;font-weight:800;letter-spacing:-.025em;text-transform:uppercase;line-height:1}
.sectors .row .t em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--acc);text-transform:none;letter-spacing:0}
.sectors .row:hover .t em{color:var(--ink)}
.sectors .row .arr{font-size:24px;color:var(--acc);transition:transform .25s,color .25s}
.sectors .row:hover .arr{color:var(--ink);transform:translateX(8px)}

/* === Footer === */
.footer{background:var(--ink);color:var(--ivory);padding:80px 36px 0;position:relative;overflow:hidden}
.footer .wm{position:absolute;left:36px;right:36px;bottom:-32px;font-family:var(--title-font);font-size:clamp(120px,22vw,360px);font-weight:900;line-height:.78;letter-spacing:-.06em;color:rgba(236,231,220,.06);text-transform:uppercase;font-stretch:var(--title-stretch);pointer-events:none;white-space:nowrap}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;position:relative;z-index:2;padding-bottom:80px;border-bottom:1px solid rgba(236,231,220,.18)}
.footer .col h4{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--acc2);margin-bottom:18px;font-weight:700}
.footer .col ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px}
.footer .col a:hover{color:var(--acc)}
.footer .col p{font-size:14px;line-height:1.6;color:rgba(236,231,220,.75)}
.footer .col p b{color:var(--ivory)}
.footer .lead-col p{font-size:16px;line-height:1.5;max-width:36ch}
.footer .lead-col .lg{display:flex;align-items:center;gap:14px;margin-bottom:24px;font-weight:700;letter-spacing:.06em;font-size:13px}
.footer .lead-col .lg img{height:36px}
.footer .lead-col .lg .sep{color:var(--acc)}
.footer .lead-col .lg .sub{color:rgba(236,231,220,.6);font-weight:500;letter-spacing:.08em;font-size:11px;text-transform:uppercase}
.footer-bottom{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;padding:24px 0 28px;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(236,231,220,.55)}
.footer-bottom a:hover{color:var(--acc)}

/* === In-view animation utility === */
.r-up{opacity:0;transform:translateY(24px);transition:opacity .9s,transform .9s}
.r-up.in{opacity:1;transform:none}
.r-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.r-stagger.in > *{opacity:1;transform:none}
.r-stagger.in > *:nth-child(1){transition-delay:.05s}
.r-stagger.in > *:nth-child(2){transition-delay:.12s}
.r-stagger.in > *:nth-child(3){transition-delay:.19s}
.r-stagger.in > *:nth-child(4){transition-delay:.26s}
.r-stagger.in > *:nth-child(5){transition-delay:.33s}
.r-stagger.in > *:nth-child(6){transition-delay:.4s}
.r-stagger.in > *:nth-child(7){transition-delay:.47s}
.r-stagger.in > *:nth-child(8){transition-delay:.54s}

/* Counter */
.counter{font-variant-numeric:tabular-nums}

/* === Sub-page hero (compact) === */
.hero-sm{position:relative;padding:80px 36px 60px;border-bottom:1.5px solid var(--ink);background:transparent;z-index:2}
.hero-sm .crumb{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.hero-sm .crumb .acc{color:var(--acc)}
.hero-sm h1{font-family:var(--title-font);font-size:clamp(64px,9.5vw,156px);font-weight:800;line-height:.86;letter-spacing:-.05em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0}
.hero-sm h1 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--acc);text-transform:none;letter-spacing:0}
.hero-sm .lead{margin-top:32px;max-width:62ch;font-size:17px;line-height:1.55;color:var(--muted)}

/* === Métier detail (single-page sections list) === */
.metier-detail{display:grid;grid-template-columns:200px 1fr;gap:40px;padding:48px 0;border-top:1px dashed rgba(0,0,0,.25)}
.metier-detail:first-of-type{border-top:0}
.metier-detail .idx{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--acc)}
.metier-detail h3{font-family:var(--title-font);font-size:clamp(40px,5.5vw,80px);font-weight:800;line-height:.92;letter-spacing:-.035em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0 0 24px}
.metier-detail .body{font-size:15.5px;line-height:1.6;color:var(--muted);max-width:62ch}
.metier-detail .body p + p{margin-top:14px}
.metier-detail .tags{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px}
.metier-detail .tags span{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;border:1px solid var(--ink);color:var(--ink)}
.metier-detail .kpis{margin-top:28px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink)}
.metier-detail .kpis .kpi{background:var(--ivory);padding:18px 16px;display:flex;flex-direction:column;gap:6px}
.metier-detail .kpis .kpi b{font-size:32px;font-weight:800;letter-spacing:-.025em;color:var(--acc);font-family:var(--title-font)}
.metier-detail .kpis .kpi span{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* === Realisations page filters === */
.filters{display:flex;flex-wrap:wrap;gap:8px;padding:24px 0 0;align-items:center}
.filters .lbl{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-right:12px}
.filters button{padding:8px 14px;border:1px solid var(--ink);font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s}
.filters button:hover{background:var(--ink);color:var(--ivory)}
.filters button.on{background:var(--acc);color:var(--ink);border-color:var(--ink)}

/* === Contact form === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--ink);border:1px solid var(--ink)}
.contact-grid .pane{background:var(--ivory);padding:48px 40px}
.contact-grid .pane.dark{background:var(--ink);color:var(--ivory)}
.contact-grid .pane h3{font-family:var(--title-font);font-size:48px;font-weight:800;line-height:.92;letter-spacing:-.035em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0 0 28px}
.contact-grid .pane.dark h3{color:var(--ivory)}
.contact-grid .pane .info{display:flex;flex-direction:column;gap:24px;margin-top:40px}
.contact-grid .pane .info .blk{display:grid;grid-template-columns:120px 1fr;gap:16px;padding-bottom:18px;border-bottom:1px dashed rgba(236,231,220,.25);font-size:14px}
.contact-grid .pane .info .blk:last-child{border-bottom:0}
.contact-grid .pane .info .blk dt{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--acc2)}
.contact-grid .pane .info .blk dd{color:var(--ivory);line-height:1.5}
.contact-grid .pane .info .blk dd b{color:var(--ivory)}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea,.field select{font-family:inherit;font-size:14px;padding:12px 14px;border:1.5px solid var(--ink);background:transparent;color:var(--ink);transition:background .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;background:#fff}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.field-chips button{padding:8px 12px;border:1px solid var(--ink);font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s}
.field-chips button.on{background:var(--acc);color:#fff;border-color:var(--acc)}
.contact-form .submit{margin-top:8px;width:100%;justify-content:center}
.contact-form .ok{padding:24px;background:var(--acc);color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.06em;line-height:1.5}

/* === Manifesto strip (between sections) === */
.manifesto .m-line-wrap{display:block;overflow:hidden;line-height:1}
.manifesto .m-line-inner{display:block}

@keyframes cuivre-pulse {
  0%, 100% { color: var(--acc); text-shadow: 0 0 0px transparent; }
  50%       { color: var(--acc2); text-shadow: 0 0 48px rgba(200,122,61,.55), 0 0 100px rgba(200,122,61,.22); }
}
.manifesto h2 em {
  animation: cuivre-pulse 3s ease-in-out infinite;
}
.manifesto h2 .m-line-wrap:nth-child(4) em {
  animation-delay: 1.5s;
}
.manifesto{padding:120px 36px;background:var(--ink);color:var(--ivory);border-bottom:1.5px solid var(--ink);position:relative;overflow:hidden}
.manifesto h2{font-family:var(--title-font);font-size:clamp(56px,8.5vw,140px);font-weight:800;line-height:.92;letter-spacing:-.04em;text-transform:uppercase;font-stretch:var(--title-stretch);max-width:18ch}
.manifesto h2 em{font-family:inherit;font-style:normal;font-weight:inherit;color:var(--acc);text-transform:uppercase;letter-spacing:inherit}
.manifesto .signature{margin-top:48px;display:flex;justify-content:space-between;align-items:end;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(236,231,220,.6);padding-top:28px;border-top:1px dashed rgba(236,231,220,.25)}
.manifesto .signature b{color:var(--acc2);font-weight:700}

/* === CTA strip === */
.cta-strip{padding:80px 36px;background:var(--acc);color:var(--ink);border-bottom:1.5px solid var(--ink);display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.cta-strip h2{font-family:var(--title-font);font-size:clamp(40px,6vw,88px);font-weight:800;line-height:.92;letter-spacing:-.035em;text-transform:uppercase;font-stretch:var(--title-stretch);margin:0;max-width:14ch;color:var(--ivory)}
.cta-strip h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;text-transform:none;letter-spacing:0}
.cta-strip .ctas{display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.cta-strip .ctas .btn{min-width:260px;justify-content:space-between;padding:18px 28px;font-size:15px}
.cta-strip .btn-dark:hover{background:#fff;color:var(--ink)}

/* === Tweaks panel customizations === */
[data-tweak-panel]{font-family:'JetBrains Mono',monospace !important}

/* === Responsive === */
@media (max-width:1100px){
  .hero-cols, .metiers, .footer-grid{grid-template-columns:repeat(2,1fr)}
  .sec-head{grid-template-columns:1fr;gap:20px}
  .sectors{grid-template-columns:1fr}
  .real{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .cta-strip{grid-template-columns:1fr;text-align:left}
  .cta-strip .ctas{align-items:flex-start}
}
@media (max-width:680px){
  .topbar nav.links{display:none}
  .topbar-inner{padding:0 18px}
  .hero,.sec,.hero-sm{padding-left:18px;padding-right:18px}
  .meta-strip{padding-left:18px;padding-right:18px}
  .hero-cols, .metiers, .real, .footer-grid{grid-template-columns:1fr}
  .footer{padding:60px 18px 0}
  .metier-detail{grid-template-columns:1fr;gap:14px}
  .sectors .row{grid-template-columns:60px 1fr auto;padding:22px 18px}
  .sectors .row .t{font-size:24px}
}
