/* =========================================================
   Anoukis Multimedia ? Refonte
   Base + 3 directions visuelles (A / B / C)
   ========================================================= */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
svg{width:18px;height:18px;flex:none}
h1,h2,h3,h4,p{margin:0}
ul{margin:0;padding:0;list-style:none}

/* ---------- THEME TOKENS : Direction A (Chaleureux & Proche) ---------- */
:root,
html[data-direction="a"]{
  --bg:#FBF5EF;
  --bg-alt:#FFFFFF;
  --surface:#FFFFFF;
  --ink:#2A1A12;
  --ink-soft:#5B4A40;
  --muted:#8A7A6E;
  --line:#E4D3C3;
  --brand:#C42D08;
  --brand-2:#E8551B;
  --brand-soft:#F8DFCE;
  --brand-ink:#FFFFFF;
  --dark-bg:#2A130C;
  --dark-ink:#F6E9DF;
  --sand:#F3E7D9;

  --font-head:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --head-weight:800;
  --head-tracking:-0.02em;
  --head-line:1.04;

  --radius:20px;
  --radius-sm:14px;
  --radius-pill:999px;
  --btn-radius:999px;
  --shadow:0 22px 46px -22px rgba(110,35,12,.5);
  --shadow-sm:0 12px 26px -16px rgba(120,40,12,.5);
  --maxw:1180px;
}

/* ---------- Direction B (Clair & Net) ---------- */
html[data-direction="b"]{
  --bg:#FFFFFF;
  --bg-alt:#F6F4F1;
  --surface:#FFFFFF;
  --ink:#1A1714;
  --ink-soft:#4D4842;
  --muted:#8C857D;
  --line:#E7E3DD;
  --brand:#D23110;
  --brand-2:#D23110;
  --brand-soft:#FBE9E3;
  --brand-ink:#FFFFFF;
  --dark-bg:#191512;
  --dark-ink:#F1ECE6;
  --sand:#F1EDE7;

  --font-head:"Schibsted Grotesk",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --head-weight:700;
  --head-tracking:-0.025em;
  --head-line:1.02;

  --radius:12px;
  --radius-sm:10px;
  --radius-pill:8px;
  --btn-radius:10px;
  --shadow:0 16px 40px -28px rgba(20,16,12,.5);
  --shadow-sm:0 6px 18px -14px rgba(20,16,12,.45);
}

/* ---------- Direction C (Confiance & Local) ---------- */
html[data-direction="c"]{
  --bg:#FAF6F0;
  --bg-alt:#F4ECE1;
  --surface:#FFFFFF;
  --ink:#27170F;
  --ink-soft:#5A463A;
  --muted:#8C7A6B;
  --line:#E6D9C9;
  --brand:#BE3209;
  --brand-2:#C9621A;
  --brand-soft:#F3E2D3;
  --brand-ink:#FFF6EE;
  --dark-bg:#3A1407;
  --dark-ink:#F6E5D6;
  --sand:#EBD9C3;

  --font-head:"Newsreader",Georgia,serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --head-weight:600;
  --head-tracking:-0.01em;
  --head-line:1.06;

  --radius:16px;
  --radius-sm:12px;
  --radius-pill:999px;
  --btn-radius:999px;
  --shadow:0 22px 48px -26px rgba(58,20,7,.5);
  --shadow-sm:0 10px 26px -18px rgba(58,20,7,.45);
}

/* ---------- BASE ---------- */
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3{font-family:var(--font-head);font-weight:var(--head-weight);letter-spacing:var(--head-tracking);line-height:var(--head-line);color:var(--ink);text-wrap:balance}
h2{font-size:clamp(28px,4vw,46px)}
h3{font-size:21px;letter-spacing:-0.01em}
.lead{font-size:clamp(17px,1.6vw,20px);color:var(--ink-soft);line-height:1.6}

.kicker{
  font-family:var(--font-body);
  font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);display:inline-flex;align-items:center;gap:9px;
}
.kicker::before{content:"";width:22px;height:2px;background:var(--brand);border-radius:2px}
html[data-direction="c"] .kicker{letter-spacing:.2em;font-size:12px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;border-radius:var(--btn-radius);font-weight:700;font-size:16px;
  border:1.5px solid transparent;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--brand);color:var(--brand-ink);box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -16px rgba(190,50,9,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-lg{padding:17px 30px;font-size:17px}
.btn-block{width:100%}

/* ---------- TOPBAR ---------- */
.topbar{background:var(--dark-bg);color:var(--dark-ink);font-size:14px}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:16px;flex-wrap:wrap}
.topbar-left{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.topbar a,.topbar-left span{display:inline-flex;align-items:center;gap:7px;opacity:.92}
.topbar a:hover{opacity:1;color:#fff}
.topbar .dot{opacity:.4}
.socials{display:flex;align-items:center;gap:14px}
.socials a{opacity:.8}
.socials svg{width:16px;height:16px}

/* ---------- HEADER / NAV ---------- */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:22px;min-height:74px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto;text-decoration:none;flex:none}
.logo-mark{width:44px;height:44px;border-radius:12px;background:linear-gradient(140deg,var(--brand),var(--brand-2));color:#fff;font-family:var(--font-head);font-weight:800;font-size:25px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 20px -10px rgba(196,45,8,.55);flex:none}
.logo-word{font-family:var(--font-head);font-weight:800;font-size:22px;color:var(--ink);line-height:.95;display:flex;flex-direction:column;letter-spacing:-.01em}
.logo-word small{font-family:var(--font-body);font-weight:700;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.brand-logo{height:46px;width:auto;max-width:none;display:block}
image-slot.hero-photo{display:block;width:100%;height:clamp(360px,46vw,540px)}
.menu{display:flex;align-items:center;gap:4px}
.menu a{padding:9px 14px;border-radius:var(--radius-pill);font-weight:600;font-size:15.5px;color:var(--ink-soft)}
.menu a:hover{color:var(--brand);background:var(--brand-soft)}
.menu a.active{color:var(--brand)}
.nav-call{display:flex;align-items:center;gap:13px}
.nav-phone{display:flex;flex-direction:column;line-height:1.15;text-align:right;white-space:nowrap}
.nav-phone small{font-size:11.5px;color:var(--muted);font-weight:600}
.nav-phone b{font-size:18px;color:var(--ink);font-family:var(--font-head);letter-spacing:-.01em}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:var(--surface);align-items:center;justify-content:center}
.burger svg{width:22px;height:22px}

/* ---------- HERO ---------- */
.hero{position:relative;background:var(--bg);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;
  padding-top:64px;padding-bottom:72px}
.hero-copy{max-width:560px}
.hero h1{font-size:clamp(38px,5.2vw,62px);margin:18px 0 0}
.hero h1 .hl{color:var(--brand)}
html[data-direction="c"] .hero h1 .hl{font-style:italic}
.hero-sub{margin-top:20px;font-size:clamp(17px,1.7vw,20px);color:var(--ink-soft);max-width:520px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.trust-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:30px}
.trust-badge{display:flex;align-items:center;gap:11px}
.trust-badge .stars{display:flex;gap:2px}
.trust-badge .stars svg{width:17px;height:17px;color:#F5A623}
.trust-badge b{font-family:var(--font-head)}
.trust-sep{width:1px;height:34px;background:var(--line)}
.trust-mini{font-size:14px;color:var(--ink-soft);line-height:1.3;white-space:nowrap}
.trust-mini b{display:block;font-size:16px;color:var(--ink);font-family:var(--font-head)}

/* hero media */
.hero-media{position:relative}
.hero-photo{aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-float{position:absolute;left:-26px;bottom:34px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:14px 16px;display:flex;align-items:center;gap:12px;max-width:240px}
.hero-float .ic{width:42px;height:42px;border-radius:12px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex:none}
.hero-float .ic svg{width:22px;height:22px}
.hero-float small{font-size:12.5px;color:var(--muted);display:block}
.hero-float b{font-size:14.5px;font-family:var(--font-head)}
.hero-badge2{position:absolute;right:-14px;top:26px;background:var(--brand);color:var(--brand-ink);
  border-radius:var(--radius-sm);padding:12px 16px;box-shadow:var(--shadow);text-align:center;line-height:1.05}
.hero-badge2 b{font-size:26px;font-family:var(--font-head);display:block}
.hero-badge2 small{font-size:11.5px;opacity:.9}

html[data-direction="b"] .hero-photo{border-radius:var(--radius)}
html[data-direction="b"] .hero .wrap{gap:48px}

/* hero illustration logistique (remplit toute la box, recadree si besoin) */
.hero-photo-logi{aspect-ratio:1/1;background:#eef3fa;border:1px solid var(--line)}
.hero-photo-logi img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}

/* decorative warm wash for A & C */
.hero::after{content:"";position:absolute;pointer-events:none;inset:auto auto 0 0;z-index:0}
html[data-direction="a"] .hero{background:
  radial-gradient(120% 90% at 88% 8%,var(--sand) 0%,transparent 55%),var(--bg)}
html[data-direction="c"] .hero{background:
  radial-gradient(100% 80% at 92% 0%,var(--bg-alt) 0%,transparent 60%),var(--bg)}

/* ---------- PLACEHOLDER ---------- */
.ph{
  position:relative;background-color:var(--sand);
  background-image:repeating-linear-gradient(135deg,
    color-mix(in srgb,var(--brand) 10%,var(--sand)) 0 2px,
    transparent 2px 13px);
  display:flex;align-items:flex-end;justify-content:flex-start;color:var(--ink-soft);
}
.ph span{font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;font-size:12px;
  background:color-mix(in srgb,var(--surface) 86%,transparent);padding:5px 10px;border-radius:8px;margin:12px;
  letter-spacing:.02em}
.ph.full{width:100%;height:100%}

/* ---------- SECTION SHELL ---------- */
section{position:relative}
.sec{padding:84px 0}
.sec-tight{padding:64px 0}
.sec-alt{background:var(--bg-alt)}
.sec-head{max-width:680px;margin:0 auto 46px;text-align:center}
.sec-head.left{text-align:left;margin-left:0}
.sec-head h2{margin-top:14px}
.sec-head .lead{margin-top:14px}

/* ---------- PAINS ---------- */
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pain{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px 18px;box-shadow:var(--shadow-sm)}
.pain .pic{width:46px;height:46px;border-radius:12px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex:none;border:1px solid color-mix(in srgb,var(--brand) 16%,transparent)}
.pain .pic svg{width:24px;height:24px}
.pain b{font-family:var(--font-head);font-size:16px;display:block;line-height:1.2}
.pain small{color:var(--muted);font-size:13.5px}

/* ---------- SERVICES ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .25s,border-color .2s;
  display:flex;flex-direction:column;min-height:230px}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--brand) 30%,var(--line))}
.svc-icon{width:62px;height:62px;border-radius:16px;background:linear-gradient(140deg,var(--brand),var(--brand-2));display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 14px 26px -12px rgba(196,45,8,.6)}
.svc-icon svg{width:30px;height:30px;color:#fff}
.svc-icon img{width:34px;height:34px}
.svc h3{font-size:22px}
.svc p{margin-top:9px;color:var(--ink-soft);font-size:15.5px;flex:1}
.svc-link{margin-top:16px;display:inline-flex;align-items:center;gap:8px;color:var(--brand);font-weight:700;font-size:15px}
.svc-link svg{width:16px;height:16px;transition:transform .2s}
.svc:hover .svc-link svg{transform:translateX(4px)}
.svc .tag{align-self:flex-start;font-size:12px;font-weight:700;color:var(--brand);background:var(--brand-soft);
  padding:4px 11px;border-radius:999px;margin-bottom:14px;letter-spacing:.02em;white-space:nowrap}

html[data-direction="b"] .svc-grid{grid-template-columns:repeat(4,1fr);gap:18px}
html[data-direction="b"] .svc{padding:24px;min-height:0}
html[data-direction="b"] .svc-icon{width:52px;height:52px;border-radius:12px}

/* ---------- WHY (reassurance band) ---------- */
.why{background:var(--dark-bg);color:var(--dark-ink)}
.why h2{color:var(--dark-ink)}
.why .kicker{color:var(--brand-2)}
.why .kicker::before{background:var(--brand-2)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:8px}
.why-item .why-ico{width:50px;height:50px;border-radius:14px;
  background:color-mix(in srgb,var(--brand) 30%,transparent);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.why-item .why-ico svg{width:26px;height:26px}
.why-item h3{color:var(--dark-ink);font-size:19px}
.why-item p{margin-top:8px;color:color-mix(in srgb,var(--dark-ink) 80%,transparent);font-size:15px}

/* ---------- STEPS ---------- */
.step-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;position:relative;box-shadow:var(--shadow-sm)}
.step-num{width:46px;height:46px;border-radius:50%;background:var(--brand);color:var(--brand-ink);
  font-family:var(--font-head);font-weight:800;font-size:20px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
html[data-direction="b"] .step-num{border-radius:10px}
.step h3{font-size:20px}
.step p{margin-top:8px;color:var(--ink-soft);font-size:15.5px}

/* ---------- REVIEWS ---------- */
.rev-head{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:34px}
.gmark{display:flex;align-items:center;gap:16px}
.gmark .score{font-family:var(--font-head);font-weight:800;font-size:50px;line-height:1;color:var(--ink)}
.gmark .gstars{display:flex;gap:3px}
.gmark .gstars svg{width:20px;height:20px;color:#F5A623}
.gmark .gsub{font-size:14px;color:var(--muted)}
.gmark .gsub b{color:var(--ink);font-weight:700}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.review .rstars{display:flex;gap:2px;margin-bottom:12px}
.review .rstars svg{width:16px;height:16px;color:#F5A623}
.review p{color:var(--ink);font-size:15.5px;flex:1}
.reviewer{display:flex;align-items:center;gap:12px;margin-top:18px}
.reviewer .av{width:42px;height:42px;border-radius:50%;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;flex:none}
.reviewer b{font-size:14.5px;display:block;line-height:1.2}
.reviewer .meta{display:flex;flex-direction:column}
.reviewer small{color:var(--muted);font-size:12.5px;display:block;margin-top:2px}

/* ---------- AREA / LOCAL ---------- */
.area .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.area-map{aspect-ratio:16/11;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.area-map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(1.05)}
.area ul.zones{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.area ul.zones li{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--ink-soft)}

/* ---------- FINAL CTA ---------- */
.cta{background:var(--brand);color:var(--brand-ink);border-radius:var(--radius);
  padding:54px;text-align:center;position:relative;overflow:hidden}
.cta h2{color:var(--brand-ink);font-size:clamp(28px,3.6vw,42px)}
.cta p{margin-top:14px;color:color-mix(in srgb,var(--brand-ink) 88%,transparent);font-size:18px}
.cta .btn-primary{background:#fff;color:var(--brand)}
.cta .btn-primary:hover{background:#fff}
.cta .btn-ghost{border-color:color-mix(in srgb,#fff 55%,transparent);color:#fff}
.cta .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}

/* ---------- FOOTER ---------- */
.footer{background:var(--dark-bg);color:var(--dark-ink);padding:60px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.footer h4{font-family:var(--font-head);font-size:15px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;color:#fff}
.footer a,.footer p{color:color-mix(in srgb,var(--dark-ink) 78%,transparent);font-size:14.5px}
.footer li{margin-bottom:9px}
.footer a:hover{color:#fff}
.footer-brand .brand{margin:0 0 16px;display:inline-flex}
.footer-brand .brand-logo{height:48px;max-width:none}
.footer .logo-word{color:#fff}
.footer .logo-word small{color:color-mix(in srgb,var(--dark-ink) 68%,transparent)}
.footer-contact li{display:flex;gap:10px;align-items:flex-start}
.footer-contact svg{width:17px;height:17px;color:var(--brand-2);flex:none;margin-top:2px}
.footer-bottom{border-top:1px solid color-mix(in srgb,#fff 14%,transparent);margin-top:42px;padding-top:22px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;
  color:color-mix(in srgb,var(--dark-ink) 60%,transparent)}

/* ---------- DIRECTION SWITCHER ---------- */
.switcher{position:fixed;z-index:200;left:50%;bottom:22px;transform:translateX(-50%);
  background:var(--ink);color:#fff;border-radius:999px;padding:6px;display:flex;align-items:center;gap:4px;
  box-shadow:0 20px 50px -18px rgba(0,0,0,.5);font-family:var(--font-body)}
.switcher .lab{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:0 12px 0 14px;opacity:.6}
.switcher button{border:none;background:transparent;color:#fff;border-radius:999px;padding:9px 16px;
  font-weight:700;font-size:13.5px;display:flex;flex-direction:column;align-items:center;line-height:1.1;gap:1px;
  transition:background .2s,color .2s}
.switcher button small{font-size:10px;font-weight:600;opacity:.6}
.switcher button.on{background:var(--brand);color:#fff}
.switcher button.on small{opacity:.85}
.switcher button:not(.on):hover{background:rgba(255,255,255,.12)}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;padding-top:46px}
  .hero-media{max-width:440px}
  .why-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  html[data-direction="b"] .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .menu,.nav-phone small,.trust-sep{display:none}
  .burger{display:flex}
  .nav .wrap{gap:14px}
}
@media (max-width:720px){
  .sec{padding:60px 0}
  .pain-grid{grid-template-columns:1fr}
  .svc-grid,html[data-direction="b"] .svc-grid{grid-template-columns:1fr}
  .step-row{grid-template-columns:1fr}
  .review-grid{grid-template-columns:1fr}
  .area .wrap{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta{padding:38px 24px}
  .switcher .lab{display:none}
}

/* ===================== PAGES INTERIEURES ===================== */
/* fil d'Ariane */
.crumbs{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600;color:var(--muted);margin-bottom:18px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--brand)}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--brand)}

/* hero de page plus compact */
.hero.hero-page .wrap{padding-top:48px;padding-bottom:56px}
.hero.hero-page h1{font-size:clamp(34px,4.4vw,52px)}

/* grille de prestations detaillees */
.det-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.det{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:24px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .25s,border-color .2s}
.det:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--brand) 28%,var(--line))}
.det .di{width:50px;height:50px;border-radius:13px;background:linear-gradient(140deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:15px;box-shadow:0 12px 22px -12px rgba(196,45,8,.55)}
.det .di svg{width:26px;height:26px}
.det h3{font-size:18.5px}
.det p{margin-top:8px;color:var(--ink-soft);font-size:14.5px}

/* deux options : atelier / domicile */
.opts{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.opt{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);position:relative;display:flex;flex-direction:column}
.opt.featured{border-color:color-mix(in srgb,var(--brand) 45%,var(--line));box-shadow:var(--shadow)}
.opt .opt-ic{width:54px;height:54px;border-radius:14px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.opt .opt-ic svg{width:28px;height:28px}
.opt h3{font-size:22px}
.opt .opt-lead{margin-top:9px;color:var(--ink-soft);font-size:15.5px;flex:1}
.opt .opt-meta{margin-top:18px;display:flex;flex-direction:column;gap:8px;font-size:14.5px;color:var(--ink-soft)}
.opt .opt-meta div{display:flex;gap:9px;align-items:flex-start}
.opt .opt-meta svg{width:17px;height:17px;color:var(--brand);flex:none;margin-top:3px}
.opt .opt-cta{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}
.opt-tag{position:absolute;top:20px;right:20px;background:var(--brand);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.04em;padding:5px 11px;border-radius:999px;text-transform:uppercase;white-space:nowrap}

/* etapes sur 4 colonnes */
.step-row.four{grid-template-columns:repeat(4,1fr)}

/* FAQ (accordeon natif) */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:2px 22px;box-shadow:var(--shadow-sm);transition:border-color .2s}
.faq details[open]{border-color:color-mix(in srgb,var(--brand) 30%,var(--line))}
.faq summary{list-style:none;cursor:pointer;padding:18px 0;font-family:var(--font-head);font-weight:700;font-size:17px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:26px;line-height:1;color:var(--brand);font-weight:400;flex:none}
.faq details[open] summary::after{content:"\2013"}
.faq details p{padding:0 0 20px;margin:-2px 0 0;color:var(--ink-soft);font-size:15.5px;max-width:680px}

/* ---------- FORFAITS / TARIFS ---------- */
.fit-note{display:flex;justify-content:center;flex-wrap:wrap;gap:10px 14px;margin:-26px auto 40px}
.fit-note span{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);
  border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--ink-soft)}
.fit-note svg{width:16px;height:16px;color:var(--brand)}
.fits{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fit{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .18s,box-shadow .25s,border-color .2s}
.fit:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--brand) 28%,var(--line))}
.fit-top{display:flex;align-items:center;gap:13px;margin-bottom:14px}
.fit-ic{width:46px;height:46px;border-radius:12px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex:none;border:1px solid color-mix(in srgb,var(--brand) 16%,transparent)}
.fit-ic svg{width:24px;height:24px}
.fit h3{font-size:17px;line-height:1.22}
.fit p{color:var(--ink-soft);font-size:14.5px;flex:1}
.fit-price{display:flex;align-items:baseline;gap:9px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.fit-price .amt{font-family:var(--font-head);font-weight:800;font-size:30px;color:var(--brand);line-height:1}
.fit-price .pnote{font-size:13px;color:var(--muted);font-weight:600}

/* guarantees : variante 3 colonnes du bandeau sombre */
.why-grid.three{grid-template-columns:repeat(3,1fr)}

@media (max-width:980px){
  .det-grid{grid-template-columns:repeat(2,1fr)}
  .step-row.four{grid-template-columns:repeat(2,1fr)}
  .fits{grid-template-columns:repeat(2,1fr)}
  .why-grid.three{grid-template-columns:1fr}
}
@media (max-width:720px){
  .fits{grid-template-columns:1fr}
}

/* ---------- DEVELOPPEMENT : statistiques (bandeau sombre) ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;text-align:center;margin-top:8px}
.stats .s .n{font-family:var(--font-head);font-weight:800;font-size:clamp(44px,5.6vw,68px);line-height:1;color:#fff}
.stats .s .l{margin-top:10px;font-size:15.5px;line-height:1.45;color:color-mix(in srgb,var(--dark-ink) 82%,transparent)}

/* ---------- REALISATIONS / PORTFOLIO ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.work{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .18s,box-shadow .25s,border-color .2s}
.work:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--brand) 30%,var(--line))}
.work-img{aspect-ratio:16/11;border-bottom:1px solid var(--line);overflow:hidden;background:var(--sand)}
.work-img img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.work-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.work-body h3{font-size:19px}
.work-body p{margin-top:7px;color:var(--ink-soft);font-size:14.5px;flex:1}
.work-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:15px}
.work-tags span{font-size:12px;font-weight:600;color:var(--ink-soft);background:var(--sand);
  border:1px solid var(--line);border-radius:999px;padding:4px 11px}
.work-link{margin-top:15px;display:inline-flex;align-items:center;gap:7px;color:var(--brand);font-weight:700;font-size:14.5px}
.work-link svg{width:15px;height:15px;transition:transform .2s}
.work:hover .work-link svg{transform:translateX(4px)}

/* ---------- TECHNOLOGIES ---------- */
.stack{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:6px}
.stack li{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);
  border-radius:999px;padding:11px 20px;font-weight:600;font-size:15px;color:var(--ink);box-shadow:var(--shadow-sm)}
.stack li svg{width:18px;height:18px;color:var(--brand)}

@media (max-width:980px){
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr;gap:22px}
}
@media (max-width:720px){
  .work-grid{grid-template-columns:1fr}
}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:start}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px;box-shadow:var(--shadow-sm)}
.form-card h2{font-size:24px}
.form-card .lead{margin:8px 0 24px;font-size:15.5px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-size:13.5px;font-weight:700;color:var(--ink);letter-spacing:.01em}
.field label .req{color:var(--brand)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 14px;transition:border-color .18s,box-shadow .18s;width:100%}
.field textarea{resize:vertical;min-height:128px;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%,transparent)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.consent{display:flex;align-items:flex-start;gap:11px;margin:4px 0 22px;font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.consent input{width:18px;height:18px;margin-top:2px;flex:none;accent-color:var(--brand)}
.form-card .btn-lg{width:100%;justify-content:center}
.form-note{margin-top:14px;font-size:12.5px;color:var(--muted);text-align:center;display:flex;align-items:center;justify-content:center;gap:7px}
.form-note svg{width:14px;height:14px;color:var(--brand)}
.field-error input,.field-error select,.field-error textarea{border-color:#c0392b;box-shadow:0 0 0 3px rgba(192,57,43,.12)}
.err-msg{display:none;font-size:12.5px;font-weight:600;color:#c0392b}
.field-error .err-msg{display:block}
.form-success{display:none;flex-direction:column;align-items:center;text-align:center;padding:30px 12px}
.form-success.show{display:flex}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.form-success .ok svg{width:32px;height:32px}
.form-success h3{font-size:22px}
.form-success p{margin-top:10px;color:var(--ink-soft);font-size:15.5px;max-width:340px}

/* coordonnees (colonne droite) */
.info-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm);margin-bottom:22px}
.info-card h3{font-size:18px;margin-bottom:6px}
.info-list{display:flex;flex-direction:column;gap:18px;margin-top:18px}
.info-item{display:flex;gap:14px;align-items:flex-start}
.info-item .ii{width:44px;height:44px;border-radius:12px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;flex:none;border:1px solid color-mix(in srgb,var(--brand) 16%,transparent)}
.info-item .ii svg{width:21px;height:21px}
.info-item .it small{display:block;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:3px}
.info-item .it b{font-family:var(--font-head);font-size:17px;color:var(--ink);font-weight:700;display:block}
.info-item .it a{color:var(--ink);font-family:var(--font-head);font-size:17px;font-weight:700;white-space:nowrap}
.info-item .it a:hover{color:var(--brand)}
.info-item .it span{color:var(--ink-soft);font-size:14.5px;line-height:1.5}

/* carte */
.map-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.map-card iframe{display:block;width:100%;height:400px;border:0;filter:saturate(1.02)}
.map-full iframe{height:460px}

@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .f-row{grid-template-columns:1fr}
}

/* ---------- E-COMMERCE : chaine (bandeau sombre) ---------- */
.chain{display:flex;align-items:flex-start;justify-content:center;gap:6px;flex-wrap:wrap;margin-top:8px}
.chain .link{display:flex;flex-direction:column;align-items:center;text-align:center;gap:11px;
  padding:0 4px;width:168px}
.chain .link .ci{width:58px;height:58px;border-radius:16px;
  background:color-mix(in srgb,var(--brand) 46%,transparent);color:#fff;
  border:1px solid color-mix(in srgb,#fff 22%,transparent);
  display:flex;align-items:center;justify-content:center}
.chain .link .ci svg{width:28px;height:28px}
.chain .link b{color:#fff;font-family:var(--font-head);font-size:17px}
.chain .link small{color:color-mix(in srgb,var(--dark-ink) 78%,transparent);font-size:13.5px;line-height:1.4}
.chain .sep{display:flex;align-items:center;height:58px;color:color-mix(in srgb,var(--dark-ink) 45%,transparent)}
.chain .sep svg{width:26px;height:26px}
@media (max-width:880px){
  .chain{display:grid;grid-template-columns:repeat(2,minmax(0,210px));gap:34px 24px;justify-content:center}
  .chain .sep{display:none}
  .chain .link{width:auto}
}
@media (max-width:460px){
  .chain{grid-template-columns:1fr}
}
@media (max-width:720px){
  .det-grid{grid-template-columns:1fr}
  .opts{grid-template-columns:1fr}
  .step-row.four{grid-template-columns:1fr}
}

/* ---------- MOBILE MENU TOGGLE ---------- */
@media (max-width:860px){
  .nav.menu-open .menu{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--line);padding:12px 24px;gap:4px;z-index:49;
    box-shadow:0 8px 24px -8px rgba(0,0,0,.15)
  }
  .nav.menu-open .menu a{padding:11px 14px;border-radius:var(--radius-sm)}
}