/* GoNoGo Immo — styles.css
   Extrait de terria_1.html le 2026-05-22T10:26:43Z
   Refactoring Phase 1 : externalisation CSS */

/* ── Accès testeur : cache le body tant que la porte n'est pas passée ── */
html.gng-gated body > *:not(#testGate){visibility:hidden!important}
html.gng-gated #testGate{display:flex!important}
#testGate{display:none;position:fixed;inset:0;z-index:2147483646;background:var(--dark);align-items:center;justify-content:center;padding:24px;font-family:var(--font-display)}
#testGate::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(68,214,44,.15) 1px,transparent 1px),linear-gradient(90deg,rgba(68,214,44,.15) 1px,transparent 1px);background-size:40px 40px;opacity:.25;pointer-events:none}
#testGate .tg-card{position:relative;max-width:420px;width:100%;background:var(--dark-2);border:1px solid var(--green-border);border-radius:20px;padding:40px 32px;text-align:center;box-shadow:0 20px 60px var(--shadow-color),0 0 80px var(--green-dim)}
#testGate .tg-logo{font-size:28px;font-weight:800;color:var(--white);margin-bottom:6px;letter-spacing:-.5px}
#testGate .tg-logo span{color:var(--green)}
#testGate .tg-subtitle{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gray);margin-bottom:28px}
#testGate .tg-badge{display:inline-block;background:rgba(255,170,0,.1);border:1px solid rgba(255,170,0,.4);color:var(--orange);font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;padding:5px 10px;border-radius:6px;margin-bottom:20px;text-transform:uppercase}
#testGate .tg-text{color:var(--gray);font-size:13px;line-height:1.6;margin-bottom:22px}
#testGate .tg-text b{color:var(--white)}
#testGate .tg-input{width:100%;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;padding:14px 16px;color:var(--white);font-size:15px;font-family:var(--font-mono);letter-spacing:1px;text-align:center;outline:none;transition:all .25s}
#testGate .tg-input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-dim)}
#testGate.tg-error .tg-card{animation:tgShake .35s ease}
#testGate.tg-error .tg-input{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,60,60,.15)}
@keyframes tgShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}
#testGate .tg-btn{margin-top:14px;width:100%;background:var(--green);color:var(--dark);border:none;border-radius:10px;padding:14px;font-size:14px;font-weight:700;font-family:var(--font-display);cursor:pointer;transition:all .25s;letter-spacing:.3px}
#testGate .tg-btn:hover{box-shadow:0 0 24px var(--green-glow);transform:translateY(-1px)}
#testGate .tg-error-msg{color:var(--red);font-size:12px;margin-top:12px;min-height:16px;font-family:var(--font-mono)}
#testGate .tg-footer{margin-top:24px;font-size:11px;color:var(--gray);font-family:var(--font-mono)}
:root{--dark:#0D0A1A;--dark-2:#1E1A34;--dark-3:#2A2545;--green:#44D62C;--green-dim:rgba(68,214,44,.15);--green-glow:rgba(68,214,44,.4);--white:#F0F0F0;--gray:#8A8599;--orange:#FFAA00;--red:#FF3C3C;--blue:#60a5fa;--blue-dim:rgba(96,165,250,.1);--blue-border:rgba(96,165,250,.2);--orange-dim:rgba(255,170,0,.1);--orange-border:rgba(255,170,0,.2);--font-display:'Outfit',sans-serif;--font-mono:'Space Mono',monospace;--nav-bg:rgba(13,10,26,.8);--nav-border:rgba(68,214,44,.08);--noise-opacity:0.03;--card-glow:rgba(68,214,44,.04);--shadow-color:rgba(0,0,0,.5);--green-border:rgba(68,214,44,.25);--green-bg:rgba(68,214,44,.06);--map-overlay-bg:rgba(13,10,26,.85);--green-border-light:rgba(68,214,44,.2);--green-border-dim:rgba(68,214,44,.08);--featured-bg:linear-gradient(160deg,rgba(68,214,44,.08),var(--dark-2));--hero-glow:var(--green-dim);--cta-glow:rgba(68,214,44,.1)}
[data-theme="light"]{--dark:#FFFFFF;--dark-2:#F5F5F7;--dark-3:#E0E0E5;--green:#1B8C0A;--green-dim:rgba(27,140,10,.1);--green-glow:rgba(27,140,10,.25);--white:#1A1A2E;--gray:#4A4A5E;--orange:#B87400;--red:#C02020;--blue:#2563EB;--blue-dim:rgba(37,99,235,.08);--blue-border:rgba(37,99,235,.2);--orange-dim:rgba(184,116,0,.08);--orange-border:rgba(184,116,0,.2);--nav-bg:rgba(255,255,255,.85);--nav-border:rgba(27,140,10,.12);--noise-opacity:0.015;--card-glow:rgba(27,140,10,.03);--shadow-color:rgba(0,0,0,.08);--green-border:rgba(27,140,10,.2);--green-bg:rgba(27,140,10,.05);--map-overlay-bg:rgba(255,255,255,.9);--green-border-light:rgba(27,140,10,.15);--green-border-dim:rgba(27,140,10,.06);--featured-bg:linear-gradient(160deg,rgba(27,140,10,.06),var(--dark-2));--hero-glow:rgba(27,140,10,.08);--cta-glow:rgba(27,140,10,.06)}
/* ══════════════════════════════════════════════════════ */
/* ── LIGHT MODE — Corrections hardcoded colors ──────── */
/* ══════════════════════════════════════════════════════ */
/* Guide cards — fact strip & chips */
[data-theme="light"] .guide-fact-strip{background:rgba(0,0,0,.025);border-color:var(--dark-3)}
[data-theme="light"] .guide-fact-chip{color:var(--white)}
[data-theme="light"] .guide-fact-chip b{color:var(--white)}
/* Guide tags — darken for light bg contrast */
[data-theme="light"] .guide-tag.build{color:#3B6FD9}
[data-theme="light"] .guide-tag.env{color:#0E8A5F}
[data-theme="light"] .guide-tag.pro{color:#8B5FC7}
[data-theme="light"] .guide-tag.aid{background:rgba(196,155,14,.1);color:#C49B0E}
/* Guide card category icons */
[data-theme="light"] .guide-tag.risk{background:rgba(194,65,12,.1);color:#C2410C}
[data-theme="light"] .guide-card[data-cat="risk"] .guide-fact-chip .gfc-icon{background:rgba(194,65,12,.1);color:#C2410C}
[data-theme="light"] .guide-card[data-cat="serv"] .guide-fact-chip .gfc-icon{background:rgba(139,95,199,.12);color:#7C3AED}
[data-theme="light"] .guide-card[data-cat="build"] .guide-fact-chip .gfc-icon{background:rgba(59,111,217,.12);color:#3B6FD9}
[data-theme="light"] .guide-card[data-cat="buy"] .guide-fact-chip .gfc-icon{background:rgba(27,140,10,.1);color:var(--green)}
[data-theme="light"] .guide-card[data-cat="env"] .guide-fact-chip .gfc-icon{background:rgba(14,138,95,.1);color:#0E8A5F}
[data-theme="light"] .guide-card[data-cat="pro"] .guide-fact-chip .gfc-icon{background:rgba(236,72,153,.1);color:#DB2777}
/* Guide card done badges */
[data-theme="light"] .guide-card-done{background:rgba(27,140,10,.12);color:var(--green);border-color:rgba(27,140,10,.4);box-shadow:0 0 0 3px rgba(27,140,10,.06)}
[data-theme="light"] .guide-card-done.compact{background:rgba(184,116,0,.12);color:var(--orange);border-color:rgba(184,116,0,.4);box-shadow:0 0 0 3px rgba(184,116,0,.06)}
/* Score bars — light mode */
[data-theme="light"] .score-bar-item[data-cat="zonage"]{background:linear-gradient(135deg,#fff,rgba(99,102,241,.06));border-left-color:#4f46e5}
[data-theme="light"] .score-bar-item[data-cat="environnement"]{background:linear-gradient(135deg,#fff,rgba(22,163,74,.06));border-left-color:#16a34a}
[data-theme="light"] .score-bar-item[data-cat="risques"]{background:linear-gradient(135deg,#fff,rgba(217,119,6,.06));border-left-color:#d97706}
[data-theme="light"] .score-bar-item[data-cat="marche"]{background:linear-gradient(135deg,#fff,rgba(8,145,178,.06));border-left-color:#0891b2}
[data-theme="light"] .score-bar-item[data-cat="zonage"] .score-bar-ico{background:rgba(79,70,229,.1);color:#4f46e5}
[data-theme="light"] .score-bar-item[data-cat="environnement"] .score-bar-ico{background:rgba(22,163,74,.1);color:#16a34a}
[data-theme="light"] .score-bar-item[data-cat="risques"] .score-bar-ico{background:rgba(217,119,6,.1);color:#d97706}
[data-theme="light"] .score-bar-item[data-cat="marche"] .score-bar-ico{background:rgba(8,145,178,.1);color:#0891b2}
[data-theme="light"] .score-bar-item:hover{box-shadow:0 4px 16px rgba(0,0,0,.08)}
/* Guide modal */
[data-theme="light"] .gm-header{color:var(--white);background:linear-gradient(180deg,var(--dark-3),var(--dark-2))}
[data-theme="light"] .gm-close{background:rgba(0,0,0,.08);color:var(--gray)}
[data-theme="light"] .gm-close:hover{background:rgba(0,0,0,.15)}
[data-theme="light"] .gm-emoji{background:rgba(27,140,10,.06);border-color:rgba(27,140,10,.18)}
[data-theme="light"] .gm-cat-badge{border-color:rgba(27,140,10,.2)}
[data-theme="light"] .gm-fact{background:rgba(0,0,0,.02)}
[data-theme="light"] .gm-section{background:rgba(0,0,0,.015)}
[data-theme="light"] .gm-section-body li{color:var(--white)}
[data-theme="light"] .gm-section[data-kind="allowed"] .gm-section-title{color:#059669}
[data-theme="light"] .gm-section[data-kind="allowed"] .gm-section-title::before{background:#059669}
[data-theme="light"] .gm-section[data-kind="forbidden"] .gm-section-title{color:#B87400}
[data-theme="light"] .gm-section[data-kind="forbidden"] .gm-section-title::before{background:#B87400}
[data-theme="light"] .gm-section[data-kind="legal"] .gm-section-title{color:#2563EB}
[data-theme="light"] .gm-section[data-kind="legal"] .gm-section-title::before{background:#2563EB}
[data-theme="light"] .gm-section[data-kind="costs"] .gm-section-title{color:#7C3AED}
[data-theme="light"] .gm-section[data-kind="costs"] .gm-section-title::before{background:#7C3AED}
[data-theme="light"] .gm-section-links a{color:var(--green);background:var(--green-bg);border-color:rgba(27,140,10,.2)}
[data-theme="light"] .gm-tip{background:linear-gradient(135deg,rgba(27,140,10,.06),rgba(27,140,10,.02));border-color:rgba(27,140,10,.2)}
/* Quartier section */
[data-theme="light"] .quartier-header{background:linear-gradient(135deg,rgba(27,140,10,.06),rgba(27,140,10,.02));border-color:rgba(27,140,10,.15)}
[data-theme="light"] .quartier-kpi{background:rgba(0,0,0,.02)}
[data-theme="light"] .q-alert-warn{background:rgba(184,116,0,.06);border-color:rgba(184,116,0,.25);color:var(--orange)}
[data-theme="light"] .q-alert-eco{background:rgba(27,140,10,.06);border-color:rgba(27,140,10,.2)}
[data-theme="light"] .q-det-dist{background:rgba(27,140,10,.08);color:var(--green)}
/* Chat */
[data-theme="light"] .chat-fab{background:var(--green);color:#fff;box-shadow:0 4px 24px rgba(27,140,10,.3)}
[data-theme="light"] .chat-counter{background:rgba(0,0,0,.02)}
[data-theme="light"] .chat-counter.warn .cc-dot{background:var(--orange)}
[data-theme="light"] .chat-counter.warn .cc-text{color:var(--orange)}
[data-theme="light"] .chat-counter.danger .cc-dot{background:var(--red)}
[data-theme="light"] .chat-counter.danger .cc-text{color:var(--red)}
[data-theme="light"] .chat-paywall .cp-text b{color:var(--white)}
[data-theme="light"] .chat-paywall .cp-cta{color:#fff}
/* Parcel chips */
[data-theme="light"] .parcel-chip.green{border-color:var(--green);background:rgba(27,140,10,.06)}
[data-theme="light"] .parcel-chip.orange{border-color:var(--orange);background:rgba(184,116,0,.06)}
[data-theme="light"] .parcel-chip.blue{border-color:#2563EB;background:rgba(37,99,235,.06)}
/* Section locked overlay */
[data-theme="light"] .section-locked>.section-locked-overlay{background:rgba(255,255,255,.7)}
[data-theme="light"] .geo-locked::after{background:rgba(255,255,255,.8);color:var(--orange)}
/* Freemium */
[data-theme="light"] .freemium-cta{color:#fff}
[data-theme="light"] .specimen-badge{background:rgba(184,116,0,.1);border-color:rgba(184,116,0,.25);color:var(--orange)}
/* Expert form chips */
[data-theme="light"] .ef-chip{background:rgba(27,140,10,.08);border-color:rgba(27,140,10,.2);color:var(--green)}
[data-theme="light"] .ef-chip .ef-chip-x{color:var(--green)}
/* Geo button */
[data-theme="light"] .address-wrap .geo-btn:hover{color:#fff}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--white);font-family:var(--font-display);-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:-1;opacity:var(--noise-opacity);transition:opacity .4s ease}
@media(max-width:768px){body::before{display:none}}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--dark)}::-webkit-scrollbar-thumb{background:var(--dark-3);border-radius:3px}
/* ── BLUEPRINT / PLAN BACKGROUND FILIGRANE ── */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:var(--blueprint-opacity,0.04);background-image:
  linear-gradient(var(--blueprint-color,rgba(68,214,44,.3)) 1px,transparent 1px),
  linear-gradient(90deg,var(--blueprint-color,rgba(68,214,44,.3)) 1px,transparent 1px),
  linear-gradient(var(--blueprint-color,rgba(68,214,44,.15)) 1px,transparent 1px),
  linear-gradient(90deg,var(--blueprint-color,rgba(68,214,44,.15)) 1px,transparent 1px);
  background-size:100px 100px,100px 100px,20px 20px,20px 20px;transition:opacity .4s ease}
[data-theme="light"] body::after{--blueprint-color:rgba(27,140,10,.2);--blueprint-opacity:0.06}
@media(max-width:768px){body::after{display:none}}

nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 40px;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--nav-border);transition:background .4s ease,border-color .4s ease}
.logo{font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:3px;color:var(--green);text-transform:uppercase}.logo span{color:var(--white)}
.nav-links{display:flex;gap:28px;align-items:center}.nav-links a{color:var(--gray);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:.5px;transition:color .3s}.nav-links a:hover{color:var(--green)}
.nav-cta{background:var(--green)!important;color:var(--dark)!important;padding:10px 24px!important;border-radius:8px;font-weight:700!important;font-size:13px!important;transition:all .3s!important}.nav-cta:hover{box-shadow:0 0 30px var(--green-glow);transform:translateY(-1px)}

.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative}
.hero::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,var(--hero-glow) 0%,transparent 70%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:100px;border:1px solid var(--green-border);background:var(--green-bg);font-size:13px;font-weight:500;color:var(--green);margin-bottom:32px;animation:fadeUp .8s ease both}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 var(--green-glow)}50%{opacity:.6;box-shadow:0 0 0 8px transparent}}
.hero h1{font-size:clamp(42px,6vw,80px);font-weight:900;line-height:1.05;max-width:900px;letter-spacing:-2px;animation:fadeUp .8s ease .1s both}.hero h1 .accent{color:var(--green)}
.hero p{font-size:clamp(16px,2vw,20px);color:var(--gray);max-width:540px;line-height:1.6;margin-top:24px;font-weight:300;animation:fadeUp .8s ease .2s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseRing{0%{transform:scale(1);opacity:1}100%{transform:scale(2.5);opacity:0}}

/* Simulator */
.simulator-section{padding:0 24px 100px;display:flex;justify-content:center;animation:fadeUp .8s ease .3s both}
.simulator{background:var(--dark-2);border:1px solid var(--dark-3);border-radius:20px;padding:48px;width:100%;max-width:760px;position:relative}
.simulator::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--green),transparent);border-radius:20px 20px 0 0;pointer-events:none;z-index:0}
.sim-step{display:none}.sim-step.active{display:block;animation:fadeUp .4s ease}
.sim-label{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:12px}
.sim-title{font-size:28px;font-weight:700;margin-bottom:32px;letter-spacing:-.5px}
.sim-input{width:100%;background:var(--dark);border:1px solid var(--dark-3);border-radius:12px;padding:14px 16px;color:var(--white);font-size:15px;font-family:var(--font-display);outline:none;transition:border-color .3s;margin-bottom:16px}
.sim-input:focus{border-color:var(--green)}.sim-input::placeholder{color:var(--gray)}
.project-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}
.project-grid.cat-panel{display:none}
.project-grid.cat-panel.active{display:grid}
.project-card{background:var(--dark);border:1px solid var(--dark-3);border-radius:12px;padding:20px;cursor:pointer;transition:all .3s;text-align:center}
.project-card:hover,.project-card.selected{border-color:var(--green);background:var(--green-bg)}
.autre-projet-input{width:100%;margin-top:8px;padding:8px 10px;background:var(--dark);border:1px solid var(--dark-3);border-radius:8px;color:var(--white);font-size:12px;font-family:inherit;text-align:center;outline:none}
.autre-projet-input:focus{border-color:var(--green)}
.project-card-autre.selected .autre-projet-input{display:block!important}
/* ── SVG ICON SYSTEM ── */
.ico{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ico svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ico-md svg{width:24px;height:24px}
.project-card .icon{margin-bottom:8px;display:flex;justify-content:center}
.project-card .label{font-size:14px;font-weight:500}
.sim-btn{width:100%;padding:18px;border:none;border-radius:12px;background:var(--green);color:var(--dark);font-family:var(--font-display);font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;letter-spacing:.5px}
.sim-btn:hover{box-shadow:0 0 40px var(--green-glow);transform:translateY(-2px)}.sim-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.sim-progress{display:flex;gap:8px;margin-bottom:32px}.sim-progress .bar{flex:1;height:3px;background:var(--dark-3);border-radius:2px;overflow:hidden}.sim-progress .bar.done{background:var(--green)}
.sim-progress .bar.active .fill{width:50%;height:100%;background:var(--green);border-radius:2px;animation:progress 1s ease infinite alternate}
@keyframes progress{from{width:30%}to{width:70%}}
.loading-state{text-align:center;padding:40px 0}
.loader-ring{width:56px;height:56px;border:3px solid var(--dark-3);border-top-color:var(--green);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 24px}@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:16px;font-weight:600;margin-bottom:12px}.loading-sub{font-size:13px;color:var(--gray);font-family:var(--font-mono)}
.score-zone{text-align:center;margin-bottom:28px}.score-ring-wrap{position:relative;width:140px;height:140px;margin:0 auto 16px}.score-ring-wrap svg{transform:rotate(-90deg)}
.score-ring-bg{fill:none;stroke:var(--dark-3);stroke-width:8}.score-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1),stroke 1s ease}
.score-value{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.score-number{font-size:38px;font-weight:900;letter-spacing:-1px}.score-max{font-size:12px;color:var(--gray);font-family:var(--font-mono)}
.score-label{font-size:16px;font-weight:700}
.score-bars{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--dark-3)}
.score-bar-item{background:var(--dark);border-radius:12px;padding:16px 18px;border-left:3px solid transparent;transition:transform .2s,box-shadow .2s}
.score-bar-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.score-bar-item[data-cat="zonage"]{border-left-color:#6366f1;background:linear-gradient(135deg,var(--dark),rgba(99,102,241,.08))}
.score-bar-item[data-cat="environnement"]{border-left-color:#22c55e;background:linear-gradient(135deg,var(--dark),rgba(34,197,94,.08))}
.score-bar-item[data-cat="risques"]{border-left-color:#f59e0b;background:linear-gradient(135deg,var(--dark),rgba(245,158,11,.08))}
.score-bar-item[data-cat="marche"]{border-left-color:#06b6d4;background:linear-gradient(135deg,var(--dark),rgba(6,182,212,.08))}
.score-bar-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.score-bar-label{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.score-bar-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.score-bar-item[data-cat="zonage"] .score-bar-ico{background:rgba(99,102,241,.15);color:#6366f1}
.score-bar-item[data-cat="environnement"] .score-bar-ico{background:rgba(34,197,94,.15);color:#22c55e}
.score-bar-item[data-cat="risques"] .score-bar-ico{background:rgba(245,158,11,.15);color:#f59e0b}
.score-bar-item[data-cat="marche"] .score-bar-ico{background:rgba(6,182,212,.15);color:#06b6d4}
.score-bar-pts{font-family:var(--font-mono);font-size:14px;font-weight:800}.score-bar-track{width:100%;height:5px;background:var(--dark-3);border-radius:3px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.score-bar-item[data-cat="zonage"] .score-bar-fill{background:linear-gradient(90deg,#6366f1,#818cf8)}
.score-bar-item[data-cat="environnement"] .score-bar-fill{background:linear-gradient(90deg,#22c55e,#4ade80)}
.score-bar-item[data-cat="risques"] .score-bar-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.score-bar-item[data-cat="marche"] .score-bar-fill{background:linear-gradient(90deg,#06b6d4,#22d3ee)}
/* ── Verdict Expert ── */
.verdict-expert{background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(99,102,241,.06));border:1px solid rgba(16,185,129,.25);border-radius:16px;padding:24px 28px;margin-bottom:28px;position:relative;overflow:hidden}
.verdict-expert::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;background:radial-gradient(circle,rgba(16,185,129,.12),transparent 70%);pointer-events:none}
.verdict-expert-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--green);margin-bottom:12px;font-family:var(--font-mono)}
.verdict-expert-tag svg{width:14px;height:14px}
.verdict-expert-text{font-size:15px;line-height:1.7;color:var(--white);font-weight:400}
/* Dual toggle (Réglementairement / En clair) */
.dual-toggle{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:12px 14px;margin:8px 0}
.dt-tabs{display:flex;gap:6px;margin-bottom:12px}
.dt-tab{flex:1;font-family:var(--font-mono);font-size:10px;letter-spacing:.8px;padding:7px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--gray);font-weight:600;cursor:pointer;transition:all .25s;text-transform:none}
.dt-tab.dt-active[data-target="reg"]{border-color:#B794F4;background:rgba(183,148,244,.15);color:#B794F4}
.dt-tab.dt-active[data-target="sim"]{border-color:#F5C518;background:rgba(245,197,24,.15);color:#F5C518}
.dt-content{display:none;font-size:14px;line-height:1.6}
.dt-content.dt-visible{display:block}
.dt-content p{margin:0 0 8px}
.verdict-expert-text strong{color:var(--green);font-weight:700}
.verdict-expert-sig{margin-top:14px;font-size:11px;color:var(--gray);font-style:italic;display:flex;align-items:center;gap:6px}
/* ── Dashboard Cards Grid ── */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:14px}
.dash-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.dash-grid-sep{text-align:center;padding:8px;color:var(--dark-3);font-size:18px;letter-spacing:8px;margin-bottom:14px}
/* ── Sommaire navigation dashboard ── */
.dash-nav-sommaire{background:var(--dark);border:1px solid var(--dark-3);border-radius:14px;padding:16px 20px;margin-bottom:16px}
.dash-nav-title{font-size:12px;font-weight:700;color:var(--gray);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.dash-nav-items{display:flex;flex-wrap:wrap;gap:8px}
.dash-nav-link{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;background:var(--dark-2);border:1px solid var(--dark-3);border-radius:99px;font-size:12px;font-weight:600;color:var(--white);cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}
.dash-nav-link:hover{border-color:var(--green);color:var(--green);background:rgba(16,185,129,.08);transform:translateY(-1px)}
.dash-nav-link svg{width:12px;height:12px}
[data-theme="light"] .dash-nav-sommaire{background:#fff;border-color:#e5e7eb}
[data-theme="light"] .dash-nav-link{background:#f3f4f6;border-color:#e5e7eb;color:#111}
[data-theme="light"] .dash-nav-link:hover{border-color:#10b981;color:#10b981;background:rgba(16,185,129,.08)}
/* ── Scroll hint animé ── */
.dash-scroll-hint{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;font-size:12px;color:var(--gray);opacity:.7;animation:scrollBounce 2s ease-in-out infinite;margin-bottom:8px;transition:opacity .5s}
.dash-scroll-hint.hidden{opacity:0;pointer-events:none}
@keyframes scrollBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.dash-card{background:var(--dark);border:1px solid var(--dark-3);border-radius:14px;padding:20px;cursor:pointer;position:relative;transition:all .25s ease;display:flex;flex-direction:column;gap:8px}
.dash-card:hover{border-color:rgba(16,185,129,.3);box-shadow:0 4px 20px rgba(0,0,0,.3);transform:translateY(-2px)}
.dash-card-title{font-size:13px;font-weight:700;color:var(--gray);display:flex;align-items:center;gap:8px}
.dash-card-title svg{width:14px;height:14px}
.dash-card-metric{font-size:26px;font-weight:900;color:var(--green);line-height:1.2;font-family:var(--font-mono)}
.dash-card-sub{font-size:12px;color:var(--gray);line-height:1.4}
.dash-card-link{font-size:11px;color:#818cf8;margin-top:auto;padding-top:4px;font-weight:600}
.dash-card.dim{opacity:.7}
.dash-card.dim:hover{opacity:1}
.dash-card.dim .dash-card-metric{font-size:22px;color:#06b6d4}
.dash-detail-panel{display:none;grid-column:1/-1;background:var(--dark);border:1px solid rgba(16,185,129,.25);border-radius:14px;padding:24px;margin-top:-6px;animation:panelSlide .3s ease}
.dash-detail-panel.open{display:block}
@keyframes panelSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.dash-detail-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--gray);cursor:pointer;font-size:18px;padding:4px 8px;border-radius:6px}
.dash-detail-close:hover{background:var(--dark-2);color:var(--white)}
/* Card category colors */
.dash-card[data-cat="zonage"]{border:1px solid rgba(99,102,241,.3);background:linear-gradient(135deg,var(--dark),rgba(99,102,241,.08))}
.dash-card[data-cat="zonage"] .dash-card-title{color:#818cf8}
.dash-card[data-cat="zonage"] .dash-card-metric{color:#818cf8}
.dash-card[data-cat="environnement"]{border:1px solid rgba(34,197,94,.2)}
.dash-card[data-cat="environnement"] .dash-card-metric{color:#22c55e}
.dash-card[data-cat="risques"]{border:1px solid rgba(245,158,11,.3);background:linear-gradient(135deg,var(--dark),rgba(245,158,11,.06))}
.dash-card[data-cat="risques"] .dash-card-title{color:#f59e0b}
.dash-card[data-cat="risques"] .dash-card-metric{color:#f59e0b}
.dash-card[data-cat="marche"] .dash-card-metric{color:#06b6d4}
.dash-card[data-cat="dpe"] .dash-card-metric{color:#06b6d4;font-size:inherit}
.dash-card[data-cat="quartier"] .dash-card-metric{color:#06b6d4}
.dash-card[data-cat="admin"]{border:1px solid rgba(34,197,94,.2)}
.dash-card[data-cat="admin"] .dash-card-metric{color:#22c55e}
.dash-card[data-cat="nature"]{border:1px solid rgba(74,222,128,.2)}
.dash-card[data-cat="nature"] .dash-card-metric{color:#4ade80}
.dash-card[data-cat="bilan"]{border:1px solid rgba(16,185,129,.25);background:linear-gradient(135deg,var(--dark),rgba(16,185,129,.06))}
.dash-card[data-cat="bilan"] .dash-card-metric{color:#10b981}
@media(max-width:700px){.dash-grid,.dash-grid-3{grid-template-columns:1fr}}
/* Light mode overrides */
[data-theme="light"] .verdict-expert{background:linear-gradient(135deg,rgba(16,185,129,.06),rgba(99,102,241,.04));border-color:rgba(16,185,129,.2)}
[data-theme="light"] .verdict-expert-text{color:#1a1a2e}
[data-theme="light"] .verdict-expert-text strong{color:#059669}
[data-theme="light"] .verdict-expert-sig{color:#6b7280}
[data-theme="light"] .dash-card{background:#fff;border-color:#e5e7eb}
[data-theme="light"] .dash-card:hover{border-color:rgba(16,185,129,.4);box-shadow:0 4px 16px rgba(0,0,0,.08)}
[data-theme="light"] .dash-card-title{color:#374151}
[data-theme="light"] .dash-card-sub{color:#6b7280}
[data-theme="light"] .dash-card[data-cat="zonage"]{border-color:rgba(79,70,229,.25);background:linear-gradient(135deg,#fff,rgba(79,70,229,.04))}
[data-theme="light"] .dash-card[data-cat="zonage"] .dash-card-title{color:#4f46e5}
[data-theme="light"] .dash-card[data-cat="zonage"] .dash-card-metric{color:#4f46e5}
[data-theme="light"] .dash-card[data-cat="risques"]{border-color:rgba(217,119,6,.25);background:linear-gradient(135deg,#fff,rgba(217,119,6,.04))}
[data-theme="light"] .dash-card[data-cat="risques"] .dash-card-title{color:#d97706}
[data-theme="light"] .dash-card[data-cat="risques"] .dash-card-metric{color:#d97706}
[data-theme="light"] .dash-card[data-cat="bilan"]{border-color:rgba(5,150,105,.2);background:linear-gradient(135deg,#fff,rgba(5,150,105,.04))}
[data-theme="light"] .dash-detail-panel{background:#fff;border-color:rgba(16,185,129,.2)}
.ai-result{animation:fadeUp .5s ease}
.result-section{margin-bottom:20px}.result-section-title{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.result-section-title::before{content:'';width:16px;height:1px;background:var(--green)}
.result-items{display:flex;flex-direction:column;gap:8px}
.result-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--dark);border-radius:10px}
.result-item .dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}
.result-item .dot.green{background:var(--green)}.result-item .dot.orange{background:var(--orange)}.result-item .dot.red{background:var(--red)}
.result-item .text{font-size:13px;line-height:1.5;color:var(--gray)}.result-item .text strong{color:var(--white)}
/* ── DETAIL TOGGLE (DVF) ── */
.detail-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border:1px dashed var(--dark-3);border-radius:8px;background:transparent;color:var(--gray);font-size:12px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:4px;margin-bottom:4px}
.detail-toggle:hover{border-color:var(--green);color:var(--green)}
.detail-toggle.open{border-color:var(--green-border-light);color:var(--green)}
.detail-toggle-sm{padding:6px 10px;font-size:11px;border:none;border-radius:6px;background:var(--dark);color:var(--gray);margin-top:8px}
.detail-toggle-sm:hover{color:var(--white)}
.detail-toggle-sm.open{color:var(--green)}
.detail-toggle-chevron{transition:transform .3s ease}
.detail-toggle.open .detail-toggle-chevron{transform:rotate(180deg)}
.detail-panel{max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease;opacity:0}
.detail-panel.open{max-height:2000px;opacity:1}
/* ── POI SUMMARY ROWS ── */
.poi-summary{display:flex;flex-direction:column;gap:2px}
.poi-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s;user-select:none}
.poi-row:hover{background:var(--dark)}
.poi-row-icon{flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center}
.poi-row-label{font-size:13px;font-weight:600;color:var(--white);flex:1;min-width:0}
.poi-row-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;flex-shrink:0}
.poi-row-closest{font-size:12px;font-weight:600;color:var(--gray);flex-shrink:0;min-width:48px;text-align:right}
.poi-row-chevron{flex-shrink:0;color:var(--gray);transition:transform .3s ease}
.poi-row.open .poi-row-chevron{transform:rotate(180deg);color:var(--green)}
.poi-row-detail{max-height:0;overflow:hidden;transition:max-height .35s ease,opacity .25s ease;opacity:0}
.poi-row-detail.open{max-height:400px;opacity:1}
/* ── BLOCS PÉDAGOGIQUES ── */
.info-pedagogy{background:var(--dark);border-left:3px solid var(--green);border-radius:0 8px 8px 0;padding:12px 14px;margin:8px 0 12px;font-size:12px;line-height:1.7;color:var(--gray)}
.info-pedagogy strong{color:var(--white);font-weight:600}
.info-pedagogy .en-clair{display:block;margin-top:6px;padding-top:6px;border-top:1px solid var(--dark-3);color:var(--green);font-weight:600;font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.info-pedagogy .en-clair + span{color:var(--white);font-weight:400;font-size:12px;text-transform:none;letter-spacing:0;display:block;margin-top:2px}
.regle-tooltip{font-size:11px;color:var(--gray);font-style:italic;margin-top:2px;opacity:.85;line-height:1.5}
/* ── BLOC QUARTIER ── */
.quartier-bloc{background:var(--dark);border:1px solid var(--dark-3);border-radius:14px;padding:20px}
.quartier-bloc .result-section{margin-bottom:16px;background:none;border:none;padding:0}
.quartier-bloc .result-section-title{margin-bottom:14px;font-size:15px;letter-spacing:2.5px;color:var(--white);padding:10px 14px;background:linear-gradient(90deg,var(--green-bg),transparent);border-left:3px solid var(--green);border-radius:0 8px 8px 0}
.quartier-bloc .result-section-title::before{display:none}
.quartier-bloc .result-section-title svg{color:var(--green)}
.quartier-header{background:linear-gradient(135deg,rgba(52,211,153,.08),rgba(52,211,153,.02));border:1px solid rgba(52,211,153,.18);border-radius:12px;padding:16px;margin:10px 0 18px}
.quartier-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.quartier-kpi{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.02);border:1px solid var(--dark-3);border-radius:10px;padding:10px 12px;transition:transform .2s ease,border-color .2s ease}
.quartier-kpi:hover{transform:translateY(-2px);border-color:var(--green)}
.qk-icon{font-size:22px;line-height:1}
.qk-text{flex:1;min-width:0}
.qk-value{font-size:15px;font-weight:700;color:var(--white);line-height:1.2}
.qk-label{font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.quartier-territ{margin-top:12px;padding-top:12px;border-top:1px dashed var(--dark-3);font-size:12px;color:var(--gray);text-align:center}
.quartier-alerts{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.q-alert{padding:10px 12px;border-radius:8px;font-size:12px;line-height:1.5}
.q-alert-warn{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);color:#f59e0b}
.q-alert-eco{background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.3);color:var(--green)}
.q-alert strong{color:var(--white)}
.q-det-title{font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:700}
.q-det-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;font-size:12px;color:var(--white);border-bottom:1px dashed var(--dark-3)}
.q-det-item:last-child{border-bottom:none}
.q-det-dist{font-size:10px;color:var(--green);background:rgba(52,211,153,.12);padding:2px 8px;border-radius:10px;white-space:nowrap}
.dpe-bar-chart{display:flex;align-items:flex-end;gap:3px;height:60px;margin:12px 0 8px}
.dpe-bar{flex:1;border-radius:3px 3px 0 0;min-width:0;position:relative;transition:height .4s ease}
.dpe-bar .dpe-bar-label{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:700}
.dpe-bar .dpe-bar-count{position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:9px;color:var(--gray)}
.dpe-etiquette{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;font-size:16px;font-weight:800;color:#fff}
.dpe-etiquette.A{background:#009c5a}.dpe-etiquette.B{background:#50b84d}.dpe-etiquette.C{background:#c8d100}.dpe-etiquette.D{background:#f5eb00}.dpe-etiquette.E{background:#f0b400}.dpe-etiquette.F{background:#eb6b0a}.dpe-etiquette.G{background:#d7221f}
/* ── BILAN FINAL ── */
.bilan-final{background:var(--dark);border:1px solid var(--dark-3);border-radius:14px;padding:20px 24px;margin-bottom:20px}
.bilan-title{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--green);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.bilan-title::before{content:'';width:16px;height:1px;background:var(--green)}
.bilan-resume{font-size:15px;line-height:1.7;color:var(--white);margin-bottom:20px;font-weight:500}
.bilan-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.bilan-cols{grid-template-columns:1fr}}
.bilan-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.bilan-col-title.good{color:var(--green)}
.bilan-col-title.bad{color:var(--orange)}
.bilan-item{font-size:13px;color:var(--gray);line-height:1.6;padding:6px 0;display:flex;align-items:flex-start;gap:8px}
.bilan-item .bi{flex-shrink:0;margin-top:3px;width:6px;height:6px;border-radius:50%}
.bilan-item .bi.green{background:var(--green)}.bilan-item .bi.orange{background:var(--orange)}.bilan-item .bi.red{background:var(--red)}
.teaser-block{position:relative;margin-bottom:24px}.teaser-content{filter:blur(6px);pointer-events:none;user-select:none;opacity:.5}
.teaser-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;text-align:center;padding:20px}
.teaser-overlay .lock-icon{font-size:32px;margin-bottom:12px}.teaser-overlay .lock-text{font-size:14px;font-weight:600}.teaser-overlay .lock-sub{font-size:12px;color:var(--gray)}
/* ── FREEMIUM ── */
/* ── UPGRADE MODAL ── */
.um-box{background:var(--dark-2);border:1px solid var(--green-border);border-radius:20px;max-width:480px;width:100%;padding:40px;text-align:center}
.um-box svg{color:var(--green)}
.um-title{color:var(--white);font-family:var(--font-display);font-size:24px;margin:0 0 12px}
.um-desc{color:var(--gray);font-size:14px;line-height:1.7;margin:0 0 24px}
.um-desc b{color:var(--green)}
.um-checks{display:flex;flex-direction:column;gap:8px;text-align:left;margin-bottom:24px}
.um-check{display:flex;align-items:center;gap:10px;color:var(--gray);font-size:13px}
.um-check-icon{color:var(--green);font-size:16px;font-weight:700}
.um-later{background:none;border:none;color:var(--gray);font-size:13px;cursor:pointer;margin-top:16px;font-family:var(--font-display);transition:color .2s}
.um-later:hover{color:var(--white)}
.freemium-cta{background:linear-gradient(135deg,var(--green),#22c55e);color:#0D0A1A;border:none;border-radius:12px;padding:14px 28px;font-family:var(--font-display);font-size:14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s;margin-top:12px;text-decoration:none}
.freemium-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(16,185,129,.3)}
.freemium-banner{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.04));border:1px solid var(--green-border-light);border-radius:16px;padding:24px;text-align:center;margin:16px 0}
.freemium-banner h3{color:var(--green);font-size:18px;margin:0 0 8px}.freemium-banner p{color:var(--gray);font-size:13px;margin:0 0 16px;line-height:1.6}
.specimen-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(251,191,36,.15);border:1px solid rgba(251,191,36,.3);color:#fbbf24;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.section-locked{position:relative;overflow:hidden}.section-locked>.section-locked-content{filter:blur(5px);pointer-events:none;user-select:none;opacity:.45}
.section-locked>.section-locked-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:3;background:rgba(13,10,26,.6);border-radius:16px;backdrop-filter:blur(2px)}
.geo-locked{opacity:.5;pointer-events:none;position:relative}.geo-locked::after{content:'🔒 Réservé aux abonnés';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(13,10,26,.7);color:var(--orange);font-size:13px;font-weight:700;border-radius:12px;z-index:2}
/* Expert request form */
.ef-overlay{position:fixed;inset:0;z-index:2147483645;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.ef-box{background:var(--dark-2);border:1px solid var(--dark-3);border-radius:20px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;padding:28px;position:relative}
.ef-box h2{font-size:20px;font-weight:800;margin:0 0 4px;color:var(--white)}.ef-box h2 span{color:var(--green)}
.ef-box .ef-sub{font-size:13px;color:var(--gray);margin-bottom:20px}
.ef-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--gray);font-size:22px;cursor:pointer;padding:4px}
.ef-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.ef-row.full{grid-template-columns:1fr}
.ef-field label{display:block;font-size:11px;font-weight:600;color:var(--gray);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.ef-field input,.ef-field textarea,.ef-field select{width:100%;padding:10px 12px;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;color:var(--white);font-family:var(--font-display);font-size:13px;outline:none;transition:border-color .2s}
.ef-field input:focus,.ef-field textarea:focus{border-color:var(--green)}
.ef-field textarea{resize:vertical;min-height:80px}
.ef-field .ef-req{color:var(--green)}
.ef-map-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--dark-3);margin-bottom:12px;height:200px;position:relative}
.ef-map-help{font-size:11px;color:var(--gray);margin-bottom:12px;font-style:italic}
.ef-parcelle-info{background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;padding:8px 12px;font-size:12px;color:var(--green);margin-bottom:12px;display:none}
.ef-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;min-height:0}
.ef-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);border-radius:8px;font-size:12px;font-family:var(--font-mono);color:var(--green);animation:chipIn .2s ease}
.ef-chip .ef-chip-x{background:none;border:none;color:var(--green);font-size:14px;cursor:pointer;padding:0 0 0 2px;line-height:1;opacity:.6;transition:opacity .2s}
.ef-chip .ef-chip-x:hover{opacity:1;color:#ef4444}
.ef-chip-empty{font-size:11px;color:var(--gray);font-style:italic;padding:4px 0}
@keyframes chipIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.ef-map-toggle{position:absolute;top:8px;right:8px;z-index:500;display:flex;background:var(--dark-2);border:1px solid var(--dark-3);border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.ef-map-toggle button{border:none;background:none;color:var(--gray);font-family:var(--font-display);font-size:11px;font-weight:600;padding:5px 10px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}
.ef-map-toggle button.active{background:var(--green);color:var(--dark)}
.ef-map-toggle button:not(.active):hover{color:var(--white)}
.ef-submit{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--green),#22c55e);color:var(--dark);font-family:var(--font-display);font-size:15px;font-weight:700;cursor:pointer;transition:all .3s;margin-top:8px}
.ef-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(16,185,129,.3)}
.ef-submit:disabled{opacity:.5;transform:none;cursor:not-allowed}
.ef-error{color:#ef4444;font-size:11px;margin-top:4px;display:none}
.ef-success{text-align:center;padding:40px 20px}
.ef-success h3{color:var(--green);font-size:22px;margin-bottom:12px}
.ef-success p{color:var(--gray);font-size:14px;line-height:1.7}
@media(max-width:600px){.ef-row{grid-template-columns:1fr}.ef-box{padding:20px}}
/* ── NAVIGATION BUTTONS (Back / Reset) ── */
.sim-nav{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:12px}
.sim-back{background:none;border:1px solid var(--dark-3);color:var(--gray);padding:14px 24px;border-radius:12px;font-family:var(--font-display);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.sim-back:hover{border-color:var(--green);color:var(--green)}
.sim-back svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sim-restart{background:none;border:none;color:var(--gray);font-family:var(--font-display);font-size:12px;cursor:pointer;transition:color .3s;padding:8px 0;opacity:.7}
.sim-restart:hover{color:var(--red);opacity:1}
.error-state{text-align:center;padding:32px 0}.error-state .err-icon{font-size:40px;margin-bottom:16px}.error-state p{color:var(--gray);font-size:14px;margin-bottom:20px;line-height:1.6}

/* Sections */
.section-label{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--green);margin-bottom:16px}
.section-title{font-size:clamp(32px,4vw,48px);font-weight:800;letter-spacing:-1px;max-width:600px;margin:0 auto 64px}
.features{padding:100px 24px;text-align:center}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;max-width:1000px;margin:0 auto}
.feature-card{background:var(--dark-2);border:1px solid var(--dark-3);border-radius:16px;padding:36px;text-align:left;transition:all .4s;position:relative;overflow:hidden}
.feature-card:hover{border-color:var(--green-border);transform:translateY(-4px)}
.feature-card::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at top left,var(--card-glow),transparent 60%);pointer-events:none}
.feature-icon{width:48px;height:48px;background:var(--green-dim);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px}
.feature-card h3{font-size:18px;font-weight:700;margin-bottom:10px}.feature-card p{font-size:14px;line-height:1.6;color:var(--gray)}

/* Guides */
.guides{padding:100px 24px;text-align:center}
.guides-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;max-width:1100px;margin:0 auto 32px}
.guides-tab{font-family:var(--font-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:8px 16px;border-radius:50px;border:1px solid var(--dark-3);background:transparent;color:var(--gray);cursor:pointer;transition:all .3s;font-weight:600;display:inline-flex;align-items:center;gap:7px}
.guides-tab svg{flex-shrink:0;opacity:.85}
.guides-tab.active svg,.guides-tab:hover svg{opacity:1}
.guides-tab:hover{border-color:var(--green-border);color:var(--white)}
.guides-tab.active{background:var(--green);color:var(--dark);border-color:var(--green)}
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;max-width:1100px;margin:0 auto}
.guide-card{background:var(--dark-2);border:1.5px solid var(--dark-3);border-radius:14px;padding:12px 14px;text-align:left;transition:all .35s ease;cursor:pointer;position:relative;overflow:hidden;display:none}
.guide-card.visible{display:block;animation:fadeUp .4s ease}
.guide-card:hover{transform:translateY(-3px)}
.guide-card[data-cat="risk"]{border-color:rgba(249,115,22,.18)}.guide-card[data-cat="risk"]:hover{border-color:#F97316;box-shadow:0 0 24px rgba(249,115,22,.22)}
.guide-card[data-cat="law"]{border-color:rgba(68,214,44,.18)}.guide-card[data-cat="law"]:hover{border-color:var(--green);box-shadow:0 0 24px rgba(68,214,44,.22)}
.guide-card[data-cat="serv"]{border-color:rgba(183,148,244,.18)}.guide-card[data-cat="serv"]:hover{border-color:#B794F4;box-shadow:0 0 24px rgba(183,148,244,.22)}
.guide-card[data-cat="build"]{border-color:rgba(91,154,255,.18)}.guide-card[data-cat="build"]:hover{border-color:#5B9AFF;box-shadow:0 0 24px rgba(91,154,255,.22)}
.guide-card[data-cat="buy"]{border-color:rgba(16,185,129,.18)}.guide-card[data-cat="buy"]:hover{border-color:#10b981;box-shadow:0 0 24px rgba(16,185,129,.22)}
.guide-card[data-cat="env"]{border-color:rgba(104,211,145,.18)}.guide-card[data-cat="env"]:hover{border-color:#68D391;box-shadow:0 0 24px rgba(104,211,145,.22)}
.guide-card[data-cat="pro"]{border-color:rgba(236,72,153,.18)}.guide-card[data-cat="pro"]:hover{border-color:#ec4899;box-shadow:0 0 24px rgba(236,72,153,.22)}
.guide-card[data-cat="aid"]{border-color:rgba(245,197,24,.22)}.guide-card[data-cat="aid"]:hover{border-color:#F5C518;box-shadow:0 0 28px rgba(245,197,24,.28)}
.guide-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;padding:3px 8px;border-radius:6px;display:inline-block;margin-bottom:8px;font-weight:700}
.guide-tag.risk{background:#F97316;color:#0D0A1A}.guide-tag.law{background:var(--green);color:var(--dark)}.guide-tag.info{background:var(--orange);color:#0D0A1A}.guide-tag.build{background:#5B9AFF;color:#0D0A1A}.guide-tag.buy{background:#10b981;color:#0D0A1A}.guide-tag.serv{background:#B794F4;color:#0D0A1A}.guide-tag.env{background:#68D391;color:#0D0A1A}.guide-tag.pro{background:#ec4899;color:#0D0A1A}.guide-tag.aid{background:#F5C518;color:#0D0A1A}
.guide-card h3{font-size:14px;font-weight:700;margin-bottom:4px;line-height:1.3}.guide-card p{font-size:11px;line-height:1.4;color:var(--gray);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.guide-fact-strip{margin-top:8px;display:flex;flex-direction:column;gap:4px;padding:8px;background:rgba(255,255,255,.02);border:1px solid var(--dark-3);border-radius:8px}
.guide-fact-strip .gfs-title{font-size:9px;font-weight:700;color:var(--gray);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:2px}
.guide-fact-chip{display:flex;align-items:flex-start;gap:8px;font-size:11.5px;line-height:1.4;color:var(--white-soft,#d4d4d4)}
.guide-fact-chip .gfc-icon{flex-shrink:0;width:16px;height:16px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;background:var(--green-dim);color:var(--green);font-weight:700;margin-top:1px}
.guide-fact-chip b{color:#fff;font-weight:700}
.guide-card[data-cat="risk"] .guide-fact-chip .gfc-icon{background:rgba(249,115,22,.14);color:#F97316}
.guide-card[data-cat="serv"] .guide-fact-chip .gfc-icon{background:rgba(183,148,244,.14);color:#B794F4}
.guide-card[data-cat="build"] .guide-fact-chip .gfc-icon{background:rgba(91,154,255,.14);color:#5B9AFF}
.guide-card[data-cat="buy"] .guide-fact-chip .gfc-icon{background:rgba(16,185,129,.14);color:#10b981}
.guide-card[data-cat="env"] .guide-fact-chip .gfc-icon{background:rgba(104,211,145,.14);color:#68D391}
.guide-card[data-cat="pro"] .guide-fact-chip .gfc-icon{background:rgba(236,72,153,.14);color:#ec4899}
.guide-card .read-more{font-size:10px;color:var(--green);font-weight:600;margin-top:8px;display:inline-block;transition:gap .3s;display:flex;align-items:center;gap:4px}
.guide-card:hover .read-more{gap:8px}
.guide-card-done{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;line-height:1;background:rgba(16,185,129,.18);color:#10b981;border:1.5px solid rgba(16,185,129,.55);box-shadow:0 0 0 3px rgba(16,185,129,.08);z-index:2;pointer-events:none}
.guide-card-done.compact{background:rgba(245,158,11,.18);color:#f59e0b;border-color:rgba(245,158,11,.6);box-shadow:0 0 0 3px rgba(245,158,11,.08)}
.guides-count{font-family:var(--font-mono);font-size:11px;color:var(--gray);margin-bottom:12px}
/* Toggle vue compacte / détaillée */
.guides-count-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;max-width:1100px;margin:0 auto}
.guides-count-row .guides-count{margin-bottom:0}
.guides-toggle-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;font-family:var(--font-display);font-size:12px;font-weight:600;background:var(--dark-2);color:var(--white);border:1px solid var(--dark-3);border-radius:8px;cursor:pointer;transition:all .2s;margin:0 0 12px 0;letter-spacing:.2px}
.guides-toggle-btn .ico{font-size:11px;letter-spacing:-1px;line-height:1;color:var(--gray);transition:color .2s}
.guides-toggle-btn:hover{border-color:var(--green-border);color:var(--green)}
.guides-toggle-btn:hover .ico{color:var(--green)}
.guides-toggle-btn:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.guides-toggle-btn[aria-pressed="true"]{background:var(--green);border-color:var(--green);color:var(--dark)}
.guides-toggle-btn[aria-pressed="true"] .ico{color:var(--dark)}
[data-theme="light"] .guides-toggle-btn{background:#fff;color:#1a1a1a;border-color:#d8dde2}
[data-theme="light"] .guides-toggle-btn:hover{border-color:#1B8C0A;color:#1B8C0A}
[data-theme="light"] .guides-toggle-btn[aria-pressed="true"]{background:#1B8C0A;border-color:#1B8C0A;color:#fff}
[data-theme="light"] .guides-toggle-btn[aria-pressed="true"] .ico{color:#fff}
/* Vue compacte des guide-cards */
.guides-grid.compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px}
.guides-grid.compact .guide-card{padding:8px 10px}
.guides-grid.compact .guide-card .guide-tag{font-size:8px;padding:1px 5px;margin-bottom:4px;letter-spacing:1px}
.guides-grid.compact .guide-card h3{font-size:12px;margin-bottom:0;line-height:1.25;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.guides-grid.compact .guide-card p,
.guides-grid.compact .guide-card .read-more,
.guides-grid.compact .guide-card .guide-fact-strip{display:none}
.guides-grid.compact .guide-card-done{top:6px;right:6px;width:16px;height:16px;font-size:11px;box-shadow:none}
.guides-grid.compact .guide-card:hover{transform:translateY(-2px)}
@media(max-width:600px){.guides-grid.compact{grid-template-columns:repeat(2,1fr)}}

/* ── MINI-MODAL GUIDES ── */
.guide-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:20px}
.guide-modal.open{display:flex;animation:gmFade .25s ease}
@keyframes gmFade{from{opacity:0}to{opacity:1}}
.gm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(4px)}
.gm-box{position:relative;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;background:var(--dark-2);border:1px solid var(--dark-3);border-top:4px solid var(--cat-c,var(--green));border-radius:20px;box-shadow:0 20px 80px rgba(0,0,0,.6);animation:gmSlide .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes gmSlide{from{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.gm-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:none;background:rgba(0,0,0,.4);color:#fff;font-size:24px;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}
.gm-close:hover{background:rgba(0,0,0,.7);transform:rotate(90deg)}
.gm-header{padding:26px 28px 22px;border-radius:20px 20px 0 0;display:flex;align-items:center;gap:16px;color:#fff;background:linear-gradient(180deg,var(--dark-3),var(--dark-2));border-bottom:1px solid var(--dark-3);position:relative}
.gm-header::after{content:'';position:absolute;left:28px;right:28px;bottom:-1px;height:2px;background:linear-gradient(90deg,var(--green),transparent)}
.gm-emoji{font-size:40px;line-height:1;flex-shrink:0;width:62px;height:62px;display:flex;align-items:center;justify-content:center;background:var(--cat-c-soft,rgba(52,211,153,.08));border:1px solid var(--cat-c-bord,rgba(52,211,153,.25));border-radius:16px}
.gm-head-text{flex:1;min-width:0}
.gm-cat-badge{display:inline-block;background:var(--cat-c,var(--green));color:#0D0A1A;font-size:10px;font-weight:700;padding:3px 9px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;border:1px solid var(--cat-c-bord,rgba(52,211,153,.3))}
.gm-title{font-size:19px;font-weight:800;line-height:1.25;margin:0 0 4px;color:var(--white)}
.gm-accroche{font-size:12.5px;margin:0;line-height:1.45;color:var(--gray)}
.gm-body{padding:22px 28px}
.gm-facts{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}
.gm-fact{display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.02);border:1px solid var(--dark-3);border-radius:12px;padding:12px 14px;transition:border-color .2s,transform .2s}
.gm-fact:hover{border-color:var(--green);transform:translateX(3px)}
.gm-fact-icon{font-size:22px;line-height:1;flex-shrink:0}
.gm-fact-text{font-size:13px;line-height:1.55;color:var(--white)}
.gm-fact-text b{color:var(--green);font-weight:700}
/* Sections enrichies */
.gm-sections{display:flex;flex-direction:column;gap:18px;margin-bottom:20px}
/* Format compact : sections plus denses, espaces réduits */
.gm-sections-compact{gap:12px;margin-bottom:14px}
.gm-sections-compact .gm-section{padding:12px 14px}
.gm-sections-compact .gm-section-title{font-size:10px;margin-bottom:7px}
.gm-sections-compact .gm-section-body{font-size:12.5px;line-height:1.55}
.gm-sections-compact .gm-section-body ul{gap:5px}
.gm-section{background:rgba(255,255,255,.015);border:1px solid var(--dark-3);border-radius:12px;padding:14px 16px}
.gm-section-title{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--cat-c,var(--green));text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.gm-section-title::before{content:'';width:14px;height:2px;background:var(--green);border-radius:2px}
.gm-section-body{font-size:13px;line-height:1.6;color:var(--white)}
.gm-section-body b{color:var(--green);font-weight:700}
.gm-section-body ul{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:7px}
.gm-section-body li{padding-left:18px;position:relative;color:#d1d5db}
.gm-section-body li::before{content:'';position:absolute;left:2px;top:8px;width:6px;height:6px;border-radius:50%;background:var(--green);opacity:.7}
.gm-section[data-kind="allowed"] .gm-section-title{color:#34d399}
.gm-section[data-kind="allowed"] .gm-section-title::before{background:#34d399}
.gm-section[data-kind="forbidden"] .gm-section-title{color:#fbbf24}
.gm-section[data-kind="forbidden"] .gm-section-title::before{background:#fbbf24}
.gm-section[data-kind="legal"] .gm-section-title{color:#60a5fa}
.gm-section[data-kind="legal"] .gm-section-title::before{background:#60a5fa}
.gm-section[data-kind="costs"] .gm-section-title{color:#c084fc}
.gm-section[data-kind="costs"] .gm-section-title::before{background:#c084fc}
.gm-section-kv{display:grid;grid-template-columns:max-content 1fr;gap:6px 14px;font-size:12.5px;margin-top:4px}
.gm-section-kv dt{color:var(--gray);font-weight:600}
.gm-section-kv dd{margin:0;color:var(--white)}
.gm-section-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.gm-section-links a{font-size:11px;font-weight:600;color:var(--green);background:var(--green-bg);border:1px solid rgba(52,211,153,.25);padding:5px 10px;border-radius:8px;text-decoration:none;transition:all .2s}
.gm-section-links a:hover{background:rgba(52,211,153,.15);transform:translateY(-1px)}
.gm-tip{background:linear-gradient(135deg,rgba(52,211,153,.1),rgba(52,211,153,.02));border:1px solid rgba(52,211,153,.3);border-radius:12px;padding:14px 16px}
.gm-tip-label{font-size:11px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.gm-tip-text{font-size:12px;line-height:1.55;color:var(--white)}
.gm-tip-text b{color:var(--green)}
.gm-footer{padding:0 28px 24px}
.gm-ask-btn{width:100%;background:var(--cat-c,var(--green));color:#0D0A1A;border:none;border-radius:12px;padding:14px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .2s,box-shadow .2s}
.gm-ask-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(52,211,153,.35)}
@media(max-width:560px){
  .gm-box{max-height:95vh;border-radius:16px}
  .gm-header{padding:22px 20px 18px;gap:14px}
  .gm-emoji{font-size:38px}
  .gm-title{font-size:17px}
  .gm-body{padding:18px 20px}
  .gm-footer{padding:0 20px 20px}
}

/* How / Pricing / FAQ / CTA / Footer — same as before */
.how{padding:100px 24px;max-width:900px;margin:0 auto}
.pricing{padding:100px 24px;text-align:center}
.pricing-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;max-width:1200px;margin:0 auto}
@media(max-width:1100px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.pricing-grid{grid-template-columns:1fr}}
.price-card{background:var(--dark-2);border:1px solid var(--dark-3);border-radius:16px;padding:22px 18px;text-align:left;transition:all .4s;position:relative;display:flex;flex-direction:column}.price-card:hover{transform:translateY(-4px)}
.price-card.featured{border-color:var(--green);background:var(--featured-bg)}
.price-card.featured::before{content:'POPULAIRE';position:absolute;top:12px;right:12px;background:var(--green);color:var(--dark);font-size:9px;font-weight:800;letter-spacing:1px;padding:3px 8px;border-radius:5px}
.price-card.pass{border-color:var(--blue-border);background:linear-gradient(180deg,var(--dark-2),rgba(96,165,250,.04))}
.price-card.expert{border-color:var(--orange-border)}
.price-name{font-size:12px;font-weight:600;color:var(--gray);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.price-card.pass .price-name{color:var(--blue)}
.price-card.expert .price-name{color:var(--orange)}
.price-amount{font-size:28px;font-weight:900;margin-bottom:4px;letter-spacing:-1px}.price-amount span{font-size:13px;font-weight:400;color:var(--gray)}
.price-card.pass .price-amount{color:var(--blue)}
.price-desc{font-size:12px;color:var(--gray);line-height:1.4;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--dark-3)}
.price-features{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px;flex:1}
.price-features li{font-size:12px;color:var(--gray);display:flex;align-items:center;gap:8px}.price-features li::before{content:'✓';color:var(--green);font-weight:700;font-size:12px}
.price-card.pass .price-features li::before{color:var(--blue)}
.price-card.expert .price-features li::before{color:var(--orange)}
.price-btn{width:100%;padding:12px;border-radius:10px;border:1px solid var(--dark-3);background:transparent;color:var(--white);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .3s}
.price-btn:hover{border-color:var(--green);background:var(--green-bg)}
.price-card.featured .price-btn{background:var(--green);color:var(--dark);border-color:var(--green)}.price-card.featured .price-btn:hover{box-shadow:0 0 30px var(--green-glow)}.price-card.featured .price-btn.specimen-btn{background:transparent;color:var(--green);border-color:rgba(68,214,44,.25)}
.price-card.pass .price-btn{border-color:var(--blue-border);color:var(--blue)}.price-card.pass .price-btn:hover{background:var(--blue-dim);border-color:var(--blue)}
.price-card.expert .price-btn{border-color:var(--orange-border);color:var(--orange)}.price-card.expert .price-btn:hover{background:var(--orange-dim);border-color:var(--orange)}

.faq{padding:100px 24px;max-width:700px;margin:0 auto}.faq-item{border-bottom:1px solid var(--dark-3)}
.faq-q{width:100%;background:none;border:none;color:var(--white);font-family:var(--font-display);font-size:16px;font-weight:600;padding:24px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left}
.faq-q .arrow{color:var(--green);font-size:20px;transition:transform .3s}.faq-item.open .faq-q .arrow{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}.faq-item.open .faq-a{max-height:500px;padding-bottom:24px}
.faq-a p{font-size:14px;line-height:1.7;color:var(--gray)}
.final-cta{padding:120px 24px;text-align:center;position:relative}
.final-cta::before{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(circle,var(--cta-glow),transparent 70%);pointer-events:none}
.final-cta h2{font-size:clamp(32px,5vw,56px);font-weight:900;letter-spacing:-1px;margin-bottom:20px}.final-cta p{font-size:18px;color:var(--gray);margin-bottom:40px}
.final-cta .sim-btn{width:auto;padding:20px 48px;font-size:18px;display:inline-block}
footer{padding:48px 40px;border-top:1px solid var(--dark-3);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
footer .logo{font-size:16px}footer p{color:var(--gray);font-size:12px}footer .links{display:flex;gap:24px}footer .links a{color:var(--gray);text-decoration:none;font-size:12px;transition:color .3s}footer .links a:hover{color:var(--green)}

/* ══════════════════════════ */
/* ── CHATBOT ── */
/* ══════════════════════════ */
.chat-fab{position:fixed;bottom:28px;right:28px;z-index:2147483647;width:60px;height:60px;border-radius:50%;background:#44D62C;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;color:#0D0A1A;box-shadow:0 4px 24px rgba(68,214,44,.4);transition:all .3s;transform:translateZ(0)}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 36px var(--green-glow)}
.chat-fab.open{border-radius:16px;width:48px;height:48px;font-size:20px;background:var(--dark-3);box-shadow:none}

.chat-window{position:fixed;bottom:100px;right:28px;z-index:9999;width:420px;max-height:min(85vh,800px);background:var(--dark-2);border:1px solid var(--dark-3);border-radius:20px;display:none;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px var(--shadow-color)}
.chat-window.open{display:flex;animation:fadeUp .3s ease}

.chat-header{padding:20px 24px;border-bottom:1px solid var(--dark-3);display:flex;align-items:center;gap:12px}
.chat-header-dot{width:10px;height:10px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
.chat-header-text{flex:1}
.chat-header-text h4{font-size:15px;font-weight:700}.chat-header-text p{font-size:11px;color:var(--gray);margin-top:2px}

.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px;min-height:420px}
.chat-msg{max-width:85%;padding:12px 16px;border-radius:14px;font-size:13px;line-height:1.6}
.chat-msg.bot{background:var(--dark);color:var(--gray);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:var(--green);color:var(--dark);align-self:flex-end;border-bottom-right-radius:4px;font-weight:500}
.chat-msg.bot strong{color:var(--white)}
.chat-related{display:inline-block;margin-top:4px;padding:8px 12px;background:var(--green-bg);border:1px solid var(--green-border);border-radius:8px;cursor:pointer;transition:all .3s;color:var(--green);font-size:12px}
.chat-related:hover{background:var(--green-dim);border-color:var(--green);box-shadow:0 0 12px var(--green-glow)}
.chat-related strong{color:var(--green)!important}
/* ── Modal Vue 3D ── */
.modal3d-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.modal3d-overlay.open{display:flex;opacity:1}
.modal3d-box{position:relative;width:92vw;max-width:1100px;height:75vh;max-height:700px;background:var(--dark-2);border:1px solid var(--green-border);border-radius:20px;overflow:hidden;box-shadow:0 0 60px rgba(68,214,44,.12)}
.modal3d-header{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(180deg,var(--dark-2) 60%,transparent);pointer-events:none}
.modal3d-header>*{pointer-events:auto}
.modal3d-title{font-family:var(--font-mono);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--green);display:flex;align-items:center;gap:8px}
.modal3d-close{width:36px;height:36px;border-radius:10px;border:1px solid var(--dark-3);background:var(--dark);color:var(--gray);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:3}
.modal3d-close:hover{border-color:var(--green);color:var(--green);box-shadow:0 0 12px var(--green-glow)}
.modal3d-map{width:100%;height:100%}
.modal3d-box .mapboxgl-ctrl-top-right,.modal3d-box .maplibregl-ctrl-top-right{top:auto!important;bottom:60px!important;right:12px!important}
.modal3d-box .mapboxgl-ctrl-group,.modal3d-box .maplibregl-ctrl-group{background:var(--dark)!important;border:1px solid var(--dark-3)!important;border-radius:8px!important}
.modal3d-box .mapboxgl-ctrl-group button,.modal3d-box .maplibregl-ctrl-group button{background:transparent!important;color:var(--gray)!important}
.modal3d-box .mapboxgl-ctrl-group button:hover,.modal3d-box .maplibregl-ctrl-group button:hover{color:var(--green)!important}
.modal3d-box .mapboxgl-ctrl-group button+button,.modal3d-box .maplibregl-ctrl-group button+button{border-top:1px solid var(--dark-3)!important}
.modal3d-box .mapboxgl-ctrl-group button .mapboxgl-ctrl-icon,.modal3d-box .maplibregl-ctrl-group button .maplibregl-ctrl-icon{filter:invert(0.7)}
.modal3d-box .maplibregl-ctrl-attrib{background:rgba(13,10,26,.8)!important;color:var(--gray)!important}
.modal3d-box .maplibregl-ctrl-attrib a{color:var(--green)!important}
.ign-source-label{position:absolute;bottom:16px;right:16px;z-index:2;font-size:10px;color:var(--gray);background:rgba(13,10,26,.85);padding:5px 10px;border-radius:6px;border:1px solid var(--green-border);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px}
.ign-source-label strong{color:var(--green)}
.modal3d-controls{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:2;display:flex;gap:8px}
.modal3d-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--dark-3);background:var(--dark);color:var(--white);font-family:var(--font-display);font-size:12px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}
.modal3d-btn:hover{border-color:var(--green);color:var(--green)}
.modal3d-btn.active{border-color:var(--green);background:var(--green-bg);color:var(--green)}
.modal3d-address{position:absolute;bottom:16px;left:16px;z-index:2;font-size:11px;color:var(--gray);background:var(--dark);padding:6px 12px;border-radius:6px;border:1px solid var(--dark-3);max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modalSV-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.modalSV-overlay.open{display:flex;opacity:1}
.modalSV-box{position:relative;width:92vw;max-width:1100px;height:75vh;max-height:700px;background:var(--dark-2);border:1px solid var(--green-border);border-radius:20px;overflow:hidden;box-shadow:0 0 60px rgba(68,214,44,.12)}
.modalSV-header{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(180deg,var(--dark-2) 60%,transparent);pointer-events:none}
.modalSV-header>*{pointer-events:auto}
.modalSV-title{font-family:var(--font-mono);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--green);display:flex;align-items:center;gap:8px}
.modalSV-close{width:36px;height:36px;border-radius:10px;border:1px solid var(--dark-3);background:var(--dark);color:var(--gray);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}
.modalSV-close:hover{border-color:var(--green);color:var(--green);box-shadow:0 0 12px var(--green-glow)}
.modalSV-frame{width:100%;height:100%;border:none}
.modalSV-address{position:absolute;bottom:16px;left:16px;z-index:2;font-size:11px;color:var(--gray);background:var(--dark);padding:6px 12px;border-radius:6px;border:1px solid var(--dark-3);max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn3d-trigger{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--dark);border:1px solid var(--green-border);border-radius:10px;color:var(--green);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:12px}
.btn3d-trigger:hover{background:var(--green-bg);border-color:var(--green);box-shadow:0 0 20px var(--green-glow);transform:translateY(-1px)}
.chat-typing{align-self:flex-start;padding:12px 16px;background:var(--dark);border-radius:14px;border-bottom-left-radius:4px;display:flex;gap:4px}
.chat-typing span{width:6px;height:6px;background:var(--gray);border-radius:50%;animation:typingDot 1.4s infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

.chat-input-area{padding:16px;border-top:1px solid var(--dark-3);display:flex;gap:10px}
.chat-input{flex:1;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;padding:12px 14px;color:var(--white);font-size:13px;font-family:var(--font-display);outline:none;transition:border-color .3s}
.chat-input:focus{border-color:var(--green)}.chat-input::placeholder{color:var(--gray)}
.chat-send{width:40px;height:40px;border:none;border-radius:10px;background:var(--green);color:var(--dark);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.chat-send:hover{box-shadow:0 0 20px var(--green-glow)}.chat-send:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}

.chat-suggestions{display:flex;flex-wrap:wrap;gap:6px;padding:0 20px 16px}
.chat-sug{background:var(--dark);border:1px solid var(--dark-3);border-radius:8px;padding:8px 12px;font-size:11px;color:var(--gray);cursor:pointer;transition:all .3s;font-family:var(--font-display)}
.chat-sug:hover{border-color:var(--green);color:var(--green)}
/* ── Compteur + reset ── */
.chat-reset-btn{background:none;border:1px solid var(--dark-3);color:var(--gray);width:30px;height:30px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s;flex-shrink:0;margin-left:auto;padding:0}
.chat-reset-btn:hover{border-color:var(--green);color:var(--green)}
.chat-counter{display:flex;align-items:center;gap:8px;padding:8px 20px;font-size:11px;font-family:var(--font-mono);color:var(--gray);background:rgba(255,255,255,.015);border-bottom:1px solid var(--dark-3)}
.chat-counter .cc-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.chat-counter.warn .cc-dot{background:#f59e0b}
.chat-counter.danger .cc-dot{background:#ef4444}
.chat-counter.warn .cc-text{color:#f59e0b}
.chat-counter.danger .cc-text{color:#ef4444;font-weight:600}
.chat-counter .cc-text{flex:1}
.cc-reset-test{display:none;background:rgba(255,170,0,.1);border:1px dashed rgba(255,170,0,.5);color:#f59e0b;font-family:var(--font-mono);font-size:10px;padding:3px 8px;border-radius:6px;cursor:pointer;transition:all .2s;margin-left:auto}
.cc-reset-test:hover{background:rgba(255,170,0,.2);border-color:#f59e0b}
.cc-reset-test.visible{display:inline-block}
/* ── Paywall banner ── */
.chat-paywall{display:none;align-items:center;gap:10px;margin:10px 14px 0;padding:10px 12px;background:linear-gradient(135deg,rgba(68,214,44,.08),rgba(68,214,44,.03));border:1px solid var(--green-border);border-radius:10px;animation:fadeUp .3s ease}
.chat-paywall.visible{display:flex}
.chat-paywall.wall{background:linear-gradient(135deg,rgba(68,214,44,.18),rgba(68,214,44,.08));border-color:var(--green);box-shadow:0 0 20px var(--green-glow)}
.chat-paywall .cp-icon{font-size:18px;flex-shrink:0}
.chat-paywall .cp-text{flex:1;font-size:11px;line-height:1.45;color:var(--gray)}
.chat-paywall .cp-text b{color:#fff}
.chat-paywall .cp-cta{flex-shrink:0;background:var(--green);color:#0D0A1A;border:none;border-radius:8px;padding:8px 12px;font-size:11px;font-weight:700;font-family:var(--font-display);cursor:pointer;transition:all .25s;white-space:nowrap}
.chat-paywall .cp-cta:hover{box-shadow:0 0 18px var(--green-glow);transform:translateY(-1px)}
.chat-paywall .cp-reset-test{display:none;flex-basis:100%;margin-top:8px;background:rgba(255,170,0,.12);border:1px dashed rgba(255,170,0,.55);color:#FFAA00;font-family:var(--font-mono);font-size:11px;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s}
.chat-paywall .cp-reset-test:hover{background:rgba(255,170,0,.22);border-color:#FFAA00}
.chat-paywall .cp-reset-test.visible{display:block}
/* ── Follow-up suggestions (relances) ── */
.chat-followup{display:flex;flex-direction:column;gap:6px;margin-top:8px;align-self:flex-start;max-width:85%}
.chat-followup-label{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--gray);padding:0 4px;margin-bottom:2px}
.chat-followup-btn{text-align:left;background:rgba(68,214,44,.06);border:1px solid var(--green-border);border-radius:10px;padding:9px 12px;font-size:12px;line-height:1.35;color:var(--white);cursor:pointer;transition:all .25s;font-family:var(--font-display);display:flex;align-items:center;gap:8px}
.chat-followup-btn:before{content:"↳";color:var(--green);font-weight:700;flex-shrink:0}
.chat-followup-btn:hover{background:var(--green-dim);border-color:var(--green);transform:translateX(2px)}
/* ── Wall state (limite atteinte) ── */
.chat-input-area.locked .chat-input{opacity:.4;pointer-events:none}
.chat-input-area.locked .chat-send{opacity:.3;pointer-events:none}

/* ══════════════════════════════════════════ */
/* ── AUTH MODAL ── */
.auth-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--white);padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .3s}
.auth-btn:hover{background:rgba(255,255,255,.12);border-color:var(--green)}
.auth-btn svg{width:16px;height:16px}
.auth-btn-logged{background:rgba(68,214,44,.1);border-color:rgba(68,214,44,.3)}
.auth-btn-logged:hover{background:rgba(68,214,44,.2)}
.auth-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:10010;align-items:center;justify-content:center;backdrop-filter:blur(4px);animation:fadeIn .2s}
.auth-overlay.open{display:flex}
.auth-modal{background:var(--dark-2);border:1px solid var(--dark-3);border-radius:20px;padding:32px;max-width:420px;width:92%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}
.auth-modal h2{font-size:20px;font-weight:700;margin-bottom:6px;color:var(--white)}
.auth-modal .auth-subtitle{font-size:13px;color:var(--gray);margin-bottom:24px}
.auth-modal label{display:block;font-size:12px;font-weight:600;color:var(--gray);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.auth-modal input[type="email"],.auth-modal input[type="password"],.auth-modal input[type="text"]{width:100%;padding:12px 14px;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;color:var(--white);font-size:14px;font-family:inherit;outline:none;margin-bottom:16px;transition:border-color .2s}
.auth-modal input:focus{border-color:var(--green)}
.auth-modal .auth-submit{width:100%;padding:14px;background:var(--green);color:#000;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}
.auth-modal .auth-submit:hover{opacity:.9;transform:translateY(-1px)}
.auth-modal .auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.auth-modal .auth-error{color:#ef4444;font-size:12px;margin-bottom:12px;display:none;padding:8px 12px;background:rgba(239,68,68,.1);border-radius:8px}
.auth-modal .auth-switch{text-align:center;margin-top:16px;font-size:13px;color:var(--gray)}
.auth-modal .auth-switch a{color:var(--green);cursor:pointer;text-decoration:none;font-weight:600}
.auth-modal .auth-switch a:hover{text-decoration:underline}
.auth-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--gray);cursor:pointer;font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}
.auth-close:hover{background:rgba(255,255,255,.1);color:var(--white)}
.auth-profile{text-align:center}
.auth-profile .auth-avatar{width:60px;height:60px;border-radius:50%;background:rgba(68,214,44,.15);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;margin:0 auto 12px}
.auth-profile .auth-email{font-size:14px;color:var(--white);font-weight:600}
.auth-profile .auth-plan{display:inline-block;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;margin-top:8px;text-transform:uppercase}
.auth-profile .auth-plan.free{background:rgba(156,163,175,.15);color:#9ca3af}
.auth-profile .auth-plan.pro{background:rgba(68,214,44,.15);color:var(--green)}
.legal-content h2{font-size:20px;font-weight:800;color:var(--white);margin:0 0 20px}
.legal-content h3{font-size:14px;font-weight:700;color:var(--green);margin:20px 0 8px}
.legal-content p{color:var(--gray);margin:0 0 12px}
.legal-content ul{color:var(--gray)}
.legal-content li{margin-bottom:6px}
.legal-content a{color:var(--green)}
.auth-profile .auth-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:20px 0;text-align:center}
.auth-profile .auth-stat{background:var(--dark);border-radius:10px;padding:12px}
.auth-profile .auth-stat-val{font-size:20px;font-weight:700;color:var(--white)}
.auth-profile .auth-stat-label{font-size:11px;color:var(--gray);margin-top:2px}
.auth-logout{width:100%;padding:12px;background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.2);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;margin-top:8px}
.auth-logout:hover{background:rgba(239,68,68,.2)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── RESPONSIVE — MOBILE FIRST ──          */
/* ══════════════════════════════════════════ */

/* Hamburger */
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;max-height:calc(100vh - 64px);overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--dark-2);border-bottom:1px solid var(--dark-3);padding:16px 20px;padding-bottom:max(20px,env(safe-area-inset-bottom));flex-direction:column;gap:12px;z-index:99;animation:fadeUp .3s ease;transition:background .4s ease;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--gray);text-decoration:none;font-size:16px;font-weight:500;padding:12px 0;border-bottom:1px solid var(--dark-3);display:block}
.mobile-menu a:last-child{border:none}
.mobile-menu a:hover,.mobile-menu a:active{color:var(--green)}
.mobile-menu .nav-cta{text-align:center;border-radius:10px;margin-top:4px;padding:14px!important;font-size:15px!important;border:none}

/* ── TABLET (max 1024px) ── */
@media(max-width:1024px){
  .features-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
  .pricing-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .guides-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .hero h1{font-size:clamp(36px,5vw,60px)}
  nav{padding:16px 28px}
}

/* ── MOBILE (max 768px) ── */
@media(max-width:768px){
  /* Nav */
  nav{padding:14px 16px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .logo{font-size:18px;letter-spacing:2px}

  /* Hero */
  .hero{min-height:auto;padding:100px 20px 60px}
  .hero h1{font-size:clamp(28px,8vw,42px);letter-spacing:-1px}
  .hero p{font-size:15px;margin-top:16px;max-width:100%}
  .hero-badge{font-size:12px;padding:6px 14px;margin-bottom:20px}

  /* Simulator */
  .simulator-section{padding:0 16px 60px}
  .simulator{padding:24px 18px;border-radius:16px}
  .sim-title{font-size:22px;margin-bottom:24px}
  .sim-input{padding:16px;font-size:16px}
  .sim-btn{padding:16px;font-size:15px}
  .project-grid{grid-template-columns:1fr 1fr;gap:10px}
  .project-card{padding:16px}
  .project-card .icon{font-size:24px;margin-bottom:6px}
  .project-card .label{font-size:13px}

  /* Dashboard cards */
  .dash-grid{grid-template-columns:1fr}
  .dash-card-header{padding:14px 16px;gap:10px}
  .dash-card-ico{width:34px;height:34px;border-radius:10px}
  .dash-card-title{font-size:13px}
  .dash-card.expanded .dash-card-body{padding:14px}
  .verdict-expert{padding:18px 20px}
  .verdict-expert-text{font-size:14px}
  /* Score */
  .score-bars{grid-template-columns:1fr}
  .score-ring-wrap{width:120px;height:120px}
  .score-ring-wrap svg{width:120px;height:120px}
  .score-number{font-size:32px}
  .score-label{font-size:14px}

  /* Results */
  .result-header{flex-direction:column;text-align:center;gap:12px}
  .result-icon{width:48px;height:48px;font-size:24px}
  .result-status{font-size:18px}
  .result-item{padding:10px 12px}
  .result-item .text{font-size:12px}
  .friction-box{padding:18px}
  .friction-title{font-size:14px}
  .result-cta{padding:20px}
  .result-cta .price{font-size:28px}

  /* Sections */
  .section-title{font-size:clamp(24px,6vw,36px);margin-bottom:40px}
  .section-label{font-size:10px;letter-spacing:2px}

  /* Features */
  .features{padding:60px 16px}
  .features-grid{grid-template-columns:1fr;gap:14px}
  .feature-card{padding:24px}
  .feature-icon{width:40px;height:40px;font-size:18px;margin-bottom:14px}
  .feature-card h3{font-size:16px}
  .feature-card p{font-size:13px}

  /* Guides */
  .guides{padding:60px 16px}
  .guides-grid{grid-template-columns:1fr;gap:8px}
  .guide-card{padding:10px}
  .guide-card h3{font-size:13px}
  .guide-card p{font-size:11px}

  /* Pricing */
  .pricing{padding:60px 16px}
  .pricing-grid{grid-template-columns:1fr;gap:12px;max-width:400px}
  .price-card{padding:28px 20px}
  .price-amount{font-size:32px}
  .price-card.featured::before{top:12px;right:12px;font-size:9px;padding:3px 8px}

  /* ABOUT */
  .about{padding:60px 16px}
  /* FAQ */
  .faq{padding:60px 16px}
  .faq-q{font-size:14px;padding:20px 0}
  .faq-a p{font-size:13px}

  /* Final CTA */
  .final-cta{padding:80px 20px}
  .final-cta h2{font-size:clamp(24px,7vw,40px)}
  .final-cta p{font-size:15px;margin-bottom:28px}
  .final-cta .sim-btn{padding:16px 36px;font-size:15px}

  /* Footer */
  footer{flex-direction:column;text-align:center;padding:32px 20px;gap:16px}
  footer .links{gap:16px;flex-wrap:wrap;justify-content:center}

  /* Chat — FULL SCREEN on mobile */
  .chat-fab{bottom:20px;right:16px;width:54px;height:54px;font-size:22px}
  .chat-window{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-height:100%;border-radius:0;z-index:10001}
  .chat-header{padding:16px 18px;padding-top:max(16px,env(safe-area-inset-top))}
  .chat-messages{padding:14px;min-height:0;flex:1}
  .chat-msg{font-size:14px;max-width:88%;padding:10px 14px}
  .chat-input-area{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom))}
  .chat-input{padding:12px;font-size:14px}
  .chat-suggestions{padding:0 14px 12px}
  .chat-sug{padding:10px 14px;font-size:12px}

  /* Chat close button on mobile — prominent back button */
  .chat-close-mobile{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:600;cursor:pointer;padding:8px 14px 8px 10px;border-radius:10px;margin-left:auto;transition:background .2s}
  .chat-close-mobile:active{background:rgba(255,255,255,.18)}

  /* Chat : compteur + reset + paywall + relances (mobile) */
  .chat-counter{padding:7px 14px;font-size:10.5px;flex-wrap:wrap;gap:6px}
  .chat-counter .cc-text{min-width:0}
  .cc-reset-test{font-size:9.5px;padding:3px 7px}
  .chat-reset-btn{width:32px;height:32px}
  .chat-paywall{margin:8px 10px 0;padding:10px;gap:8px;flex-wrap:wrap}
  .chat-paywall .cp-text{font-size:11px;flex-basis:100%;order:2}
  .chat-paywall .cp-icon{order:1;flex-basis:auto}
  .chat-paywall .cp-cta{order:3;flex:1 1 auto;padding:10px 14px;font-size:12px}
  .chat-paywall .cp-reset-test{order:4;flex-basis:100%;font-size:11px;padding:9px 12px}
  .chat-followup{max-width:92%}
  .chat-followup-btn{font-size:12px;padding:10px 12px;line-height:1.4}
  .chat-followup-label{font-size:9px}

  /* Porte d'accès testeur (mobile) */
  #testGate{padding:16px}
  #testGate .tg-card{padding:28px 20px;border-radius:16px;max-width:100%}
  #testGate .tg-logo{font-size:24px}
  #testGate .tg-subtitle{font-size:9px;margin-bottom:20px}
  #testGate .tg-badge{font-size:9px;margin-bottom:16px}
  #testGate .tg-text{font-size:12px;margin-bottom:18px}
  #testGate .tg-input{font-size:16px;padding:14px}
  #testGate .tg-btn{font-size:14px;padding:14px}
}

/* ── SMALL MOBILE (max 380px) ── */
@media(max-width:380px){
  .hero h1{font-size:26px}
  .hero p{font-size:14px}
  .simulator{padding:20px 14px}
  .sim-title{font-size:20px}
  .project-grid{gap:8px}
  .project-card{padding:14px}
  .project-card .icon{font-size:20px}
  .project-card .label{font-size:12px}
  .score-ring-wrap{width:100px;height:100px}
  .score-ring-wrap svg{width:100px;height:100px}
  .score-number{font-size:26px}
  .price-amount{font-size:28px}
  .pricing-grid{max-width:100%}
}

/* ── TOUCH IMPROVEMENTS ── */
@media(hover:none){
  .project-card:active{border-color:var(--green);background:var(--green-bg);transform:scale(.97)}
  .sim-btn:active:not(:disabled){transform:scale(.98);box-shadow:0 0 20px var(--green-glow)}
  .feature-card:active{transform:translateY(-2px)}
  .guide-card:active{transform:translateY(-2px)}
  .price-btn:active{background:var(--green-bg)}
  .chat-sug:active{border-color:var(--green);color:var(--green)}
  .faq-q:active{color:var(--green)}
}

/* Safe area for notch devices */
@supports(padding:max(0px)){
  nav{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
  .simulator-section{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
  footer{padding-bottom:max(32px,env(safe-area-inset-bottom))}
}

/* Desktop chat close hidden — uniquement écrans larges, sinon écrase la règle mobile (.chat-close-mobile{display:flex}) déclarée plus haut dans @media(max-width:768px) */
@media(min-width:769px){.chat-close-mobile{display:none}}

/* ── THEME TOGGLE ── */
.theme-toggle{background:var(--dark);border:2px solid var(--green);border-radius:50px;width:52px;height:28px;cursor:pointer;position:relative;transition:all .3s;display:flex;align-items:center;padding:2px;flex-shrink:0;box-shadow:0 0 10px rgba(68,214,44,.25)}
.theme-toggle .toggle-thumb{width:22px;height:22px;border-radius:50%;background:var(--green);transition:all .3s;display:flex;align-items:center;justify-content:center;font-size:12px;transform:translateX(0);box-shadow:0 0 6px rgba(68,214,44,.5)}
[data-theme="light"] .theme-toggle .toggle-thumb{transform:translateX(24px)}
.theme-toggle:hover{border-color:var(--green);box-shadow:0 0 16px rgba(68,214,44,.4)}
.reveal{opacity:0;transform:translateY(40px);transition:all .8s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}

/* ── SEARCH MODE TOGGLE (Adresse / Cadastre) ── */
.search-mode-toggle{display:flex;align-items:center;gap:0;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;padding:3px;margin-bottom:14px;width:fit-content}
.search-mode-btn{padding:8px 18px;border:none;background:transparent;color:var(--gray);font-size:13px;font-weight:600;font-family:var(--font-display);border-radius:8px;cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:6px}
.search-mode-btn.active{background:var(--green);color:#fff;box-shadow:0 0 12px rgba(68,214,44,.3)}
.search-mode-btn:not(.active):hover{color:var(--white);background:var(--dark-2)}
.search-mode-btn svg{width:14px;height:14px}
.cadastre-input-group{display:none;flex-direction:column;gap:10px;margin-bottom:16px}
.cadastre-input-group.show{display:flex}
.cadastre-step-row{display:flex;gap:10px;align-items:flex-start}
.cad-field{display:flex;flex-direction:column;gap:4px;position:relative}
.cad-label{font-size:11px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.5px}
.cad-combo{position:relative;display:flex;align-items:center}
.cad-combo-input{padding-right:32px!important;cursor:pointer}
.cad-combo-input:disabled{opacity:.4;cursor:not-allowed}
.cad-combo-arrow{position:absolute;right:10px;font-size:10px;color:var(--gray);pointer-events:none;transition:transform .2s}
.cad-combo.open .cad-combo-arrow{transform:rotate(180deg)}
.cad-loading{font-size:11px;color:var(--gray);font-style:italic;margin-top:2px}
@media(max-width:600px){.cadastre-step-row{flex-direction:column}}
.cadastre-row{display:flex;gap:8px;align-items:flex-start}
.cadastre-row .sim-input{margin-bottom:0}
.cadastre-hint{font-size:11px;color:var(--gray);margin-top:-4px;padding-left:4px}
.cadastre-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--dark);border:1px solid var(--dark-3);border-top:none;border-radius:0 0 12px 12px;z-index:50;max-height:220px;overflow-y:auto;display:none}
.cadastre-dropdown.show{display:block}
.cadastre-item{padding:12px 16px;cursor:pointer;font-size:13px;color:var(--gray);border-bottom:1px solid var(--dark-3);transition:all .2s;display:flex;align-items:flex-start;gap:10px}
.cadastre-item:last-child{border-bottom:none}
.cadastre-item:hover,.cadastre-item.active{background:var(--dark-2);color:var(--white)}
.cadastre-item .cad-icon{color:var(--green);flex-shrink:0;margin-top:1px}
.cadastre-item .cad-main{font-weight:500;color:var(--white);font-size:13px}
.cadastre-item .cad-detail{font-size:11px;color:var(--gray);margin-top:2px}

/* ── MAP & ADDRESS AUTOCOMPLETE ── */
.address-wrap{display:flex;align-items:flex-start;gap:8px}
.address-wrap .sim-input{width:100%;margin-bottom:0}
.address-wrap .geo-btn{flex-shrink:0;width:46px;height:46px;border:1px solid var(--green-border);background:var(--green-dim);border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--green);transition:all .3s;position:relative}
.address-wrap .geo-btn:hover{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 0 16px rgba(16,185,129,.25)}
.address-wrap .geo-btn.loading{animation:geo-pulse 1s ease infinite}
.address-wrap .geo-btn .geo-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--dark);border:1px solid var(--dark-3);border-radius:8px;padding:8px 12px;white-space:nowrap;font-size:12px;color:var(--white);font-family:var(--font-display);pointer-events:none;opacity:0;transition:opacity .2s;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:10}
.address-wrap .geo-btn .geo-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--dark-3)}
.address-wrap .geo-btn:hover .geo-tooltip{opacity:1}
@keyframes geo-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.address-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--dark);border:1px solid var(--dark-3);border-top:none;border-radius:0 0 12px 12px;z-index:50;max-height:220px;overflow-y:auto;display:none}
.address-dropdown.show{display:block}
.address-item{padding:12px 16px;cursor:pointer;font-size:14px;color:var(--gray);border-bottom:1px solid var(--dark-3);transition:all .2s;display:flex;align-items:flex-start;gap:10px}
.address-item:last-child{border-bottom:none}
.address-item:hover,.address-item.active{background:var(--dark-2);color:var(--white)}
.address-item .addr-icon{color:var(--green);font-size:16px;flex-shrink:0;margin-top:1px}
.address-item .addr-main{font-weight:500;color:var(--white);font-size:13px}
.address-item .addr-ctx{font-size:11px;color:var(--gray);margin-top:2px}
.map-placeholder{display:block;background:linear-gradient(135deg,rgba(68,214,44,.04),rgba(68,214,44,.02));border:1px dashed var(--green-border);border-radius:14px;padding:28px 22px;text-align:center;margin:0 0 18px;animation:fadeUp .4s ease}
.map-placeholder .mp-icon{font-size:32px;margin-bottom:8px;opacity:.85}
.map-placeholder .mp-title{font-size:15px;font-weight:700;color:var(--white);margin-bottom:6px}
.map-placeholder .mp-subtitle{font-size:12.5px;line-height:1.5;color:var(--gray);max-width:420px;margin:0 auto}
.map-placeholder .mp-subtitle b{color:var(--white)}
.map-placeholder .mp-geo-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--green-dim);color:var(--green);vertical-align:middle;margin:0 2px}
#mapContainer.show ~ .sim-step.active .map-placeholder,.sim-step.active #mapPlaceholder.hidden{display:none}
#mapContainer{display:none;margin:0 0 16px;border-radius:12px;overflow:hidden;border:1px solid var(--dark-3);position:relative;transition:all .4s ease;z-index:2}
#map{z-index:1;width:100%;height:500px;background:var(--dark);transition:height .4s ease}
#map .leaflet-top.leaflet-left{z-index:1001!important}
#map .leaflet-control-zoom{z-index:1001!important;pointer-events:auto!important;position:relative!important}
#map .leaflet-control-zoom a{pointer-events:auto!important;cursor:pointer!important;display:block!important;width:30px!important;height:30px!important;line-height:30px!important;text-align:center!important}
#mapContainer.show{display:block;animation:fadeUp .4s ease}
#mapContainer.compact #map{height:500px}
.terria-pin-pulse{position:absolute;left:50%;bottom:0;transform:translate(-50%,50%);width:34px;height:34px;border-radius:50%;background:rgba(68,214,44,.45);animation:terriaPulse 1.8s ease-out infinite;pointer-events:none}
.terria-pin-pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:rgba(68,214,44,.6);animation:terriaPulse 1.8s ease-out infinite;animation-delay:.6s}
@keyframes terriaPulse{0%{transform:translate(-50%,50%) scale(.4);opacity:.9}100%{transform:translate(-50%,50%) scale(2.2);opacity:0}}
#mapContainer.compact .map-hint{display:none}
#mapContainer.compact .leaflet-control-layers{display:block}
.leaflet-control-layers{background:var(--map-overlay-bg)!important;border:1px solid var(--green-border-light)!important;border-radius:8px!important;backdrop-filter:blur(8px);color:var(--gray)!important;font-size:12px!important;padding:6px 10px!important;font-family:var(--font-display)!important}
.leaflet-control-layers label{color:var(--gray)!important;cursor:pointer}
.leaflet-control-layers label:hover{color:var(--white)!important}
.leaflet-control-layers-separator{border-top-color:var(--dark-3)!important}
.map-hint{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:1000;background:rgba(13,10,26,.92);backdrop-filter:blur(8px);padding:10px 20px;border-radius:10px;font-size:13px;color:var(--green);font-weight:600;pointer-events:none;border:1px solid var(--green);white-space:nowrap;animation:hint-pulse 2s ease-in-out infinite;box-shadow:0 0 20px rgba(68,214,44,.15)}
@keyframes hint-pulse{0%,100%{box-shadow:0 0 20px rgba(68,214,44,.15);border-color:var(--green)}50%{box-shadow:0 0 30px rgba(68,214,44,.3);border-color:rgba(68,214,44,.7)}}
.map-hint .hint-arrow{display:inline-block;animation:hint-bounce 1.5s ease infinite;margin-right:6px}
@keyframes hint-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.parcel-info{background:var(--dark);border:1px solid var(--green-border-light);border-radius:10px;padding:14px 16px;margin-bottom:16px;display:none;animation:fadeUp .3s ease}
.parcel-info.show{display:flex;align-items:center;gap:12px}
.parcel-info .pi-icon{width:36px;height:36px;background:var(--green-dim);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--green);font-size:16px;flex-shrink:0}
.parcel-info .pi-text{flex:1}
.parcel-info .pi-label{font-size:13px;font-weight:600;color:var(--white)}
.parcel-info .pi-detail{font-size:11px;color:var(--gray);margin-top:2px}
.parcel-info .pi-change{background:none;border:1px solid var(--dark-3);color:var(--gray);font-size:11px;padding:6px 10px;border-radius:6px;cursor:pointer;font-family:var(--font-display);transition:all .2s}
.parcel-info .pi-change:hover{border-color:var(--green);color:var(--green)}
@media(max-width:768px){
  #map{height:600px}
  .map-hint{font-size:11px;padding:6px 12px}
  .parcel-info{padding:12px}
}
@media(max-width:380px){
  #map{height:440px}
}
/* ── CATEGORY CARDS (Step 1) ── */
.cat-card{display:flex;align-items:center;gap:20px;padding:24px;background:var(--dark);border:1px solid var(--dark-3);border-radius:16px;cursor:pointer;transition:all .4s;min-height:100px;margin-bottom:16px}
.cat-card:hover{border-color:var(--green);background:var(--green-bg);transform:translateX(4px)}
.cat-card.selected{border-color:var(--green);background:var(--green-bg)}
.cat-card .cat-icon{width:64px;height:64px;background:var(--green-dim);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--green)}
.cat-card .cat-icon svg{width:32px;height:32px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cat-card .cat-text{flex:1}
.cat-card .cat-title{font-size:18px;font-weight:700;color:var(--white);margin-bottom:6px}
.cat-card .cat-subtitle{font-size:13px;color:var(--gray);line-height:1.4}
/* ── PARCEL CHIPS (Multi-select) ── */
.parcel-chips{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.parcel-chip{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--dark);border:1px solid var(--dark-3);border-radius:10px;font-size:13px}
.parcel-chip.green{border-color:#44D62C;background:rgba(68,214,44,.08)}
.parcel-chip.orange{border-color:#FFAA00;background:rgba(255,170,0,.08)}
.parcel-chip.blue{border-color:#5B9AFF;background:rgba(91,154,255,.08)}
.parcel-chip .chip-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.parcel-chip .chip-text{flex:1;color:var(--white);font-weight:500}
.parcel-chip .chip-close{background:none;border:none;color:var(--gray);cursor:pointer;font-size:14px;padding:0;transition:color .2s;flex-shrink:0}
.parcel-chip .chip-close:hover{color:var(--green)}
.parcel-max-msg{font-size:12px;color:var(--orange);padding:8px 12px;text-align:center;font-style:italic}
/* ── ADDRESS CONFIRMATION BAR ── */
.address-confirmed{background:var(--dark);border:1px solid var(--green-border-light);border-radius:10px;padding:14px 16px;margin-bottom:16px;display:none;animation:fadeUp .3s ease}
.address-confirmed.show{display:block}
.address-confirmed .confirmed-check{display:inline-block;color:var(--green);margin-right:6px;font-weight:700}
.address-confirmed .confirmed-address{font-weight:600;color:var(--white);margin-bottom:6px;font-size:14px}
.address-confirmed .confirmed-parcels{font-size:12px;color:var(--gray)}

/* ── Modal légale (mentions, CGV, cookies, confidentialité) ── */
.legal-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:24px}
.legal-modal.open{display:flex;animation:fadeUp .3s ease}
.lm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px)}
.lm-box{position:relative;max-width:760px;width:100%;max-height:85vh;background:var(--dark-2);border:1px solid var(--dark-3);border-radius:20px;overflow-y:auto;box-shadow:0 20px 60px var(--shadow-color)}
.lm-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:var(--dark-3);border:none;color:var(--white);font-size:22px;cursor:pointer;transition:all .2s;z-index:2;display:flex;align-items:center;justify-content:center;line-height:1}
.lm-close:hover{background:var(--red);color:#fff}
.lm-content{padding:40px 48px;color:var(--white);font-size:14px;line-height:1.7}
.lm-content h2{color:var(--green);font-size:24px;margin:0 0 8px;font-family:var(--font-display)}
.lm-content h3{color:var(--green);font-size:15px;margin:24px 0 8px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.5px}
.lm-content p{margin:8px 0;color:var(--gray)}
.lm-content strong{color:var(--white)}
.lm-content em{color:var(--gray);font-size:12px}
.lm-content ul{margin:8px 0 16px 20px;color:var(--gray)}
.lm-content li{margin:4px 0;line-height:1.6}
.lm-content code{background:var(--dark);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:12px;color:var(--green)}
.lm-content a{color:var(--green);text-decoration:none}
.lm-content a:hover{text-decoration:underline}
[data-theme="light"] .lm-content{color:#1a1a2e}
[data-theme="light"] .lm-content p,[data-theme="light"] .lm-content ul{color:#4a4a5e}
[data-theme="light"] .lm-content strong{color:#1a1a2e}
@media(max-width:768px){
  .legal-modal{padding:0}
  .lm-box{max-height:100vh;border-radius:0;max-width:100%}
  .lm-content{padding:24px 20px}
  .lm-content h2{font-size:20px}
}

/* ══ BEGIN CHAT-CONTEXT-V1 ══ Bouton CTA chat contextuel sous verdict expert (v2 — visibilité + élégance) */
.chat-cta-verdict{
  margin-top:22px;
  padding-top:18px;
  border-top:1px dashed rgba(16,185,129,.22);
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  justify-content:center;
}
.chat-cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;
  border-radius:12px;
  border:1px solid rgba(16,185,129,.55);
  background:linear-gradient(135deg, rgba(16,185,129,.20), rgba(16,185,129,.08));
  color:#10b981;
  font-family:var(--font-display);
  font-size:13.5px;
  font-weight:700;
  letter-spacing:.2px;
  cursor:pointer;
  transition:all .25s ease;
  box-shadow:0 2px 14px rgba(16,185,129,.18), inset 0 1px 0 rgba(255,255,255,.06);
}
.chat-cta-btn:hover{
  background:linear-gradient(135deg, rgba(16,185,129,.32), rgba(16,185,129,.18));
  border-color:rgba(16,185,129,.95);
  box-shadow:0 8px 28px rgba(16,185,129,.40), inset 0 1px 0 rgba(255,255,255,.12);
  transform:translateY(-2px);
}
.chat-cta-btn:active{transform:translateY(0)}
.chat-cta-btn svg{width:17px;height:17px;flex-shrink:0;stroke-width:2.2}
.chat-cta-hint{font-size:12px;color:var(--gray);font-style:italic;opacity:.85}
[data-theme="light"] .chat-cta-verdict{border-top-color:rgba(27,140,10,.22)}
[data-theme="light"] .chat-cta-btn{
  background:linear-gradient(135deg, rgba(27,140,10,.14), rgba(27,140,10,.05));
  border-color:rgba(27,140,10,.55);
  color:#1B8C0A;
  box-shadow:0 2px 14px rgba(27,140,10,.14), inset 0 1px 0 rgba(255,255,255,.6);
}
[data-theme="light"] .chat-cta-btn:hover{
  background:linear-gradient(135deg, rgba(27,140,10,.24), rgba(27,140,10,.12));
  box-shadow:0 8px 28px rgba(27,140,10,.30), inset 0 1px 0 rgba(255,255,255,.7);
}
@media(max-width:768px){
  .chat-cta-verdict{flex-direction:column;align-items:stretch;gap:10px}
  .chat-cta-btn{justify-content:center;width:100%;padding:14px 20px}
  .chat-cta-hint{text-align:center}
}
/* ══ END CHAT-CONTEXT-V1 ══ */
