/* ============================================================
   BLOOM — Louka Nicolaeff
   Direction : éditorial clair, grandes images, header minimal
   Titres : Reckless Neue · Texte : Season Sans
   ============================================================ */

/* ░░ FONTS (fichiers fournis) ░░
   Reckless n'est fourni qu'en ITALIQUE variable (collection VF).
   Pour les titres droits, on reste sur un serif de secours élégant
   tant que tu n'as pas le Reckless droit. Les italiques utilisent
   le vrai Reckless. Season Sans gère tout le texte. */
@font-face{font-family:"Reckless Neue";src:url("fonts/RecklessItalicCollectionVF-TRIAL.woff2") format("woff2");font-weight:300 600;font-style:italic;font-display:swap}
@font-face{font-family:"Season Sans";src:url("fonts/SeasonSans-TRIAL-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Season Sans";src:url("fonts/SeasonSans-TRIAL-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}

:root{
  --serif:"Reckless Neue","Times New Roman",Georgia,serif;
  --sans:"Season Sans","Helvetica Neue",Arial,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --gut:clamp(18px,4vw,56px);
}

/* ░░ THÈME SOMBRE (par défaut) ░░ */
:root,
body{
  --bg:#141414;             /* fond principal */
  --bg-2:#1d1d1c;           /* surfaces / cartes */
  --fg:#f6f4ef;             /* texte principal (blanc cassé clair) */
  --fg-dim:rgba(246,244,239,.82);   /* texte secondaire — bien plus clair qu'avant */
  --fg-faint:rgba(246,244,239,.5);
  --line:rgba(246,244,239,.18);
  --panel-bg:#f3f1ec;       /* panneau inversé (clair) */
  --panel-fg:#141414;
  --panel-fg-dim:rgba(20,20,20,.7);
  --panel-fg-faint:rgba(20,20,20,.42);
  --panel-line:rgba(20,20,20,.16);
  --logo-filter:none;        /* logo blanc tel quel */
}

/* ░░ THÈME CLAIR ░░ */
body.light{
  --bg:#f3f1ec;
  --bg-2:#e9e6df;
  --fg:#141414;
  --fg-dim:rgba(20,20,20,.72);
  --fg-faint:rgba(20,20,20,.44);
  --line:rgba(20,20,20,.16);
  --panel-bg:#141414;
  --panel-fg:#f6f4ef;
  --panel-fg-dim:rgba(246,244,239,.82);
  --panel-fg-faint:rgba(246,244,239,.5);
  --panel-line:rgba(246,244,239,.18);
  --logo-filter:invert(1);   /* logo blanc -> noir */
}

/* alias de compat pour l'ancien code */
:root,body{--black:var(--fg);--white:#fff;--paper:var(--bg);--paper-2:var(--bg-2);--ink-dim:var(--fg-dim);--ink-faint:var(--fg-faint)}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:16.5px;line-height:1.6;overflow-x:hidden;transition:background .5s var(--ease),color .5s var(--ease)}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:auto}
em{font-style:italic}

/* titres : poids léger (Reckless Neue Book = 300/400) */
h1,h2,h3{font-weight:300}
.hero-title,.page-title,.sec-title,.sec-head h2,.statement-text,.contact-body h2,.about-h,.profile-txt h2{font-weight:300}

/* ░░ ACCESSIBILITÉ : focus clavier visible ░░ */
:focus-visible{outline:2px solid var(--fg);outline-offset:3px;border-radius:2px}
body.light :focus-visible{outline-color:#141414}
.theme-toggle:focus-visible,.cf-submit:focus-visible{outline-offset:4px}
/* lien d'évitement */
.skip-link{position:absolute;left:-999px;top:0;z-index:9999;background:var(--fg);color:var(--bg);padding:12px 20px;border-radius:0 0 6px 0;font-size:14px}
.skip-link:focus{left:0}
h1,h2,h3{font-weight:400}
::selection{background:var(--black);color:var(--paper)}

/* ░░ PRELOADER (animation logo) ░░ */
.loader{position:fixed;inset:0;z-index:9000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:34px;transition:opacity .7s var(--ease),visibility .7s}
.loader.done{opacity:0;visibility:hidden}
.loader-logo{position:relative;overflow:hidden;display:block}
.loader-logo img{height:clamp(46px,9vw,84px);width:auto;filter:var(--logo-filter);
  opacity:0;transform:translateY(14px);animation:logoIn 1s var(--ease) .1s forwards}
/* reflet qui balaie le logo */
.loader-logo .loader-sheen{position:absolute;top:0;left:-60%;width:45%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  mix-blend-mode:overlay;animation:sheen 1.5s var(--ease) .7s infinite}
body.light .loader-logo .loader-sheen{background:linear-gradient(100deg,transparent,rgba(0,0,0,.18),transparent)}
@keyframes logoIn{to{opacity:1;transform:none}}
@keyframes sheen{0%{left:-60%}55%,100%{left:120%}}
.loader-bar{width:min(220px,48vw);height:1px;background:var(--line);overflow:hidden}
.loader-bar i{display:block;height:100%;width:0;background:var(--fg);transition:width .2s linear}

/* ░░ HEADER ░░ */
.head{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px var(--gut);transition:transform .5s var(--ease),padding .5s var(--ease),background .5s,border-color .5s;border-bottom:1px solid transparent}
.head.solid{background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding-top:15px;padding-bottom:15px}
.head.hide{transform:translateY(-100%)}
.head-logo img{height:46px;width:auto;filter:var(--logo-filter);transition:height .5s var(--ease)}
.head.solid .head-logo img{height:38px}
.head-nav{display:flex;gap:clamp(16px,2.2vw,38px);align-items:center;margin-left:auto;margin-right:clamp(18px,3vw,48px)}
.head-nav a{font-size:14px;color:var(--fg);position:relative}
.head-nav a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:currentColor;transition:width .4s var(--ease)}
.head-nav a:hover::after{width:100%}
.head-contact{border:1px solid var(--line);padding:8px 18px;border-radius:100px}
.head-contact::after{display:none!important}
.head-status{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--fg-dim);white-space:nowrap}
.head-status .dot{width:7px;height:7px;border-radius:50%;background:#5fbf7e;box-shadow:0 0 0 0 rgba(95,191,126,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(95,191,126,.5)}70%{box-shadow:0 0 0 7px rgba(95,191,126,0)}100%{box-shadow:0 0 0 0 rgba(95,191,126,0)}}
/* ░░ TOGGLE THÈME ░░ */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);border-radius:50%;background:none;cursor:pointer;color:var(--fg);transition:.4s var(--ease);flex-shrink:0}
.theme-toggle:hover{background:var(--fg);color:var(--bg)}
.theme-toggle svg{width:17px;height:17px;display:block}
.theme-toggle .icon-sun{display:none}
body.light .theme-toggle .icon-sun{display:block}
body.light .theme-toggle .icon-moon{display:none}
.burger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:6px;z-index:1100}
.burger span{width:25px;height:1.6px;background:var(--fg);display:block;transition:.4s var(--ease)}

/* ░░ HERO ░░ */
.hero{position:relative;min-height:100svh;display:grid;grid-template-rows:1fr auto;padding:0 var(--gut) clamp(30px,5vh,56px);overflow:hidden}
.hero-media{position:absolute;top:0;left:0;right:0;height:62vh;z-index:0}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
.hero-ph{position:absolute;inset:0;background:linear-gradient(165deg,#3a3733,#1a1916 70%);overflow:hidden}
.hero-ph::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 70% 25%,rgba(255,255,255,.08),transparent 60%)}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),transparent 45%,var(--bg))}
.hero-text{position:relative;z-index:2;align-self:end;padding-top:46vh}
.hero-title{font-family:var(--serif);font-size:clamp(54px,13vw,210px);line-height:.86;letter-spacing:-.02em}
.hero-title .amp{font-style:italic;padding:0 .12em;color:var(--fg-faint)}
.hero-foot{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.1fr auto;gap:clamp(20px,4vw,60px);align-items:end;border-top:1px solid var(--line);padding-top:26px;margin-top:clamp(30px,5vh,56px)}
.hero-avail{font-size:15px;max-width:24ch}
.hero-avail a{border-bottom:1px solid var(--fg);padding-bottom:1px}
.hero-intro{font-size:15px;color:var(--fg-dim);max-width:52ch}
.hero-cta{display:inline-flex;align-items:center;gap:10px;font-size:14px;border:1px solid var(--line);padding:14px 26px;border-radius:100px;white-space:nowrap;transition:.45s var(--ease)}
.hero-cta i{transition:transform .45s var(--ease)}
.hero-cta:hover{background:var(--fg);color:var(--bg)}
.hero-cta:hover i{transform:translate(3px,-3px)}

/* ░░ NAV CARDS ░░ */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,20px);padding:clamp(40px,7vh,90px) var(--gut)}
.card{display:block}
.card-label{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-size:clamp(18px,1.8vw,24px);margin-bottom:14px}
.card-label .i{font-family:var(--sans);font-size:12px;color:var(--ink-faint)}
.card-img{overflow:hidden;aspect-ratio:4/5;background:var(--paper-2)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.card:hover .card-img img{transform:scale(1.05)}
.card-ph{width:100%;height:100%;transition:transform 1s var(--ease)}
.card:hover .card-ph{transform:scale(1.05)}
.c1{background:linear-gradient(150deg,#c9c3b6,#a59c8b)}
.c2{background:linear-gradient(150deg,#b8bcc0,#8d9298)}
.c3{background:linear-gradient(150deg,#cabfb4,#9b8d7d)}
.c4{background:linear-gradient(150deg,#bcc2bd,#8f9790)}

/* ░░ SECTION GENERICS ░░ */
section{position:relative}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;padding:0 var(--gut);margin-bottom:clamp(34px,5vh,60px)}
.sec-head h2{font-family:var(--serif);font-size:clamp(34px,6vw,86px);line-height:.96;letter-spacing:-.02em}
.sec-link{font-size:14px;color:var(--ink-dim);border-bottom:1px solid var(--line);padding-bottom:2px;transition:.3s}
.sec-link:hover{color:var(--black);border-color:var(--black)}
.sec-desc{font-size:clamp(16px,1.7vw,20px);max-width:46ch;color:var(--ink-dim)}
.sec-index{display:inline-block;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:20px}

/* ░░ WORK ░░ */
.work{padding:clamp(50px,9vh,120px) 0}
.case{display:block;padding:0 var(--gut);margin-bottom:clamp(46px,8vh,110px)}
.case:last-child{margin-bottom:0}
.case-img{overflow:hidden;background:var(--paper-2);aspect-ratio:3/2}
.case-img img{height:100%;object-fit:cover;transition:transform 1.2s var(--ease);transform:scale(1.01)}
.case:hover .case-img img{transform:scale(1.05)}
.case-meta{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-top:22px}
.case-meta h3{font-family:var(--serif);font-size:clamp(24px,3.4vw,46px);line-height:1.04;letter-spacing:-.01em;max-width:18ch}
.case-meta h3 span{display:block;font-size:.46em;color:var(--ink-dim);margin-top:8px;letter-spacing:0}
.case-tag{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;padding-top:10px}

/* ░░ SERVICES ░░ */
.services{padding:clamp(60px,10vh,140px) 0;background:var(--panel-bg);color:var(--panel-fg);margin:clamp(40px,7vh,90px) 0;transition:background .5s var(--ease),color .5s var(--ease)}
.services .sec-head h2{color:var(--panel-fg)}
.services .sec-desc{color:var(--panel-fg-dim)}
.svc-list{padding:0 var(--gut);border-top:1px solid var(--panel-line)}
.svc{display:grid;grid-template-columns:70px 1fr 1.5fr auto;gap:clamp(14px,3vw,50px);align-items:start;padding:clamp(26px,4.4vh,46px) 0;border-bottom:1px solid var(--panel-line);transition:padding-left .5s var(--ease)}
.svc:hover{padding-left:16px}
.svc-n{font-family:var(--serif);font-size:15px;color:var(--panel-fg-faint);padding-top:8px}
.svc h3{font-family:var(--serif);font-size:clamp(23px,3vw,40px);line-height:1.04;letter-spacing:-.01em}
.svc p{color:var(--panel-fg-dim);font-size:15.5px;max-width:50ch}
.svc-tags{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--panel-fg-faint);text-align:right;padding-top:8px;white-space:nowrap}

/* ░░ CLIENTS ░░ */
.clients{padding:clamp(50px,8vh,100px) var(--gut);text-align:center;border-top:1px solid var(--line)}
.clients-label{display:block;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:clamp(28px,4vh,46px)}
.clients-row{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(20px,3vw,52px) clamp(28px,5vw,80px)}
.clients-row span{font-family:var(--serif);font-size:clamp(22px,3.2vw,46px);color:var(--ink-faint);transition:color .4s var(--ease);cursor:default}
.clients-row span:hover{color:var(--black)}

/* ░░ TESTIMONIALS ░░ */
.testi{padding:clamp(50px,9vh,120px) 0;border-top:1px solid var(--line)}
.testi-track{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,34px);padding:0 var(--gut)}
.testi-card{border:1px solid var(--line);border-radius:4px;padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;justify-content:space-between;gap:30px;min-height:300px;background:var(--bg-2)}
.testi-card p{font-family:var(--serif);font-size:clamp(18px,1.8vw,23px);line-height:1.35}
.testi-card footer{display:flex;flex-direction:column;gap:3px}
.testi-card strong{font-weight:500}
.testi-card span{font-size:13px;color:var(--ink-faint)}

/* ░░ PROFILE ░░ */
.profile{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;padding:clamp(50px,9vh,130px) var(--gut);border-top:1px solid var(--line)}
.profile-img{overflow:hidden;background:var(--paper-2)}
.profile-ph{aspect-ratio:4/5;background:linear-gradient(165deg,#cfc8bb,#a89e8d);display:flex;align-items:center;justify-content:center}
.profile-ph span{font-family:var(--serif);font-style:italic;color:rgba(20,20,20,.4)}
.profile-img img{aspect-ratio:4/5;object-fit:cover}
.profile-txt h2{font-family:var(--serif);font-size:clamp(32px,4.6vw,64px);line-height:1.0;letter-spacing:-.02em;margin-bottom:28px}
.profile-txt p{color:var(--ink-dim);margin-bottom:18px;max-width:48ch}
.profile-link{display:inline-block;margin-top:14px;font-size:15px;border-bottom:1px solid var(--black);padding-bottom:2px}

/* ░░ CONTACT ░░ */
.contact{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(30px,5vw,80px);align-items:center;padding:clamp(60px,11vh,160px) var(--gut);background:var(--panel-bg);color:var(--panel-fg);transition:background .5s var(--ease),color .5s var(--ease)}
.contact-ph{aspect-ratio:4/5;background:linear-gradient(165deg,#2c2a26,#161513)}
.contact-img img{aspect-ratio:4/5;object-fit:cover}
.contact-body h2{font-family:var(--serif);font-size:clamp(34px,6vw,90px);line-height:.98;letter-spacing:-.02em}
.contact-mail{display:inline-block;margin-top:clamp(28px,4vh,48px);font-family:var(--serif);font-size:clamp(20px,2.6vw,34px);border-bottom:1px solid var(--panel-line);padding-bottom:4px;transition:border-color .4s}
.contact-mail:hover{border-color:var(--panel-fg)}
.contact-links{display:flex;gap:30px;margin-top:34px;font-size:14px;color:var(--panel-fg-dim)}
.contact-links a{transition:color .3s}
.contact-links a:hover{color:var(--panel-fg)}

/* ░░ FOOTER ░░ */
.foot{padding:clamp(46px,7vh,80px) var(--gut) 36px}
.foot-mark{border-bottom:1px solid var(--line);padding-bottom:30px;margin-bottom:40px}
.foot-logo{height:34px;width:auto}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-bottom:50px}
.foot-col h5{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px}
.foot-col a,.foot-col span{display:block;font-size:14px;color:var(--ink-dim);margin-bottom:10px;transition:color .3s;width:fit-content}
.foot-col a:hover{color:var(--black)}
.foot-bot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px;font-size:13px;color:var(--ink-faint)}

/* ░░ REVEAL ░░ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ░░ RESPONSIVE ░░ */
@media(max-width:1024px){
  .hero-foot{grid-template-columns:1fr 1fr;row-gap:24px}
  .hero-cta{grid-column:1/-1;justify-self:start}
  .svc{grid-template-columns:50px 1fr;row-gap:12px}
  .svc p,.svc-tags{grid-column:2}
  .svc-tags{text-align:left;padding-top:0}
  .testi-track{grid-template-columns:1fr;max-width:560px;margin:0 auto}
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body{font-size:16px}
  .head-nav{position:fixed;inset:0;background:var(--bg);flex-direction:column;justify-content:center;gap:26px;margin:0;transform:translateY(-100%);transition:transform .6s var(--ease)}
  .head-nav.open{transform:none}
  .head-nav a{font-size:30px;font-family:var(--serif);color:var(--fg)}
  .head-nav a::after{display:none}
  .head-contact{border:none;padding:0}
  .head-status{display:none}
  .burger{display:flex}
  .burger.x span:nth-child(1){transform:translateY(3.8px) rotate(45deg)}
  .burger.x span:nth-child(2){transform:translateY(-3.8px) rotate(-45deg)}
  .hero-media{height:54vh}
  .hero-text{padding-top:38vh}
  .hero-foot{grid-template-columns:1fr;gap:20px}
  .case-meta{flex-direction:column;gap:10px}
  .profile{grid-template-columns:1fr;gap:32px}
  .profile-img{max-width:360px}
  .contact{grid-template-columns:1fr;gap:34px}
  .contact-img{max-width:320px}
  .foot-cols{grid-template-columns:1fr 1fr}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}

/* ============================================================
   PAGES INTERNES (multi-pages)
   ============================================================ */

/* ░░ état actif nav ░░ */
.head-nav a.active{opacity:1}
.head-nav a.active::after{width:100%}
.head.solid .head-nav a.active{font-weight:500}

/* ░░ corps des pages internes : décalage sous header fixe ░░ */
body.page{padding-top:0}
.page-hero{padding:clamp(130px,20vh,210px) var(--gut) clamp(40px,7vh,80px)}
.page-index{display:inline-block;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:22px}
.page-title{font-family:var(--serif);font-size:clamp(44px,8.5vw,124px);line-height:.94;letter-spacing:-.025em}
.page-lead{font-size:clamp(16px,1.8vw,21px);color:var(--ink-dim);max-width:54ch;margin-top:clamp(24px,4vh,38px)}
.page-hero .btn-dark{margin-top:clamp(28px,4vh,42px)}

/* ░░ boutons ░░ */
.btn-light,.btn-dark{display:inline-flex;align-items:center;gap:10px;font-size:14px;padding:15px 30px;border-radius:100px;transition:.45s var(--ease)}
.btn-light{border:1px solid rgba(243,241,236,.3);color:var(--paper)}
.btn-light:hover{background:var(--paper);color:var(--black)}
/* bouton plein, bien visible (sur panneau services) */
.btn-solid{display:inline-flex;align-items:center;gap:12px;font-size:15px;padding:18px 38px;border-radius:100px;background:var(--panel-fg);color:var(--panel-bg);font-weight:500;transition:.45s var(--ease)}
.btn-solid i{transition:transform .45s var(--ease)}
.btn-solid:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.25)}
.btn-solid:hover i{transform:translate(4px,-4px)}
.btn-dark{border:1px solid var(--line);color:var(--black)}
.btn-dark:hover{background:var(--black);color:var(--paper)}
.btn-light i,.btn-dark i{transition:transform .45s var(--ease)}
.btn-light:hover i,.btn-dark:hover i{transform:translate(3px,-3px)}
.services-cta{padding:clamp(36px,5vh,56px) var(--gut) 0;display:flex;justify-content:center}

/* ░░ services page ░░ */
.services--page{margin-top:0;padding-top:clamp(20px,4vh,40px)}
.services--page .svc-list{border-top:1px solid var(--panel-line)}

/* ░░ méthode ░░ */
.method{padding:clamp(60px,10vh,140px) 0}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,60px);padding:0 var(--gut)}
.step{border-top:1px solid var(--black);padding-top:24px}
.step-n{font-family:var(--serif);font-size:14px;color:var(--ink-faint)}
.step-cat{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin:12px 0 14px}
.step h3{font-family:var(--serif);font-size:clamp(23px,2.8vw,34px);line-height:1.05;letter-spacing:-.01em;margin-bottom:14px}
.step p{color:var(--ink-dim);font-size:15.5px}

/* ░░ faq ░░ */
.faq{padding:clamp(60px,10vh,140px) 0;border-top:1px solid var(--line)}
.faq-list{padding:0 var(--gut);border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line);padding:clamp(22px,3.4vh,32px) 0;cursor:pointer}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:24px}
.faq-q h3{font-family:var(--serif);font-size:clamp(20px,2.8vw,32px);line-height:1.1;letter-spacing:-.01em;transition:opacity .4s}
.faq-item:hover .faq-q h3{opacity:.55}
.faq-plus{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;background:var(--black);transition:.4s var(--ease)}
.faq-plus::before{left:0;top:50%;width:100%;height:1.5px;transform:translateY(-50%)}
.faq-plus::after{top:0;left:50%;height:100%;width:1.5px;transform:translateX(-50%)}
.faq-item.open .faq-plus::after{transform:translateX(-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.faq-a p{color:var(--ink-dim);padding-top:16px;max-width:72ch}

/* ░░ portfolio gallery ░░ */
.gallery{padding:clamp(20px,4vh,50px) 0 clamp(50px,8vh,110px)}
.gallery .case{margin-bottom:clamp(46px,8vh,100px)}
.gallery .case:last-child{margin-bottom:0}

/* ░░ valeurs (à propos) ░░ */
.values{padding:clamp(60px,10vh,140px) 0;border-top:1px solid var(--line)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,60px);padding:0 var(--gut)}
.value{border-top:1px solid var(--black);padding-top:24px}
.value-n{font-family:var(--serif);font-size:14px;color:var(--ink-faint)}
.value h3{font-family:var(--serif);font-size:clamp(24px,3vw,38px);margin:14px 0 14px;letter-spacing:-.01em}
.value p{color:var(--ink-dim);font-size:15.5px}
.profile--page{border-top:none;padding-top:clamp(20px,3vh,40px)}
.about-sign{display:inline-block;font-family:var(--serif);font-style:italic;font-size:24px;margin-top:18px}

/* ░░ contact page ░░ */
.page-hero--contact{padding-bottom:clamp(30px,4vh,50px)}
.contact-page{display:grid;grid-template-columns:1.4fr .8fr;gap:clamp(34px,5vw,80px);padding:0 var(--gut) clamp(60px,10vh,140px);align-items:start}
.contact-form{display:flex;flex-direction:column;gap:24px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cf-field{display:flex;flex-direction:column;gap:9px}
.cf-field label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.cf-field input,.cf-field textarea,.cf-select select{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--black);font-family:var(--sans);font-size:16px;padding:12px 0;outline:none;transition:border-color .4s}
.cf-field input:focus,.cf-field textarea:focus,.cf-select select:focus{border-color:var(--black)}
.cf-field textarea{resize:vertical}
.cf-select{position:relative}
.cf-select::after{content:"↓";position:absolute;right:2px;top:12px;pointer-events:none;color:var(--ink-faint)}
.cf-select select{appearance:none;cursor:pointer}
.cf-submit{align-self:flex-start;margin-top:10px;display:inline-flex;align-items:center;gap:10px;background:var(--black);color:var(--paper);border:none;font-family:var(--sans);font-size:14px;padding:16px 32px;border-radius:100px;cursor:pointer;transition:.45s var(--ease)}
.cf-submit i{transition:transform .45s var(--ease)}
.cf-submit:hover{background:#000}
.cf-submit:hover i{transform:translate(3px,-3px)}
.cf-note{font-size:13px;color:var(--ink-dim);background:var(--paper-2);padding:14px 16px;border-radius:6px}
.contact-aside{display:flex;flex-direction:column;gap:30px;border-left:1px solid var(--line);padding-left:clamp(24px,3vw,44px)}
.ca-block h5{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
.ca-block a,.ca-block span{display:block;color:var(--ink-dim);font-size:15px;margin-bottom:6px;transition:color .3s;width:fit-content}
.ca-block a:hover{color:var(--black)}
.ca-mail{font-family:var(--serif);font-size:clamp(18px,2vw,24px)!important;color:var(--black)!important}

/* ░░ footer CTA ░░ */
.foot-cta{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;padding-bottom:clamp(40px,6vh,70px);border-bottom:1px solid var(--line);margin-bottom:40px}
.foot-cta-label{font-family:var(--serif);font-size:clamp(24px,3.4vw,44px);letter-spacing:-.01em}
.foot-cta-link{display:inline-flex;align-items:center;gap:10px;font-size:15px;border:1px solid var(--line);padding:15px 30px;border-radius:100px;transition:.45s var(--ease)}
.foot-cta-link i{transition:transform .45s var(--ease)}
.foot-cta-link:hover{background:var(--black);color:var(--paper)}
.foot-cta-link:hover i{transform:translate(3px,-3px)}

@media(max-width:760px){
  .steps,.values-grid{grid-template-columns:1fr;gap:34px}
  .contact-page{grid-template-columns:1fr;gap:40px}
  .cf-row{grid-template-columns:1fr}
  .contact-aside{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:34px}
  .foot-cta{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   AJOUTS : logos clients réels + avis (étoiles) + thème
   ============================================================ */

/* ░░ mur de logos clients ░░ */
.logos-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(30px,6vw,90px);max-width:1100px;margin:0 auto}
.logo-item{display:flex;align-items:center;justify-content:center;height:clamp(64px,8vw,104px)}
.logo-item img{width:auto;height:100%;max-width:240px;object-fit:contain;filter:var(--logo-filter)}
.logo-item img[src*="taxi-dimitri"]{height:128%;max-width:300px}

/* ░░ étoiles avis ░░ */
.testi-stars{font-size:15px;letter-spacing:.16em;color:var(--fg);opacity:.85}
.testi-card p{flex:1}

/* éviter le flash : init thème clair avant CSS chargé */
html[data-init-light] body{--bg:#f3f1ec;--bg-2:#e9e6df;--fg:#141414;--fg-dim:rgba(20,20,20,.56);--fg-faint:rgba(20,20,20,.34);--line:rgba(20,20,20,.14);--panel-bg:#141414;--panel-fg:#f3f1ec;--panel-fg-dim:rgba(243,241,236,.56);--panel-fg-faint:rgba(243,241,236,.32);--panel-line:rgba(243,241,236,.16);--logo-filter:invert(1)}

@media(max-width:760px){
  .logos-row{gap:34px 40px}
  .logo-item{height:54px}
  .theme-toggle{width:34px;height:34px}
}

/* ░░ PAGE MENTIONS LÉGALES ░░ */
.legal{padding:0 var(--gut) clamp(60px,10vh,140px);max-width:920px}
.legal-block{margin-bottom:clamp(36px,5vh,56px)}
.legal-block h2{font-family:var(--serif);font-size:clamp(22px,3vw,34px);letter-spacing:-.01em;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.legal-block p{color:var(--fg-dim);margin-bottom:14px;max-width:70ch}
.legal-block a{border-bottom:1px solid var(--line);transition:border-color .3s}
.legal-block a:hover{border-color:var(--fg)}
.legal-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:8px}
.legal-list li{display:grid;grid-template-columns:240px 1fr;gap:18px;padding-bottom:12px;border-bottom:1px solid var(--line);align-items:baseline}
.legal-list li span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint)}
.legal-list li b{font-weight:400;color:var(--fg)}
.legal-note{margin-top:30px;font-size:14px;color:var(--fg-faint);font-style:italic}
@media(max-width:680px){.legal-list li{grid-template-columns:1fr;gap:4px}}
