:root{
  --night:#050723;
  --night-2:#0a0d37;
  --ink:#151521;
  --muted:#6f7187;
  --line:rgba(5,7,35,.14);
  --line-on-dark:rgba(255,255,255,.16);
  --cobalt:#1238ff;
  --cobalt-2:#315cff;
  --orange:#ff5b22;
  --apricot:#ff9a72;
  --pink:#f5a6cf;
  --pink-2:#ffd3e8;
  --olive:#a3a83d;
  --leaf:#d6e45c;
  --cream:#fff7ef;
  --cream-2:#fffaf4;
  --white:#ffffff;
  --success:#16a34a;
  --danger:#dc2626;
  --apricot-light:#ffc8b6;
  --olive-deep:#596000;
  --footer-bg:#020416;
  --cobalt-soft:#6f8cff;
  --shadow:0 28px 80px rgba(5,7,35,.24);
  --radius:8px;
  --radius-lg:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{margin:0;padding-top:72px;background:var(--cream);color:var(--ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  min-height:72px;
  padding:16px clamp(20px,4vw,56px);
  background:rgba(255,247,239,.88);
  border-bottom:1px solid rgba(5,7,35,.08);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  box-shadow:0 1px 0 rgba(5,7,35,.04),0 8px 24px -16px rgba(5,7,35,.08);
}
.logo{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:Archivo,sans-serif;
  font-size:26px;
  font-weight:900;
  letter-spacing:-.035em;
}
.logo-mark{
  width:34px;
  height:34px;
  border-radius:10px;
  background:url("outputs/forhia-brand-assets/forhia-mark.svg") center/cover no-repeat;
  box-shadow:0 12px 28px rgba(18,56,255,.24);
}
.logo-dot{color:var(--orange)}
.nav-links{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.nav-links a{
  padding:8px 10px;
  border-radius:999px;
  color:#4f5166;
}
.nav-links a:hover,.nav-links a.active{background:rgba(255,91,34,.12);color:var(--orange)}
.nav-actions{display:flex;gap:10px;align-items:center}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:inherit;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:850;
  white-space:nowrap;
  cursor:pointer;
}
.primary{background:var(--cobalt);color:var(--white);box-shadow:0 18px 40px rgba(18,56,255,.18)}
.orange{background:var(--orange);color:var(--white)}
.ghost{border-color:rgba(5,7,35,.12);background:rgba(255,255,255,.56)}
.hero{
  position:relative;
  overflow:hidden;
  min-height:620px;
  display:grid;
  align-items:end;
  padding:118px clamp(20px,5vw,64px) 64px;
  background:
    linear-gradient(90deg,rgba(5,7,35,.92),rgba(5,7,35,.62) 54%,rgba(5,7,35,.12)),
    radial-gradient(circle at 14% 16%,rgba(245,166,207,.52),transparent 26%),
    radial-gradient(circle at 80% 10%,rgba(255,91,34,.72),transparent 27%),
    radial-gradient(circle at 60% 72%,rgba(18,56,255,.92),transparent 34%),
    var(--night);
  color:var(--white);
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:linear-gradient(rgba(255,255,255,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.18) 1px,transparent 1px);
  background-size:52px 52px;
  opacity:.28;
}
.hero-inner{position:relative;z-index:1;max-width:1060px}
.breadcrumb{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:28px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  color:rgba(255,255,255,.62);
  text-transform:uppercase;
}
.breadcrumb a{color:var(--leaf)}
.kicker{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--cobalt);
  margin-bottom:18px;
}
.dark .kicker,.hero .kicker{color:var(--leaf)}
h1,h2,h3,p{margin:0}
h1{
  max-width:980px;
  font-family:Archivo,sans-serif;
  font-size:clamp(38px,5.2vw,72px);
  line-height:.86;
  letter-spacing:-.035em;
  font-weight:900;
}
.hero p{
  max-width:760px;
  margin-top:26px;
  color:rgba(255,255,255,.74);
  font-size:21px;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
.dot-blue{color:var(--cobalt)}.dot-orange,.hero h1 .dot-orange{color:var(--orange)}.dot-pink{color:var(--pink)}.dot-leaf{color:var(--leaf)}
.product-dot{
  display:inline-block;
  width:.22em;
  height:.22em;
  margin-left:.08em;
  border-radius:2px;
  vertical-align:baseline;
}
.product-dot.blue{background:var(--cobalt)}
.product-dot.orange{background:var(--orange)}
.product-dot.pink{background:var(--pink)}
.product-dot.leaf{background:var(--leaf)}
.section{padding:84px clamp(20px,5vw,64px);scroll-margin-top:138px}
.section-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,520px);
  gap:34px;
  align-items:end;
  margin-bottom:28px;
}
.section h2{
  font-family:Archivo,sans-serif;
  font-size:clamp(38px,5.2vw,72px);
  line-height:.86;
  letter-spacing:-.035em;
  font-weight:900;
}
.section-head p,.card p,.route p,.metric p{color:var(--muted);font-size:16px}
.dark{background:var(--night);color:var(--white)}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g3{grid-template-columns:repeat(3,minmax(0,1fr))}
.g4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card,.route,.metric{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--white);
  padding:24px;
}
.dark .card,.dark .route,.dark .metric{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.dark .card p,.dark .route p,.dark .metric p{color:rgba(255,255,255,.68)}
.card small,.route small,.metric small{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--cobalt);
}
.dark small{color:var(--leaf)}
.card h3,.route h3{
  margin:22px 0 12px;
  font-family:Archivo,sans-serif;
  font-size:34px;
  line-height:.9;
  letter-spacing:-.025em;
}
.card ul{
  display:grid;
  gap:10px;
  margin:18px 0 0;
  padding:0;
  list-style:none;
  color:var(--muted);
}
.dark .card ul{color:rgba(255,255,255,.68)}
.card li:before{
  content:"";
  display:inline-block;
  width:8px;
  height:8px;
  margin-right:10px;
  border-radius:999px;
  background:var(--leaf);
}
.metric b{
  display:block;
  margin:14px 0 8px;
  font-family:Archivo,sans-serif;
  font-size:52px;
  line-height:.85;
  letter-spacing:-.035em;
  color:var(--orange);
}
.route{
  min-height:260px;
  display:flex;
  flex-direction:column;
}
.route .btn{margin-top:auto;width:max-content}
.product-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--line);
}
.product-strip a{
  display:block;
  min-height:160px;
  background:var(--white);
  padding:22px;
}
.product-strip b{
  display:block;
  margin-top:18px;
  font-family:Archivo,sans-serif;
  font-size:32px;
  letter-spacing:-.025em;
  line-height:.9;
}
.product-strip span{
  display:block;
  margin-top:8px;
  color:var(--muted);
  font-size:14px;
}
.cta-band{
  margin-top:34px;
  border-radius:var(--radius-lg);
  background:var(--orange);
  color:var(--white);
  padding:30px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
}
.cta-band p{margin-top:10px;color:rgba(255,255,255,.76)}
.cta-band h3{
  font-family:Archivo,sans-serif;
  font-size:clamp(30px,3.5vw,46px);
  line-height:.9;
  letter-spacing:-.035em;
  font-weight:900;
}
.contact-form{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--white);
  padding:24px;
}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form input,.contact-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--cream-2);
  color:var(--ink);
  padding:14px;
  font:inherit;
  outline:0;
}
.contact-form input:focus-visible,.contact-form textarea:focus-visible{
  border-color:var(--cobalt);
  box-shadow:0 0 0 3px rgba(18,56,255,.16);
}
.honeypot{position:absolute;left:-9999px;height:0;width:0;opacity:0;pointer-events:none}
.form-status{margin-top:14px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.form-status.ok{color:var(--success)}
.form-status.err{color:var(--danger)}
.contact-form textarea{min-height:110px;resize:vertical;margin-top:12px}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(21,21,33,.42)}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.footer{
  padding:50px clamp(20px,5vw,64px) 28px;
  background:var(--footer-bg);
  color:rgba(255,255,255,.68);
}
.footer-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) repeat(3,minmax(150px,.42fr));
  gap:34px;
}
.footer h4{
  margin:0 0 14px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  color:rgba(255,255,255,.42);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.footer ul{display:grid;gap:10px;margin:0;padding:0;list-style:none}
.footer a{color:rgba(255,255,255,.76)}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  margin-top:36px;
  padding-top:22px;
  border-top:1px solid rgba(255,255,255,.12);
}
@media(max-width:1120px){
  .nav-links a{font-size:13px;padding:8px 8px}
  .g4,.product-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:980px){
  .nav{flex-wrap:wrap}
  .nav-links{
    order:3;
    display:flex;
    width:100%;
    overflow-x:auto;
    padding-bottom:2px;
    scrollbar-width:none;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-actions .ghost{display:none}
}
@media(max-width:820px){
  .section-head,.g2,.g3,.g4,.product-strip,.cta-band,.field-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:auto;padding-top:24px}
  .footer-bottom{flex-direction:column}
}

/* ===== FOCUS VISIBLE A11y ===== */
*:focus-visible{outline:2px solid var(--cobalt);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline-offset:3px}

/* ===== FOOTER LEGAL COLUMN ===== */
.footer-grid{grid-template-columns:minmax(0,1.1fr) repeat(4,minmax(140px,.42fr))}
@media(max-width:1120px){.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr}}
.footer .legal-list a:hover{color:var(--white)}

/* ===== PAGE LEGAL STUB ===== */
.legal-page{padding:56px clamp(20px,5vw,64px) 96px;background:var(--cream)}
.legal-page h1{font-family:Archivo,sans-serif;font-size:clamp(38px,5.2vw,72px);line-height:.86;letter-spacing:-.035em;font-weight:900;margin:0 0 24px}
.legal-page h2{font-family:Archivo,sans-serif;font-size:clamp(24px,2.8vw,32px);line-height:1;letter-spacing:-.025em;margin:32px 0 14px}
.legal-page p,.legal-page li{color:var(--ink);font-size:15px;line-height:1.6;margin:0 0 12px}
.legal-page ul{padding-left:22px;margin:0 0 14px}
.legal-page .updated{font-family:"JetBrains Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:8px;display:block}
.legal-page .legal-inner{max-width:880px;margin:0 auto}

/* ===== RAPPORT SCAN — namespace .report-* ===== */
.report-shell{padding:48px clamp(20px,5vw,64px) 64px;background:var(--cream)}
.report-top{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:42px;border-bottom:1px solid var(--line);padding-bottom:24px}
.report-top small,.report-section-label{font-family:"JetBrains Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:rgba(5,7,35,.58)}
.report-top h1{margin-top:14px;font-family:Archivo,sans-serif;font-size:clamp(38px,6vw,72px);line-height:.88;letter-spacing:-.035em}
.report-top .muted-title{color:rgba(5,7,35,.48)}
.report-top p{max-width:760px;margin-top:18px;color:var(--muted)}
.report-block{padding:42px 0;border-bottom:1px solid var(--line)}
.report-section-label{display:flex;justify-content:space-between;gap:16px;margin-bottom:24px}
.report-title{font-family:Archivo,sans-serif;font-size:clamp(32px,4.4vw,58px);line-height:.9;letter-spacing:-.035em;margin-bottom:22px}
.report-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border:1px solid var(--line);background:rgba(5,7,35,.12);gap:1px}
.report-metric{background:var(--white);padding:26px}
.report-metric small,.mini-label{font-family:"JetBrains Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:rgba(5,7,35,.52)}
.report-metric b{display:block;margin-top:12px;font-family:Archivo,sans-serif;font-size:72px;line-height:.85;letter-spacing:-.035em;color:var(--cobalt)}
.report-metric b .unit{font-size:28px}
.report-metric b .pct{font-size:38px}
.report-metric:nth-child(2) b{color:var(--orange)}
.report-metric:nth-child(3) b{color:var(--olive)}
.report-metric p{margin-top:14px;color:var(--muted);font-size:14px}
.report-note{margin-top:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);padding:20px;color:var(--muted)}
.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.report-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--white);padding:22px}
.report-card h3{font-family:Archivo,sans-serif;font-size:30px;line-height:.92;letter-spacing:-.025em;margin:14px 0 10px}
.report-card p,.report-card li{color:var(--muted);font-size:14px}
.report-card ul{display:grid;gap:9px;margin:14px 0 0;padding:0;list-style:none}
.report-card li:before{content:"";display:inline-block;width:8px;height:8px;margin-right:10px;border-radius:2px;background:var(--orange)}
.risk-ok{border-top:3px solid var(--success);background:var(--white);padding:28px}
.risk-ok h3{font-family:Archivo,sans-serif;font-size:34px;line-height:.95;letter-spacing:-.025em;margin:12px 0}
.risk-ok .mini-label{color:var(--success)}
.risk-ok .accent{color:var(--success)}
.axis-list{display:grid;gap:12px}
.axis{display:grid;grid-template-columns:130px 1fr 48px;align-items:center;gap:14px}
.bar{height:8px;border-radius:999px;background:rgba(5,7,35,.08);position:relative;overflow:hidden}
.bar i{position:absolute;left:50%;top:0;height:100%;border-radius:999px;background:var(--success)}
.axis.neg .bar i{right:50%;left:auto;background:var(--danger)}
.axis b{font-family:Archivo,sans-serif;color:var(--success)}
.axis.neg b{color:var(--danger)}
.bar.w6 i{width:6%}.bar.w3 i{width:2.5%}.bar.w12 i{width:12%}.bar.w8 i{width:8%}
.source-list{display:grid;gap:1px;border:1px solid var(--line);background:var(--line);border-radius:var(--radius);overflow:hidden}
.source-row{display:grid;grid-template-columns:54px 1fr 86px 76px;gap:12px;align-items:center;background:var(--white);padding:14px}
.quote{border-left:3px solid var(--orange);background:var(--white);padding:18px;color:var(--muted);font-style:italic}
@media(max-width:980px){.report-shell{padding-top:48px}.report-top{display:block}.report-metrics,.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.source-row{grid-template-columns:42px 1fr}}
@media(max-width:720px){.report-metrics,.report-grid{grid-template-columns:1fr}.axis{grid-template-columns:1fr}.source-row{grid-template-columns:1fr}}

/* ===== SCAN PANEL LOADING (dashboard demo home) ===== */
.scanPanel.loading{position:relative;opacity:.7;pointer-events:none}
.scanPanel.loading::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);background-size:200% 100%;animation:scan-shimmer 1.4s infinite;pointer-events:none}
@keyframes scan-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== HOMEPAGE — sections specifiques ===== */
.site{overflow:hidden;min-height:100vh}
img{display:block;max-width:100%}
button,input{font:inherit}

/* Homepage hero override (2-column layout with product shell) */
.site .hero{
  grid-template-columns:minmax(0,.95fr) minmax(480px,1.05fr);
  align-items:center;
  gap:clamp(32px,5vw,72px);
  isolation:isolate;
}
.site .hero:before{
  z-index:-1;
  pointer-events:none;
  mask-image:linear-gradient(90deg,var(--night),rgba(0,0,0,.86),transparent 92%);
}
.site .hero > *{position:relative;z-index:1}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  color:rgba(255,255,255,.76);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.eyebrow:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--leaf);
  box-shadow:0 0 24px var(--leaf);
}
.site h1{margin-top:30px}
.hero-lead{
  max-width:650px;
  margin-top:28px;
  font-size:clamp(18px,2vw,23px);
  color:rgba(255,255,255,.76);
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
.hero-cta .btn.ghost.on-dark,
.band .btn.ghost.on-dark,
.form-card .btn.ghost.on-dark{
  color:var(--white);
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.08);
}
.band .btn.ghost.on-dark{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.28)}
.trust-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  max-width:640px;
  margin-top:50px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.15);
}
.trust-row div{background:rgba(5,7,35,.42);padding:16px}
.trust-row b{display:block;font-family:Archivo,sans-serif;font-size:24px;letter-spacing:-.025em}
.trust-row span{display:block;margin-top:4px;font-family:"JetBrains Mono",monospace;font-size:10px;color:rgba(255,255,255,.54);text-transform:uppercase}

/* Product shell (mock dashboard) */
.product-shell{
  position:relative;
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  background:rgba(255,255,255,.09);
  box-shadow:var(--shadow);
  backdrop-filter:blur(20px);
  overflow:hidden;
}
.app-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-height:58px;
  padding:18px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.window-dots{display:flex;gap:7px}
.window-dots span{width:10px;height:10px;border-radius:999px;background:rgba(255,255,255,.34)}
.app-tag{
  display:flex;
  align-items:center;
  min-height:20px;
  padding-top:1px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  line-height:1.2;
  color:rgba(255,255,255,.58);
  text-transform:uppercase;
  white-space:nowrap;
}
.scan-panel{padding:22px}
.scan-input{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  padding:10px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  background:rgba(5,7,35,.42);
}
.scan-input input{
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--white);
  padding:0 10px;
}
.scan-input input::placeholder{color:rgba(255,255,255,.4)}
.models{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}
.model{
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.66);
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  cursor:pointer;
}
.model.active{background:var(--leaf);color:var(--night);border-color:var(--leaf)}
.query-list{display:grid;gap:10px;margin-top:15px;transition:opacity .2s ease}
.scan-loader{
  display:none;
  align-items:center;
  gap:10px;
  margin-top:14px;
  padding:11px 12px;
  border:1px solid rgba(214,228,92,.28);
  border-radius:10px;
  background:rgba(214,228,92,.08);
  color:var(--leaf);
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
}
.scan-panel.loading .scan-loader{display:flex}
.scan-loader i{
  width:13px;
  height:13px;
  border-radius:50%;
  border:2px solid rgba(214,228,92,.28);
  border-top-color:var(--leaf);
  animation:spin .75s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.query{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:10px;
  background:rgba(255,255,255,.06);
}
.query b{display:block;font-size:13px}
.query span{display:block;margin-top:3px;font-size:12px;color:rgba(255,255,255,.52)}
.badge{
  padding:6px 8px;
  border-radius:999px;
  background:rgba(255,91,34,.18);
  color:var(--apricot-light);
  font-family:"JetBrains Mono",monospace;
  font-size:10px;
  white-space:nowrap;
}

/* Sections (homepage spacing override) */
.site .section{padding:96px clamp(20px,4vw,56px)}
.section.blue{
  background:
    radial-gradient(circle at 100% 8%,rgba(255,91,34,.45),transparent 24%),
    radial-gradient(circle at 0% 84%,rgba(245,166,207,.25),transparent 28%),
    var(--cobalt);
  color:var(--white);
}
.site .section-head{
  grid-template-columns:minmax(0,.85fr) minmax(300px,.5fr);
  margin-bottom:44px;
}
.blue .kicker{color:var(--leaf)}
.section-head p{font-size:18px}
.dark .section-head p,.blue .section-head p{color:rgba(255,255,255,.72)}

/* Accents */
.accent-blue{color:var(--cobalt-soft)}
.accent-orange{color:var(--orange)}
.accent-pink{color:var(--pink)}
.accent-leaf{color:var(--leaf)}

/* Cards on homepage (slightly different background for cream sections) */
.site .card{background:rgba(255,255,255,.66);padding:24px}
.site .dark .card,.site .blue .card{
  border-color:var(--line-on-dark);
  background:rgba(255,255,255,.08);
}
.site .card h3{
  font-family:Archivo,sans-serif;
  font-size:28px;
  line-height:.96;
  letter-spacing:-.035em;
  margin-bottom:12px;
}
.site .card p{color:var(--muted)}
.site .dark .card p,.site .blue .card p{color:rgba(255,255,255,.68)}

/* Platform statement */
.platform-lead{
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(360px,1fr);
  gap:28px;
  align-items:stretch;
  margin-bottom:20px;
}
.platform-statement{
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.08);
  padding:30px;
}
.platform-statement h3{
  font-family:Archivo,sans-serif;
  font-size:clamp(38px,4vw,58px);
  line-height:.9;
  letter-spacing:-.035em;
  margin:0 0 18px;
}
.platform-statement p{color:rgba(255,255,255,.72);font-size:17px}

/* Steps */
.steps{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--line);
}
.step{background:var(--white);padding:20px;min-height:150px}
.step b{display:block;font-family:Archivo,sans-serif;font-size:25px;line-height:1;letter-spacing:-.025em}
.step span{display:block;margin-top:9px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);text-transform:uppercase}

/* Position cards */
.position-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-top:18px;
}
.position-card{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:20px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.72);
  padding:24px;
}
.position-card .index{
  font-family:Archivo,sans-serif;
  font-size:48px;
  line-height:.86;
  letter-spacing:-.035em;
  color:var(--cobalt);
}
.position-card h3{
  margin:0 0 10px;
  font-family:Archivo,sans-serif;
  font-size:30px;
  line-height:.94;
  letter-spacing:-.035em;
}
.position-card p{margin:0;color:var(--muted)}
.position-card ul{
  display:grid;
  gap:8px;
  margin:16px 0 0;
  padding:0;
  list-style:none;
  color:var(--ink);
  font-size:14px;
}
.position-card li{display:grid;grid-template-columns:18px 1fr;gap:8px}
.position-card li:before{content:"";width:8px;height:8px;margin-top:7px;border-radius:999px;background:var(--orange)}

/* Bricks (product modules SCAN/PULSE/CONTENT/SPRINT) */
.brick{
  position:relative;
  min-height:420px;
  padding:24px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius);
  background:rgba(255,255,255,.08);
  overflow:hidden;
}
.brick:before{
  content:attr(data-num);
  position:absolute;
  right:16px;
  top:10px;
  font-family:Archivo,sans-serif;
  font-weight:900;
  font-size:82px;
  line-height:1;
  letter-spacing:-.035em;
  color:rgba(255,255,255,.1);
}
.brick small{
  display:block;
  margin-bottom:52px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  color:var(--leaf);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.brick h3{max-width:260px}
.brick p{margin-bottom:18px}
.module-list{
  display:grid;
  gap:10px;
  margin:0;
  padding:18px 0 0;
  border-top:1px solid rgba(255,255,255,.12);
  list-style:none;
}
.module-list li{
  display:grid;
  grid-template-columns:14px 1fr;
  gap:10px;
  color:rgba(255,255,255,.7);
  font-size:13px;
  line-height:1.35;
}
.module-list li:before{
  content:"";
  width:7px;
  height:7px;
  margin-top:6px;
  border-radius:999px;
  background:var(--leaf);
}

/* Proof / Index visual */
.proof-wrap{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,.82fr);
  gap:20px;
  align-items:stretch;
}
.indice-visual{
  position:relative;
  min-height:540px;
  border-radius:var(--radius-lg);
  background:
    linear-gradient(rgba(255,255,255,.12) 1px,transparent 1px) 0 0/42px 42px,
    linear-gradient(90deg,rgba(255,255,255,.12) 1px,transparent 1px) 0 0/42px 42px,
    var(--night);
  overflow:hidden;
  padding:34px;
  color:var(--white);
}
.indice-visual:after{
  content:"";
  position:absolute;
  right:-70px;
  top:80px;
  width:310px;
  height:310px;
  border-radius:80px;
  transform:rotate(-10deg);
  background:linear-gradient(135deg,var(--orange),var(--pink));
}
.indice-visual h3{
  position:relative;
  z-index:1;
  max-width:520px;
  font-family:Archivo,sans-serif;
  font-size:70px;
  line-height:.86;
  letter-spacing:-.035em;
}
.indice-visual .big{
  position:relative;
  z-index:1;
  margin-top:84px;
  font-family:Archivo,sans-serif;
  font-size:150px;
  line-height:.8;
  letter-spacing:-.035em;
}
.indice-visual .big span{font-size:44px;color:rgba(255,255,255,.5)}
.indice-visual p{position:relative;z-index:1;max-width:360px;color:rgba(255,255,255,.7)}
.metric-list{display:grid;gap:14px}
.metric{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--white);
  padding:22px;
}
.metric small{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);text-transform:uppercase}
.metric b{display:block;margin-top:10px;font-family:Archivo,sans-serif;font-size:48px;letter-spacing:-.03em;line-height:.9}
.metric p{margin-top:10px;color:var(--muted)}
.formula-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--cream-2);
  padding:22px;
}
.formula-card h3{
  margin:0 0 12px;
  font-family:Archivo,sans-serif;
  font-size:28px;
  line-height:.96;
  letter-spacing:-.035em;
}
.formula{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
}
.formula span{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(18,56,255,.08);
  color:var(--cobalt);
}

/* Insights / Observatoire */
.insight-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.quote-panel{
  margin-top:24px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:var(--radius-lg);
  background:rgba(5,7,35,.28);
  padding:26px;
}
.quote-panel p{
  max-width:920px;
  font-family:Archivo,sans-serif;
  font-size:clamp(26px,3.7vw,48px);
  line-height:.95;
  letter-spacing:-.035em;
  color:var(--white);
}
.quote-panel span{display:block;margin-top:14px;color:rgba(255,255,255,.72)}
.obs-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--line);
  margin-top:20px;
}
.obs-stat{background:var(--white);padding:24px;min-height:150px}
.obs-stat b{
  display:block;
  font-family:Archivo,sans-serif;
  font-size:48px;
  line-height:.88;
  letter-spacing:-.035em;
  color:var(--cobalt);
}
.obs-stat span{
  display:block;
  margin-top:10px;
  font-family:"JetBrains Mono",monospace;
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
}
.obs-note{margin-top:18px;color:var(--muted)}
.obs-insights{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:18px;
}
.obs-insights .card b{
  display:block;
  margin-bottom:14px;
  font-family:Archivo,sans-serif;
  font-size:50px;
  line-height:.85;
  letter-spacing:-.035em;
  color:var(--orange);
}

/* Use cases */
.usecase{
  min-height:310px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
}
.usecase .number{font-family:Archivo,sans-serif;font-size:68px;line-height:.8;letter-spacing:-.035em;color:var(--orange)}
.usecase:nth-child(2) .number{color:var(--pink)}
.usecase:nth-child(3) .number{color:var(--olive)}

/* Band CTA orange */
.band{
  padding:70px clamp(20px,4vw,56px);
  background:var(--orange);
  color:var(--white);
}
.band-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:28px;
  align-items:center;
}
.band h2{font-size:clamp(38px,5.2vw,68px)}
.band p{max-width:650px;margin-top:18px;color:rgba(255,255,255,.78);font-size:19px}

/* Pricing cards & matrix */
.pricing-card{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--line);
}
.pricing-side,.pricing-main{background:var(--white);padding:34px}
.pricing-side{background:var(--night);color:var(--white)}
.pricing-side p{color:rgba(255,255,255,.68)}
.price{
  margin:26px 0;
  font-family:Archivo,sans-serif;
  font-size:70px;
  line-height:.9;
  letter-spacing:-.035em;
}
.features{display:grid;gap:13px}
.feature{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:10px;
  align-items:start;
  color:var(--muted);
}
.feature:before{
  content:"";
  width:12px;
  height:12px;
  margin-top:5px;
  border-radius:999px;
  background:var(--leaf);
}
.offer-matrix{
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--white);
  box-shadow:0 24px 70px rgba(5,7,35,.08);
}
.offer-cards{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
#pricing-agence .offer-cards{grid-template-columns:repeat(3,minmax(0,1fr))}
.offer-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--white);
  padding:22px;
  min-height:240px;
}
.offer-card.featured{
  background:var(--night);
  color:var(--white);
}
.offer-card small{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  color:var(--cobalt);
  text-transform:uppercase;
  letter-spacing:.08em;
}
.offer-card.featured small{color:var(--leaf)}
.offer-label{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
  background:rgba(255,91,34,.12);
  color:var(--orange);
  font-family:"JetBrains Mono",monospace;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.offer-card.featured .offer-label{
  background:rgba(214,228,92,.14);
  color:var(--leaf);
}
.offer-card h3{
  margin-top:18px;
  font-family:Archivo,sans-serif;
  font-size:34px;
  line-height:.9;
  letter-spacing:-.035em;
}
.offer-card .price-line{
  margin-top:14px;
  font-family:Archivo,sans-serif;
  font-size:30px;
  line-height:.95;
  letter-spacing:-.025em;
}
.offer-card p{
  margin-top:14px;
  color:var(--muted);
  font-size:14px;
}
.offer-card.featured p{color:rgba(255,255,255,.68)}
.matrix-scroll{overflow-x:auto}
.matrix{
  width:100%;
  min-width:980px;
  border-collapse:collapse;
}
.matrix th,.matrix td{
  border-bottom:1px solid rgba(5,7,35,.1);
  border-right:1px solid rgba(5,7,35,.08);
  padding:18px 16px;
  vertical-align:middle;
}
.matrix th:last-child,.matrix td:last-child{border-right:0}
.matrix tr:last-child td{border-bottom:0}
.matrix thead th{
  background:var(--night);
  color:var(--white);
  text-align:left;
}
.matrix thead th:first-child{width:280px}
.plan-name{
  display:block;
  font-family:Archivo,sans-serif;
  font-size:26px;
  line-height:.9;
  letter-spacing:-.025em;
}
.plan-price{
  display:block;
  margin-top:9px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  color:rgba(255,255,255,.58);
  text-transform:uppercase;
}
.feature-name b{
  display:block;
  font-family:Archivo,sans-serif;
  font-size:18px;
  line-height:1;
  letter-spacing:-.025em;
}
.feature-name span{
  display:block;
  margin-top:6px;
  color:var(--muted);
  font-size:13px;
}
.matrix td:not(.feature-name){
  text-align:center;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  color:var(--muted);
}
.check,.cross,.partial{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:999px;
  font-family:Inter,sans-serif;
  font-weight:900;
}
.check{background:rgba(214,228,92,.32);color:var(--olive-deep)}
.cross{background:rgba(5,7,35,.08);color:rgba(5,7,35,.32)}
.partial{background:rgba(255,91,34,.14);color:var(--orange)}
.offer-note{
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  padding:22px;
  border-top:1px solid rgba(5,7,35,.1);
  background:var(--cream-2);
}
.offer-note p{margin:0;color:var(--muted)}
.offer-note b{color:var(--ink)}
.pricing-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
}
.pricing-tabs button{
  min-height:44px;
  padding:0 18px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.68);
  color:var(--muted);
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
  cursor:pointer;
}
.pricing-tabs button.active{background:var(--orange);border-color:var(--orange);color:var(--white)}
.pricing-panel{
  display:block;
  max-height:0;
  overflow:hidden;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:opacity .22s ease,transform .22s ease;
}
.pricing-panel.active{
  max-height:2600px;
  opacity:1;
  visibility:visible;
  transform:none;
}
.pricing-footnote{margin-top:14px;color:var(--muted);font-size:14px}

/* FAQ list */
.faq-list{
  display:grid;
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--line);
}
.faq-list details{background:var(--white)}
.faq-list summary{
  display:grid;
  grid-template-columns:70px 1fr auto;
  gap:18px;
  align-items:center;
  cursor:pointer;
  padding:22px;
  list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary span:first-child{
  font-family:"JetBrains Mono",monospace;
  color:var(--cobalt);
  font-size:12px;
}
.faq-list summary b{
  font-family:Archivo,sans-serif;
  font-size:21px;
  line-height:1.05;
  letter-spacing:-.025em;
}
.faq-list summary i{
  font-style:normal;
  font-family:Archivo,sans-serif;
  font-size:28px;
  color:var(--orange);
  transition:transform .2s ease;
}
.faq-list details[open] summary i{transform:rotate(45deg)}
.faq-list details p{
  max-width:820px;
  margin:0;
  padding:0 22px 24px 110px;
  color:var(--muted);
}

/* Compliance */
.compliance-grid{
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1fr);
  gap:20px;
}
.compliance-panel{
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.08);
  padding:28px;
}
.compliance-panel h3{
  font-family:Archivo,sans-serif;
  font-size:44px;
  line-height:.9;
  letter-spacing:-.035em;
  margin:0 0 18px;
}
.compliance-panel p{color:rgba(255,255,255,.72)}
.security-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);
  background:rgba(255,255,255,.14);
  overflow:hidden;
}
.security-list div{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:12px;
  align-items:center;
  min-height:72px;
  padding:16px;
  background:rgba(5,7,35,.7);
}
.security-list span{
  font-family:"JetBrains Mono",monospace;
  color:var(--leaf);
  font-size:11px;
}
.security-list b{
  font-size:14px;
  color:rgba(255,255,255,.82);
}

/* Form card on dark */
.form-card{
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.08);
  padding:24px;
}
.form-card .field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.form-card .field-grid input,.form-card textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.16);
  border-radius:10px;
  background:rgba(5,7,35,.36);
  color:var(--white);
  padding:14px;
  outline:0;
}
.form-card textarea{min-height:110px;resize:vertical;margin-top:12px}
.form-card .field-grid input::placeholder,.form-card textarea::placeholder{color:rgba(255,255,255,.42)}
.form-card .form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

/* Footer (homepage variant — slightly different padding) */
.site .footer{
  padding:54px clamp(20px,4vw,56px) 30px;
  border-top:1px solid rgba(255,255,255,.12);
}
.site .footer-grid{
  grid-template-columns:minmax(0,1.1fr) repeat(4,minmax(140px,.45fr));
  gap:36px;
}
.footer-brand p{max-width:360px;margin:18px 0 0;color:rgba(255,255,255,.62)}
.site .footer h4{letter-spacing:.16em}
.site .footer a,.site .footer li{color:rgba(255,255,255,.7);font-size:14px}
.site .footer-bottom{
  margin-top:44px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
  color:rgba(255,255,255,.42);
  align-items:center;
  justify-content:space-between;
}
.mobile-menu{display:none}

/* Homepage responsive */
@media(max-width:1100px){
  .site .hero,.proof-wrap,.pricing-card,.platform-lead,.compliance-grid{grid-template-columns:1fr}
  .product-shell{max-width:760px}
  .steps{grid-template-columns:repeat(3,1fr)}
  .position-grid,.insight-grid,.obs-grid,.obs-insights,.offer-cards,.g3,.g4{grid-template-columns:repeat(2,1fr)}
  .site .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:980px){
  .mobile-menu{display:inline-flex}
  .site .hero{align-items:start;padding-top:32px}
}
@media(max-width:800px){
  .site .hero{padding-top:24px}
  .demo-metrics,.site .section-head,.band-inner,.g2,.g3,.g4,.insight-grid,.obs-grid,.obs-insights,.security-list,.offer-cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .position-grid,.position-card,.offer-note{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr}
  .form-card .field-grid{grid-template-columns:1fr}
  .indice-visual{min-height:460px}
  .indice-visual h3{font-size:52px}
  .indice-visual .big{font-size:108px}
  .faq-list summary{grid-template-columns:1fr auto;gap:10px}
  .faq-list summary span:first-child{grid-column:1/-1}
  .faq-list details p{padding:0 22px 24px}
  .site .footer-grid{grid-template-columns:1fr}
  .site .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ===== DEMO SCANNER HOME — miroir du rapport prod ===== */
/* La section #demo dans index.html doit etre visuellement coherente avec
   rapport-scan.html (canonical). On reuse la STRUCTURE des .report-metrics
   du namespace .report-* mais on l'adapte au fond sombre du .product-shell
   de la home (qui est sur fond night/blue). Sur la page rapport (cream) les
   metrics sont blanches ; ici elles sont rgba(white,.08) pour rester lisibles. */
.demo-section-label{
  display:flex;
  justify-content:space-between;
  gap:16px;
  margin:22px 0 14px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:rgba(255,255,255,.58);
}
.demo-section-label span:first-child{color:rgba(255,255,255,.78)}
.demo-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  gap:1px;
  border-radius:12px;
  overflow:hidden;
}
.demo-metrics .report-metric{
  background:rgba(5,7,35,.55);
  padding:20px;
}
.demo-metrics .report-metric small{color:rgba(255,255,255,.55)}
.demo-metrics .report-metric b{
  font-size:54px;
  color:var(--leaf);
}
.demo-metrics .report-metric:nth-child(1) b{color:var(--cobalt-soft,#6f8cff)}
.demo-metrics .report-metric:nth-child(2) b{color:var(--orange)}
.demo-metrics .report-metric:nth-child(3) b{color:var(--leaf)}
.demo-metrics .report-metric b .unit{font-size:22px;color:rgba(255,255,255,.5)}
.demo-metrics .report-metric b .pct{font-size:30px;color:rgba(255,255,255,.5)}
.demo-metrics .report-metric p{
  font-size:13px;
  margin-top:10px;
  color:rgba(255,255,255,.65);
}

/* Skeleton effect pendant le scan : on grise les sections de résultats
   pour signaler clairement le chargement (en plus du .scan-loader visible). */
.scan-panel.loading .demo-metrics,
.scan-panel.loading .query-list{opacity:.45;transition:opacity .2s}

.demo-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:18px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--leaf);
  border-bottom:1px solid var(--leaf);
  padding-bottom:4px;
  width:max-content;
}
.demo-cta:hover{color:var(--orange);border-bottom-color:var(--orange)}

@media(max-width:980px){
  .demo-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:680px){
  .demo-metrics{grid-template-columns:1fr}
  .demo-metrics .report-metric b{font-size:44px}
}


/* ============================================================
   RESPONSIVE HARDENING — cross-device, cross-browser, a11y
   Append-only : ne touche pas aux règles précédentes.
   Cible : iPhone SE (320) → 4K (2560+), iOS Safari, Chrome
   Android, Firefox, Edge. Couvre zoom auto iOS, viewport
   keyboard, tap highlight, focus visible fallback, ultra-wide.
   ============================================================ */

/* Color-scheme : empêche l'inversion auto en dark mode système */
html{color-scheme:light}

/* Viewport dynamique : évite le bug iOS/Android où le clavier
   soft pousse le contenu sous le keyboard (100vh figé). */
.site{min-height:100dvh}
@supports not (height:100dvh){.site{min-height:100vh}}

/* Tap highlight iOS : remplace le flash gris par teinte cobalt
   subtile sur les surfaces interactives, transparent sur boutons. */
*{-webkit-tap-highlight-color:rgba(18,56,255,.08)}
.btn,.nav-links a,.demo-cta,summary{-webkit-tap-highlight-color:transparent}

/* Inputs : font-size 16px = MUST sur iOS Safari sinon zoom auto
   au focus + min-height 44px = touch target Apple HIG. */
.contact-form input,
.contact-form textarea,
.contact-form select{
  font-size:16px;
  min-height:44px;
}
.contact-form textarea{min-height:120px}

/* Focus fallback pour navigateurs sans :focus-visible support
   (vieux Safari < 15.4, certains Android browsers). */
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus{
  border-color:var(--cobalt);
  box-shadow:0 0 0 3px rgba(18,56,255,.16);
}

/* Empêche débordement horizontal global (filet de sécurité) */
html,body{overflow-x:hidden;max-width:100vw}
img,svg,video,iframe,table{max-width:100%}

/* ===== Zone grise 480-720px : breakpoint intermédiaire ===== */
@media(max-width:600px){
  /* Axe sentiment (rapport-scan) : label 130px trop large sous 600px */
  .axis{grid-template-columns:max(96px,28vw) 1fr 44px;gap:10px}
  .axis b{font-size:14px}

  /* Source-row : 4 colonnes fixes sur petite tablette */
  .source-row{grid-template-columns:42px 1fr 64px 64px;gap:10px;padding:12px}

  /* FAQ summary 70px label trop dominant */
  .faq-list summary{grid-template-columns:clamp(48px,12vw,70px) 1fr auto;gap:10px}
}

@media(max-width:480px){
  /* Field grid 2-col compresse les inputs sous 480px */
  .field-grid{grid-template-columns:1fr;gap:10px}

  /* Trust-row 3 chiffres alignés deviennent illisibles */
  .trust-row{grid-template-columns:1fr;max-width:100%}
  .trust-row b{font-size:22px}

  /* CTA-band button + label côte-à-côte cassent */
  .cta-band{grid-template-columns:1fr;gap:14px;padding:24px}
  .cta-band h3{font-size:clamp(24px,7vw,32px)}

  /* Hero/form actions : full-width buttons */
  .form-actions,.hero-actions,.hero-cta{flex-direction:column;align-items:stretch;gap:10px}
  .form-actions .btn,.hero-actions .btn,.hero-cta .btn{width:100%}

  /* Source-row final : tout en pile sur très petits écrans */
  .source-row{grid-template-columns:1fr;gap:6px}

  /* Axe : label au-dessus de la barre */
  .axis{grid-template-columns:1fr;gap:6px}

  /* Report metrics : pile complète */
  .report-metric b{font-size:54px}
  .report-metric b .unit{font-size:22px}
  .report-metric b .pct{font-size:30px}

  /* Legal page padding réduit */
  .legal-page{padding:32px 18px 64px}
  .legal-page h1{font-size:clamp(32px,8vw,48px)}
  .legal-page h2{font-size:clamp(20px,5vw,26px)}

  /* Nav padding compact */
  .nav{padding:12px 16px;gap:12px}
  .logo{font-size:22px}
  .logo-mark{width:28px;height:28px;border-radius:8px}
}

@media(max-width:360px){
  /* iPhone SE 1ère gen, Galaxy S5 : ultra compact */
  .nav{padding:10px 12px}
  .legal-page{padding:24px 14px 56px}
  .report-shell{padding:24px 14px 48px}
  .section{padding:64px 14px}
}

/* ===== Mobile en landscape (hauteur réduite) ===== */
@media(max-height:520px) and (orientation:landscape){
  .hero{min-height:auto;padding-top:16px;padding-bottom:40px}
  .legal-page,.report-shell{padding-top:24px}
}

/* ===== Tablettes 7-10" portrait : entre 540 et 820 ===== */
@media(min-width:540px) and (max-width:820px){
  /* Footer 2 cols intermédiaire au lieu de 1 */
  .footer-grid,.site .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ===== Ultra-large : 1600px+ (4K, 21:9, large desktop) ===== */
@media(min-width:1600px){
  .hero-inner,.section,.legal-page,.report-shell,.footer{
    padding-left:clamp(48px,6vw,120px);
    padding-right:clamp(48px,6vw,120px);
  }
  .legal-inner{max-width:960px}
  .report-shell .report-block{max-width:1400px;margin:0 auto}
}

@media(min-width:2000px){
  /* 4K et au-delà : grids plus aérées, typo plus généreuse */
  .g3,.g4{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}
  .report-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
}

/* ===== Print stylesheet : CGU + rapport-scan imprimables ===== */
@media print{
  .nav,.footer,.hero-actions,.form-actions,.demo-cta,
  .nav-actions,.cta-band,#contact{display:none !important}
  body{background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
  a[href]:after{content:" (" attr(href) ")";font-size:10px;color:#666}
  .legal-page,.report-shell{padding:24px 0}
  .report-block{break-inside:avoid;border:1px solid #ddd;padding:16px;margin-bottom:16px}
  h1,h2,h3{break-after:avoid}
  .report-metric b{font-size:48px !important}
}

/* ===== Reduced motion : respecte les préférences a11y ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ===== Touch targets : tous les liens nav minimum 40px ===== */
@media(pointer:coarse){
  .nav-links a,.footer a,.legal-list a{
    min-height:36px;
    display:inline-flex;
    align-items:center;
  }
  .footer ul a{padding:6px 0}
}
