/* ============================================================
   EBII — feuille de style (Phase 2)
   Tokens & composants repris de la maquette « EBII - Accueil ».
   Polices auto-hébergées (souveraineté, aucun CDN).
   ============================================================ */

/* ---- Fonts (self-hosted woff2) ---- */
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/schibsted-grotesk-400.woff2') format('woff2')}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/schibsted-grotesk-500.woff2') format('woff2')}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/schibsted-grotesk-600.woff2') format('woff2')}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/schibsted-grotesk-700.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/jetbrains-mono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/jetbrains-mono-500.woff2') format('woff2')}

:root{
  --ink:#181d26; --body:#3a3f47; --muted:#72767e; --hairline:#e8e3da;
  --canvas:#fbfaf7; --soft:#f3efe6;
  --coral:#aa2d00; --forest:#0a2e0e; --cream:#f5e9d4; --navy:#181d26;
  --link:#1b61c9; --on-dark:#fbfaf7;
  --danger:#aa2d00; --success:#0a6b2e;
  --accent:#181d26; --accent-ink:#fbfaf7;
  --r-btn:999px; --r-card:18px; --r-input:10px;
  --font-display:'Schibsted Grotesk',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-body:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --sec-pad:104px; --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--canvas);color:var(--body);
  font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
h1,h2,h3{font-family:var(--font-display);color:var(--ink);font-weight:500;letter-spacing:-.02em;line-height:1.1;text-wrap:balance}
a{color:inherit;text-decoration:none}
.lead{font-size:18px;line-height:1.6;color:var(--body);margin-top:16px;max-width:42em}
.muted{color:var(--muted)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-body);font-size:15px;
  font-weight:500;padding:14px 26px;border-radius:var(--r-btn);border:1px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .25s ease,background .2s ease,border-color .2s ease;line-height:1}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:var(--accent-ink);
  box-shadow:0 1px 2px rgba(24,29,38,.18),0 6px 18px -8px rgba(24,29,38,.45)}
.btn-primary:hover{box-shadow:0 2px 4px rgba(24,29,38,.2),0 12px 28px -8px rgba(24,29,38,.5)}
.btn-secondary{background:transparent;color:var(--ink);border-color:var(--hairline)}
.btn-secondary:hover{border-color:var(--ink);background:rgba(24,29,38,.03)}
.btn-on-dark{background:var(--on-dark);color:var(--ink);box-shadow:none}
.btn-on-dark:hover{transform:translateY(-1px)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}
.linklike{background:none;border:none;font-family:var(--font-body);font-size:14px;color:var(--body);cursor:pointer;padding:0}
.linklike:hover{color:var(--ink)}
.linklike.danger{color:var(--danger)}
.inline-form{display:inline}

/* ---- nav ---- */
nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--canvas) 86%,transparent);
  backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--hairline)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:0 40px;height:66px;display:flex;align-items:center;gap:30px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;
  color:var(--ink);font-size:18px;letter-spacing:-.02em}
.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--ink);color:var(--canvas);
  display:grid;place-items:center;font-family:var(--font-mono);font-size:13px;font-weight:500}
.nav-links{display:flex;align-items:center;gap:24px;font-size:14px;color:var(--body)}
.nav-links a{position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.nav-cta{font-size:14px;font-weight:500;color:var(--ink)}
.nav-toggle{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{width:22px;height:2px;background:var(--ink);border-radius:2px}
.nav-mobile{display:none;flex-direction:column;gap:4px;padding:14px 40px 22px;border-bottom:1px solid var(--hairline);background:var(--canvas)}
.nav-mobile a{padding:9px 0;font-size:15px;color:var(--body)}
.nav-mobile a:hover{color:var(--ink)}
.nav-toggle:checked~.nav-mobile{display:flex}

/* language switcher */
.lang-switch{position:relative;font-family:var(--font-mono)}
.lang-switch>summary{list-style:none;cursor:pointer;font-size:12px;color:var(--muted);
  padding:6px 10px;border:1px solid var(--hairline);border-radius:8px}
.lang-switch>summary::-webkit-details-marker{display:none}
.lang-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--canvas);
  border:1px solid var(--hairline);border-radius:10px;padding:6px;display:grid;
  grid-template-columns:repeat(2,1fr);gap:2px;min-width:128px;box-shadow:0 12px 30px -12px rgba(24,29,38,.35);z-index:60}
.lang-menu a{font-size:12px;padding:6px 10px;border-radius:6px;color:var(--body)}
.lang-menu a:hover{background:var(--soft);color:var(--ink)}
.lang-menu a.current{color:var(--ink);font-weight:600}

/* ---- hero (single column, full width) ---- */
.hero{padding:calc(var(--sec-pad) * .92) 0 var(--sec-pad)}
.hero-copy{max-width:980px}
.hero h1{font-size:clamp(44px,5.8vw,72px);line-height:1.02;font-weight:500;margin:22px 0 0;letter-spacing:-.026em;max-width:21ch}
.hero .lead{font-size:19px;line-height:1.6;color:var(--body);margin-top:24px;max-width:42em}
.hero-cta{display:flex;gap:13px;margin-top:36px;flex-wrap:wrap}
.since{display:flex;align-items:center;gap:9px;margin-top:28px;font-size:13px;color:var(--muted);font-family:var(--font-mono)}
.since .dot{width:7px;height:7px;border-radius:50%;background:var(--forest)}

/* ---- audience strip ---- */
.audience{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:26px 0}
.audience-row{display:flex;align-items:center;gap:18px 30px;flex-wrap:wrap}
.audience-row .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.audience-row .v{font-size:15px;color:var(--ink);font-weight:500;font-family:var(--font-display)}
.audience-row .sep{color:var(--hairline)}

/* ---- generic section ---- */
section.band{padding:var(--sec-pad) 0}
.band.narrow .wrap{max-width:680px}
.sec-head{max-width:720px}
.sec-head h2{font-size:clamp(28px,3.4vw,42px);line-height:1.12;font-weight:500;margin-top:14px;letter-spacing:-.02em}
.sec-head p{font-size:17px;color:var(--body);margin-top:16px;line-height:1.6}
.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:36px}

/* ---- services grid ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:52px;
  background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-card);overflow:hidden}
.svc{background:var(--canvas);padding:32px 30px 36px;display:flex;flex-direction:column;gap:13px;min-height:190px;transition:box-shadow .2s ease,background .2s ease}
.svc:hover{background:var(--soft);box-shadow:inset 3px 0 0 var(--coral)}
.svc h3{font-size:20px;font-weight:500;letter-spacing:-.01em}
.svc p{font-size:14.5px;color:var(--body);line-height:1.55}

/* ---- approche (cream panel) ---- */
.approche{background:var(--cream);border-radius:var(--r-card);padding:56px 52px;margin-top:8px}
.approche h2{color:#16261a;font-size:clamp(26px,3.2vw,38px);font-weight:500;margin-top:14px;letter-spacing:-.02em}
.appr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:44px}
.appr{border-top:2px solid rgba(10,46,14,.18);padding-top:18px}
.appr h3{font-size:21px;color:#1d2b1f;font-weight:500;margin-bottom:10px}
.appr p{font-size:15px;color:#3f4a40;line-height:1.6}

/* ---- produits — signature cards ---- */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.prod{border-radius:var(--r-card);padding:34px 30px 30px;display:flex;flex-direction:column;min-height:340px;color:var(--on-dark);position:relative;overflow:hidden}
.prod.coral{background:var(--coral)}
.prod.forest{background:var(--forest)}
.prod.navy{background:var(--navy)}
.prod .av{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;background:#fff;margin-bottom:auto;overflow:hidden;box-shadow:0 2px 10px -4px rgba(0,0,0,.3)}
.prod .av img{width:100%;height:100%;object-fit:contain;padding:8px;display:block}
.prod h3{color:var(--on-dark);font-size:24px;font-weight:500;margin-top:26px;letter-spacing:-.01em}
.prod .tag{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(251,250,247,.62);margin-top:9px}
.prod p{font-size:14.5px;color:rgba(251,250,247,.82);line-height:1.6;margin-top:16px}
.prod .lk{margin-top:20px;font-size:14px;font-weight:500;color:var(--on-dark);display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);opacity:.92}
.prod .lk:hover{opacity:1}
.prod-go{position:absolute;inset:0;z-index:1;border-radius:inherit}
.prod-go:focus-visible{outline:2px solid var(--on-dark);outline-offset:-5px}
.prod .lk{position:relative;z-index:2}

/* ---- technologies ---- */
.tech-strip{margin-top:46px;display:flex;flex-wrap:wrap;gap:12px}
.tech-strip .t{font-family:var(--font-mono);font-size:13.5px;color:var(--body);padding:11px 18px;
  border:1px solid var(--hairline);border-radius:999px;background:var(--canvas);transition:.2s}
.tech-strip .t:hover{border-color:var(--ink);color:var(--ink)}

/* ---- cta band ---- */
.cta-band{background:var(--navy);border-radius:var(--r-card);padding:72px 60px;text-align:center;position:relative;overflow:hidden;margin-top:8px}
.cta-band h2{color:var(--on-dark);font-size:clamp(30px,3.6vw,46px);font-weight:500;margin-top:14px;max-width:16em;margin-left:auto;margin-right:auto;line-height:1.1}
.cta-band p{color:rgba(251,250,247,.78);font-size:17px;margin:18px auto 0;max-width:34em}
.cta-band .btn-wrap{margin-top:34px}

/* ---- footer ---- */
footer{border-top:1px solid var(--hairline);padding:72px 0 40px;margin-top:var(--sec-pad)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-brand p{font-size:14px;color:var(--muted);line-height:1.65;margin-top:16px;max-width:30em}
.foot-col h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:500}
.foot-col a{display:block;font-size:14.5px;color:var(--body);padding:5px 0}
.foot-col a:hover{color:var(--ink)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  margin-top:54px;padding-top:26px;border-top:1px solid var(--hairline);font-size:13px;color:var(--muted)}
.foot-bot .right{font-family:var(--font-mono);letter-spacing:.04em}
.foot-legal{display:flex;gap:18px;flex-wrap:wrap}
.foot-legal a{color:var(--muted)}
.foot-legal a:hover{color:var(--ink)}

/* ---- pages légales ---- */
.legal-body{line-height:1.7;color:var(--body)}
.legal-body h2{font-size:20px;font-weight:500;margin:30px 0 10px}
.legal-body p{margin:0 0 14px}
.legal-body ul{margin:0 0 14px;padding-left:1.3em}
.legal-body li{margin:4px 0}

/* ============================================================
   Outil de partage de fichiers + admin (Phase 1)
   ============================================================ */
.card{background:#fff;border:1px solid var(--hairline);border-radius:var(--r-card);padding:30px;margin-top:24px}
.form{display:flex;flex-direction:column;gap:8px}
.form label{font-size:13px;font-weight:500;color:var(--ink);margin-top:12px}
.form label:first-of-type{margin-top:0}
.form input,.form select,.form textarea{font-family:var(--font-body);font-size:15px;color:var(--ink);background:var(--canvas);
  border:1px solid var(--hairline);border-radius:var(--r-input);padding:12px 14px;width:100%}
.form textarea{min-height:140px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--link);box-shadow:0 0 0 3px rgba(27,97,201,.12)}
.form .btn{margin-top:20px;align-self:flex-start}
.alert{border-radius:12px;padding:14px 16px;margin-top:20px;font-size:14.5px}
.alert.error{background:rgba(170,45,0,.08);color:var(--danger);border:1px solid rgba(170,45,0,.2)}
.alert.success{background:rgba(10,107,46,.08);color:var(--success);border:1px solid rgba(10,107,46,.2)}
.file-list{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:12px}
.file-row{display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:#fff;border:1px solid var(--hairline);border-radius:14px;padding:16px 20px}
.file-meta{display:flex;flex-direction:column;gap:3px;min-width:0}
.file-name{font-weight:500;color:var(--ink);word-break:break-all}
.file-size{font-family:var(--font-mono);font-size:12px;color:var(--muted)}
.table-wrap{overflow-x:auto;margin-top:8px}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);font-weight:500;padding:12px 14px;border-bottom:1px solid var(--hairline)}
.table td{padding:14px;border-bottom:1px solid var(--hairline);color:var(--body)}
.badge{display:inline-block;font-family:var(--font-mono);font-size:11px;padding:3px 9px;border-radius:999px;border:1px solid var(--hairline)}
.badge.active{color:var(--success);border-color:rgba(10,107,46,.3)}
.badge.expired{color:var(--muted)}
.badge.admin{color:var(--coral);border-color:rgba(170,45,0,.3)}
.token{font-family:var(--font-mono);font-size:16px;background:var(--soft);color:var(--ink);
  padding:16px;border-radius:12px;margin:12px 0;word-break:break-all;user-select:all}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}

/* ---- Phase 3 : édition wiki inline (affordances admin uniquement) ---- */
.ebii-editable{position:relative;cursor:pointer;border-radius:4px;
  transition:box-shadow .15s ease,background .15s ease}
.ebii-editable:hover{box-shadow:0 0 0 2px var(--link);background:rgba(27,97,201,.07)}
.ebii-editable:focus-visible{outline:2px solid var(--link);outline-offset:2px}
.ebii-editable::after{content:"✎";position:absolute;top:-9px;right:-9px;z-index:5;
  width:18px;height:18px;display:none;place-items:center;border-radius:50%;
  font-size:11px;line-height:1;background:var(--link);color:#fff;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.ebii-editable:hover::after{display:grid}
.ebii-edit-form{display:block;margin:8px 0}
.ebii-edit-form textarea{width:100%;min-height:96px;font-family:var(--font-mono);font-size:14px;
  line-height:1.5;color:var(--ink);background:#fff;border:1px solid var(--hairline);
  border-radius:var(--r-input);padding:12px 14px;resize:vertical}
.ebii-edit-form textarea:focus{outline:none;border-color:var(--link);
  box-shadow:0 0 0 3px rgba(27,97,201,.16)}
.ebii-edit-actions{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.ebii-edit-actions .btn{padding:9px 18px;font-size:14px}
.ebii-edit-hint{font-family:var(--font-mono);font-size:11.5px;color:var(--muted)}
.contact-mail{margin-top:24px}

/* ---- éditions : portraits applicatifs (onglets HTMX) ---- */
.ed-app{margin-top:48px}
.ed-inner.coral{--pf-accent:var(--coral)}
.ed-inner.forest{--pf-accent:var(--forest)}
.ed-inner.navy{--pf-accent:var(--navy)}
.ed-tabs{display:flex;flex-wrap:wrap;gap:6px;border-bottom:1px solid var(--hairline)}
.ed-tab{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--muted);
  padding:13px 20px;border-radius:10px 10px 0 0;position:relative;cursor:pointer;
  transition:color .2s ease,background .2s ease}
.ed-tab:hover{color:var(--ink);background:var(--soft)}
.ed-tab.is-active{color:var(--ink)}
.ed-tab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:var(--pf-accent,var(--ink))}
.ed-portrait{background:var(--soft);border:1px solid var(--hairline);border-top:none;
  border-radius:0 0 var(--r-card) var(--r-card);padding:40px 40px 36px}
.ed-pf-head{display:flex;align-items:center;gap:16px}
.ed-pf-logo{width:52px;height:52px;flex:none;border-radius:13px;background:#fff;overflow:hidden;
  display:grid;place-items:center;box-shadow:0 2px 10px -4px rgba(24,29,38,.3)}
.ed-pf-logo img{width:100%;height:100%;object-fit:contain;padding:8px}
.ed-pf-id h2{font-size:24px;font-weight:500;color:var(--ink);letter-spacing:-.01em}
.ed-pf-id .tag{display:block;margin-top:4px;font-family:var(--font-mono);font-size:11.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--pf-accent)}
.ed-pf-lead{margin-top:18px;max-width:62ch;font-size:16px;line-height:1.6;color:var(--body)}
.ed-pf-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px 44px;margin-top:30px}
.ed-pf-block h3{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted)}
.ed-pf-block ul{list-style:none;margin-top:13px;display:flex;flex-direction:column;gap:9px}
.ed-pf-block li{position:relative;padding-left:18px;font-size:14.5px;line-height:1.55;color:var(--body)}
.ed-pf-block li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;
  border-radius:50%;background:var(--pf-accent)}
.ed-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px}
.ed-chips span{font-family:var(--font-mono);font-size:12px;color:var(--ink);background:#fff;
  border:1px solid var(--hairline);border-radius:999px;padding:5px 12px}
.ed-pf-block .lk{display:inline-flex;align-items:center;gap:7px;margin-top:13px;
  font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--pf-accent);
  transition:gap .2s ease}
.ed-pf-block .lk:hover{gap:11px}
@media(max-width:760px){
  .ed-app{margin-top:36px}
  .ed-pf-grid{grid-template-columns:1fr;gap:26px}
  .ed-portrait{padding:30px 24px}
  .ed-tab{padding:11px 15px;font-size:13px}
}

/* ---- section rhythm + micro-interactions ---- */
.band.tint{background:var(--soft)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1.5px;background:var(--ink);transition:right .25s ease}
.nav-links a:hover::after{right:0}
.prod{transition:transform .25s ease,box-shadow .3s ease}
.prod:hover{transform:translateY(-4px);box-shadow:0 30px 60px -34px rgba(24,29,38,.55)}
.prod .lk{transition:gap .2s ease,opacity .2s ease}
.prod:hover .lk{gap:11px}
@media (prefers-reduced-motion: no-preference){
  @supports (animation-timeline: view()){
    .sec-head,.svc-grid,.approche,.prod-grid,.tech-strip,.cta-band,.card,.file-list{
      animation:ebii-reveal linear both;animation-timeline:view();animation-range:entry 2% entry 26%}
    @keyframes ebii-reveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
  }
}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .nav-links{display:none}
  .hamburger{display:flex}
}
@media(max-width:900px){ .svc-grid{grid-template-columns:1fr 1fr} }
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .prod-grid{grid-template-columns:1fr}
  .prod{min-height:auto}
}
@media(max-width:820px){ .foot-grid{grid-template-columns:1fr 1fr;gap:34px} }
@media(max-width:760px){
  .wrap,.nav-in{padding-left:20px;padding-right:20px}
  .nav-mobile{padding-left:20px;padding-right:20px}
  .appr-grid{grid-template-columns:1fr;gap:32px}
  .approche{padding:40px 28px}
  :root{--sec-pad:72px}
}
@media(max-width:620px){ .svc-grid{grid-template-columns:1fr} .cta-band{padding:48px 26px} }

/* ============================================================
   Page « Votre projet » (argumentaire + formulaire de devis)
   ============================================================ */
.projet-badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;
  letter-spacing:.04em;color:var(--ink);background:var(--cream);border:1px solid var(--hairline);
  border-radius:999px;padding:7px 15px}
.projet-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--forest)}
.projet-hero h1{margin-top:20px}
.projet-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:46px;
  background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-card);overflow:hidden}
.projet-stats .stat{background:var(--canvas);padding:24px 22px;display:flex;flex-direction:column;gap:4px}
.projet-stats .stat strong{font-family:var(--font-display);font-size:30px;font-weight:500;color:var(--ink);letter-spacing:-.02em}
.projet-stats .stat span{font-size:13.5px;color:var(--muted)}

/* méthode — 4 étapes */
.projet-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:52px}
.projet-step{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-card);padding:30px 28px 26px}
.projet-step .num{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--ink);color:var(--canvas);font-family:var(--font-mono);font-size:15px}
.projet-step h3{font-size:19px;font-weight:500;margin:18px 0 8px}
.projet-step p{font-size:14.5px;color:var(--body);line-height:1.55}
.projet-step .tag{display:inline-block;margin-top:14px;font-family:var(--font-mono);font-size:11.5px;
  letter-spacing:.06em;color:var(--coral);background:var(--cream);border-radius:999px;padding:4px 12px}
.projet-step.is-final{border-color:rgba(10,107,46,.35)}
.projet-step.is-final .num{background:var(--success)}
.projet-step.is-final .tag{color:var(--success);background:rgba(10,107,46,.08)}

/* galerie d'exemples */
.projet-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.projet-card{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-card);
  padding:26px 24px;transition:transform .2s ease,box-shadow .25s ease,border-color .2s ease}
.projet-card:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:0 20px 40px -28px rgba(24,29,38,.5)}
.projet-card .ic{font-size:26px;line-height:1;margin-bottom:14px}
.projet-card h3{font-size:17px;font-weight:500;margin-bottom:7px}
.projet-card p{font-size:14px;color:var(--body);line-height:1.55}

/* formulaire « Votre projet » */
.pf-wrap{max-width:780px;margin:0 auto}
.pf-form{display:flex;flex-direction:column;margin-top:24px}
.pf-form input,.pf-form select,.pf-form textarea{font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-input);padding:12px 14px;width:100%}
.pf-form textarea{min-height:120px;resize:vertical}
.pf-form input:focus,.pf-form select:focus,.pf-form textarea:focus{outline:none;border-color:var(--link);box-shadow:0 0 0 3px rgba(27,97,201,.12)}
.pf-label{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--coral);margin:30px 0 4px;padding-top:18px;border-top:1px solid var(--hairline)}
.pf-form>.pf-label:first-of-type{border-top:none;padding-top:0;margin-top:6px}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pf-field{display:flex;flex-direction:column;margin-top:14px}
.pf-field label{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:6px}
.pf-field .opt{color:var(--muted);font-weight:400}
.pf-form .btn{margin-top:26px;align-self:flex-start}
.pf-note{margin-top:14px;font-size:13px}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.pf-success{text-align:center;padding:48px 30px}
.pf-success .ic{width:64px;height:64px;margin:0 auto 18px;display:grid;place-items:center;border-radius:50%;
  background:rgba(10,107,46,.1);color:var(--success);font-size:30px}
.pf-success h2{font-size:26px;font-weight:500;margin-bottom:10px}
.pf-success p{font-size:16px;color:var(--body);line-height:1.6;max-width:46ch;margin:0 auto}

@media(max-width:880px){
  .projet-stats{grid-template-columns:repeat(2,1fr)}
  .projet-gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .projet-steps{grid-template-columns:1fr}
  .projet-gallery{grid-template-columns:1fr}
  .pf-row{grid-template-columns:1fr;gap:0}
}
