/* assets/style.css — RoadZone */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --orange:#EA580C;--orange2:#F97316;--dark:#111827;--darker:#0d1117;
  --text:#F9FAFB;--muted:#9CA3AF;--border:rgba(255,255,255,0.08);
  --r:14px;--rs:8px;
}
body{font-family:'DM Sans',sans-serif;background:var(--darker);color:var(--text);overflow-x:hidden}

/* ── Navigation ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(13,17,23,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo img{height:44px;width:44px;object-fit:cover;border-radius:10px}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:20px;color:white}
.nav-logo-text span{color:var(--orange)}
.nav-links{display:flex;align-items:center;gap:20px}
.nav-links a{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:color .15s}
.nav-links a:hover{color:white}
.nav-cta{background:var(--orange);color:white;border:none;padding:10px 20px;border-radius:var(--rs);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:opacity .2s;display:inline-flex;align-items:center}
.nav-cta:hover{opacity:.88}
@media(max-width:768px){.nav-links{display:none}nav{padding:0 1rem}}

/* ── Hero ── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:100px 2rem 60px;background:radial-gradient(ellipse at 50% 0%, rgba(234,88,12,0.15) 0%, transparent 70%)}
.hero-badge{background:rgba(234,88,12,0.15);border:1px solid rgba(234,88,12,0.3);color:var(--orange2);padding:6px 16px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:24px;display:inline-block}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,4.5rem);line-height:1.15;margin-bottom:20px;max-width:800px}
.hero h1 em{color:var(--orange);font-style:normal}
.hero p{font-size:1.1rem;color:var(--muted);max-width:580px;line-height:1.7;margin-bottom:36px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:32px}
.btn-primary{background:linear-gradient(135deg,var(--orange),#C2410C);color:white;padding:14px 32px;border-radius:10px;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:opacity .2s}
.btn-primary:hover{opacity:.9}
.btn-secondary{background:rgba(255,255,255,0.08);color:white;padding:14px 32px;border-radius:10px;font-family:inherit;font-size:15px;font-weight:500;cursor:pointer;border:1.5px solid rgba(255,255,255,0.15);text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-secondary:hover{border-color:var(--orange);color:var(--orange)}
.hero-logo{width:160px;height:160px;object-fit:cover;border-radius:24px;margin-bottom:32px;box-shadow:0 20px 60px rgba(234,88,12,0.3)}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;justify-content:center}
.stat{text-align:center}
.stat-val{font-size:2rem;font-weight:700;color:var(--orange)}
.stat-lbl{font-size:12px;color:var(--muted);margin-top:2px}

/* ── Sections ── */
.section{padding:80px 2rem}
.container{max-width:1100px;margin:0 auto}
.section-header{text-align:center;margin-bottom:50px}
.section-header h2{font-family:'Playfair Display',serif;font-size:2.2rem;margin-bottom:12px}
.section-header p{color:var(--muted);font-size:1rem;max-width:520px;margin:0 auto;line-height:1.7}

/* ── Événements ── */
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.event-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.event-card:hover{border-color:rgba(234,88,12,0.4)}
.event-header{background:linear-gradient(135deg,#1f2937,#374151);padding:20px;display:flex;gap:14px;align-items:flex-start}
.event-date{background:var(--orange);color:white;border-radius:8px;padding:8px 12px;text-align:center;min-width:52px;flex-shrink:0}
.event-day{font-size:22px;font-weight:700;line-height:1}
.event-month{font-size:9px;text-transform:uppercase;opacity:.85}
.event-title{font-size:15px;font-weight:600;margin-bottom:4px}
.event-org{font-size:11px;color:rgba(255,255,255,0.6)}
.event-body{padding:14px 20px}
.event-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;color:var(--muted);margin-bottom:8px}
.event-desc{font-size:12px;color:var(--muted);line-height:1.6}
.event-badge{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}
.badge-gratuit{background:rgba(16,185,129,0.15);color:#10B981}
.badge-payant{background:rgba(234,88,12,0.15);color:var(--orange)}
.ftab-ev{padding:9px 18px;border:1.5px solid var(--border);background:transparent;border-radius:20px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;color:var(--muted);transition:all .15s;text-decoration:none;display:inline-block}
.ftab-ev.active{background:var(--orange);color:white;border-color:var(--orange)}
.ftab-ev:hover:not(.active){border-color:var(--orange);color:var(--orange)}

/* ── Catégories ── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.cat-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--r);padding:24px 20px;text-align:center;cursor:pointer;transition:all .2s;text-decoration:none;color:var(--text)}
.cat-card:hover{border-color:var(--orange);background:rgba(234,88,12,0.06)}
.cat-ico{font-size:36px;margin-bottom:12px}
.cat-name{font-size:14px;font-weight:600;margin-bottom:4px}
.cat-nb{font-size:11px;color:var(--muted)}

/* ── Formulaires ── */
.forms-tabs{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}
.ftab{padding:10px 22px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.ftab.active{background:var(--orange);color:white;border-color:var(--orange)}
.form-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--r);padding:32px;max-width:680px;margin:0 auto}
.fg{margin-bottom:16px}
.fl{font-size:12px;color:var(--muted);font-weight:500;display:block;margin-bottom:5px}
.fi{width:100%;background:rgba(255,255,255,0.06);border:1.5px solid rgba(255,255,255,0.1);border-radius:var(--rs);padding:11px 14px;color:white;font-family:inherit;font-size:13px;outline:none;transition:border-color .15s}
.fi:focus{border-color:var(--orange)}
textarea.fi{min-height:80px;resize:vertical}
.fi option{background:#1f2937;color:white}
.fg-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:500px){.fg-2{grid-template-columns:1fr}}
.moto-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid rgba(255,255,255,0.1);border-radius:20px;font-size:12px;cursor:pointer;color:var(--muted);transition:all .15s}
.moto-pill:hover{border-color:var(--orange)}
.moto-pill input{accent-color:var(--orange)}
.vdot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.2)}
.vdot.active{background:var(--orange)}
.vdot.done{background:#10B981}

/* ── Steps ── */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.step-card{text-align:center;padding:28px 20px}
.step-nb{width:48px;height:48px;border-radius:50%;background:var(--orange);color:white;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step-title{font-size:16px;font-weight:600;margin-bottom:8px}
.step-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* ── Carte ── */
#carte-roadzone{height:420px;border-radius:14px;border:1.5px solid rgba(234,88,12,0.3);overflow:hidden;margin-bottom:12px}
.leaflet-popup-content-wrapper{background:#1f2937;color:white;border:1px solid rgba(234,88,12,0.4)}
.leaflet-popup-tip{background:#1f2937}

/* ── Footer ── */
footer{background:#0d1117;border-top:1px solid var(--border);padding:40px 2rem;text-align:center}
.footer-links{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.footer-links a{color:var(--muted);text-decoration:none;font-size:13px}
.footer-links a:hover{color:var(--orange)}

/* ── PWA Banner ── */
.pwa-banner{background:linear-gradient(135deg,rgba(234,88,12,0.12),rgba(249,115,22,0.08));border:1px solid rgba(234,88,12,0.25);border-radius:14px;padding:20px 24px;margin:0 auto 32px;max-width:600px;text-align:center}

/* ── Alerts / Messages ── */
.alert{padding:14px 18px;border-radius:var(--rs);margin-bottom:16px;font-size:13px}
.alert-success{background:rgba(16,185,129,0.15);border:1px solid rgba(16,185,129,0.3);color:#10B981}
.alert-error{background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);color:#EF4444}
