/* ===== SafeRoad DZ — light theme (navy + jaune / sécurité routière) ===== */
:root{
  --paper:#FBFAF6; --cream:#F5EFE1; --white:#FFFFFF; --sand:#EAE3D4;
  --text:#16243A; --text-2:#33425C; --muted:#64718A; --muted-2:#929CB0;
  --line:#EBE3D0; --line-2:#F1EADB;
  --gold:#FBB613; --gold-dark:#E09A0C; --gold-ink:#9A6300; --gold-soft:#FFF3D2; --gold-line:#F3E2A6;
  --red:#D11A2B;
  --radius:18px; --maxw:1180px;
  --shadow:0 18px 40px -22px rgba(22,36,58,.28);
  --shadow-sm:0 8px 22px -14px rgba(22,36,58,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--text);font-family:"Plus Jakarta Sans",system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.ar{font-family:"Cairo",sans-serif}
h1,h2,h3,.disp{font-family:"Bricolage Grotesque","Plus Jakarta Sans",sans-serif}

/* nav */
header.site{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(251,250,246,.85);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Bricolage Grotesque";font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--text)}
.brand b{color:var(--gold-ink)}
.brand-logo{width:44px;height:44px;flex:none;object-fit:cover;display:block;border-radius:11px;box-shadow:var(--shadow-sm)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:var(--text-2);font-size:15px;font-weight:600;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-ink)}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:800;border-radius:12px;padding:12px 20px;font-size:15px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .25s ease,background .2s;font-family:"Plus Jakarta Sans"}
.btn-primary{background:var(--gold);color:var(--text);box-shadow:0 10px 24px -10px rgba(251,182,19,.75)}
.btn-primary:hover{transform:translateY(-2px);background:var(--gold-dark);box-shadow:0 16px 30px -12px rgba(251,182,19,.7)}
.btn-ghost{border-color:var(--line);color:var(--text);background:var(--white)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-ink)}
.menu-btn{display:none;background:var(--white);border:1px solid var(--line);border-radius:10px;padding:8px;cursor:pointer}
.menu-btn svg{stroke:var(--text);width:22px;height:22px}

/* official google play badge */
.gplay{display:inline-block;height:54px;border-radius:9px;transition:transform .15s ease,box-shadow .25s ease;box-shadow:var(--shadow-sm)}
.gplay svg{height:54px;width:auto;display:block}
.gplay:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

/* hero */
.hero{position:relative;z-index:1;padding:60px 0 80px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--gold-ink);background:var(--gold-soft);border:1px solid var(--gold-line);padding:7px 14px;border-radius:100px;margin-bottom:22px}
.eyebrow .dz{color:var(--text-2);font-weight:600}
h1{font-weight:800;font-size:clamp(36px,5vw,58px);line-height:1.07;letter-spacing:-.02em;margin-bottom:20px}
h1 .hl{background:linear-gradient(transparent 58%,var(--gold) 58%);padding:0 .05em;border-radius:2px}
.lead{font-size:clamp(16px,2vw,19px);color:var(--text-2);max-width:520px;margin-bottom:30px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.trust{display:flex;align-items:center;gap:10px;margin-top:24px;color:var(--muted);font-size:14px}
.trust b{color:var(--text)}
.stars{color:var(--gold);letter-spacing:1px}

/* hero photo */
.hero-photo{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);aspect-ratio:4/5;background:#cfe0ec}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-badge{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);border-radius:100px;padding:8px 15px;font-weight:700;font-size:13.5px;color:var(--text);box-shadow:var(--shadow-sm)}
.hero-badge .d{width:9px;height:9px;border-radius:50%;background:var(--gold)}
.alert-card{position:absolute;left:18px;right:18px;bottom:18px;display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow)}
.alert-card .ic{width:44px;height:44px;flex:none;border-radius:12px;display:grid;place-items:center;font-size:22px;background:var(--gold-soft)}
.alert-card .t1{font-family:"Bricolage Grotesque";font-weight:700;font-size:15.5px;color:var(--text)}
.alert-card .t2{font-size:13px;color:var(--gold-ink);font-weight:700}

/* sections */
section{position:relative;z-index:1}
.sec{padding:88px 0}
.sec.alt{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head.center{margin:0 auto 48px;text-align:center}
.kicker{font-weight:800;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-ink);margin-bottom:14px;display:block}
h2{font-weight:800;font-size:clamp(27px,3.4vw,40px);line-height:1.1;letter-spacing:-.015em;margin-bottom:14px}
.sec-head p{color:var(--text-2);font-size:17px}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm)}
.step .num{font-family:"Bricolage Grotesque";font-weight:800;font-size:18px;color:var(--text);background:var(--gold);width:44px;height:44px;border-radius:13px;display:grid;place-items:center;margin-bottom:20px}
.step h3{font-weight:700;font-size:20px;margin-bottom:10px}
.step p{color:var(--text-2);font-size:15px}

.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-sm)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .fi{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:24px;margin-bottom:18px;background:var(--gold-soft)}
.card h3{font-weight:700;font-size:18px;margin-bottom:9px}
.card p{color:var(--text-2);font-size:14.5px}

.hazards{background:var(--white);border:1px solid var(--line);border-radius:24px;padding:42px;box-shadow:var(--shadow-sm)}
.hz-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
.hz{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:14px 16px}
.hz .e{font-size:22px}.hz span{font-size:14.5px;font-weight:600}

.proof{display:grid;grid-template-columns:1.1fr 1fr;gap:46px;align-items:center}
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:28px}
.metric{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm)}
.metric .big{font-family:"Bricolage Grotesque";font-weight:800;font-size:34px;color:var(--gold-dark);line-height:1}
.metric .lbl{color:var(--muted);font-size:14px;margin-top:6px;font-weight:600}
.vote-demo{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow-sm)}
.vote-demo .vh{font-weight:700;font-size:14px;color:var(--muted);margin-bottom:6px}
.vote-row{display:flex;align-items:center;justify-content:space-between;padding:15px 0;border-bottom:1px solid var(--line-2)}
.vote-row:last-child{border:none}
.vote-l{display:flex;align-items:center;gap:12px}
.vote-l .e{font-size:22px}
.vote-l b{font-weight:700;font-size:15px;display:block}
.vote-l small{color:var(--muted);font-size:12.5px}
.conf{font-weight:800;font-size:13px;color:var(--gold-ink);display:flex;align-items:center;gap:8px}
.conf .bar{width:56px;height:7px;border-radius:4px;background:var(--cream);overflow:hidden}
.conf .bar i{display:block;height:100%;background:var(--gold);border-radius:4px}

.faq{max-width:780px;margin:0 auto}
.q{border:1px solid var(--line);border-radius:14px;margin-bottom:12px;background:var(--white);box-shadow:var(--shadow-sm)}
.q button{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;background:none;border:none;color:var(--text);cursor:pointer;padding:20px 22px;text-align:left;font-family:"Bricolage Grotesque";font-weight:700;font-size:17.5px}
.q button .x{flex:none;width:28px;height:28px;border-radius:9px;border:1px solid var(--line);display:grid;place-items:center;transition:transform .25s,background .2s,color .2s;font-size:20px;color:var(--gold-ink)}
.q.open button .x{transform:rotate(45deg);background:var(--gold);color:var(--text);border-color:var(--gold)}
.q .a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.q .a p{color:var(--text-2);font-size:15.5px;padding:0 22px 22px}

/* final cta with road strip */
.final{position:relative;z-index:1;padding:0 0 90px}
.final-box{position:relative;border-radius:26px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);text-align:center;padding:72px 30px}
.final-box .bgimg{position:absolute;inset:0;z-index:0}
.final-box .bgimg img{width:100%;height:100%;object-fit:cover}
.final-box .bgimg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(251,250,246,.92),rgba(251,250,246,.82))}
.final-box>.inner{position:relative;z-index:1}
.final h2{margin-bottom:14px}
.final p{color:var(--text-2);max-width:520px;margin:0 auto 28px;font-size:17px}

/* content / legal pages */
.page-hero{position:relative;z-index:1;padding:64px 0 42px;border-bottom:1px solid var(--line);background:var(--cream)}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-size:clamp(30px,4.6vw,48px);margin-bottom:12px}
.page-hero p{color:var(--text-2);font-size:18px;max-width:620px}
.article{position:relative;z-index:1;padding:54px 0 84px}
.article-wrap{max-width:820px;margin:0 auto}
.block{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 32px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.block h2{font-size:clamp(20px,2.3vw,25px);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.block h2 .em{font-size:24px}
.block h3{font-weight:700;font-size:18px;margin:20px 0 8px;color:var(--text)}
.block p{color:var(--text-2);font-size:15.5px;margin-bottom:12px}
.block p:last-child{margin-bottom:0}
.block ul{list-style:none;margin:10px 0}
.block li{color:var(--text-2);font-size:15.5px;padding:7px 0 7px 26px;position:relative}
.block li::before{content:"";position:absolute;left:4px;top:15px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.block a{color:var(--gold-ink);border-bottom:1px solid var(--gold-line)}
.block a:hover{color:var(--gold-dark)}
.tag{display:inline-block;font-size:11.5px;font-weight:700;color:var(--gold-ink);background:var(--gold-soft);border:1px solid var(--gold-line);border-radius:7px;padding:3px 9px;margin-left:8px;vertical-align:middle}
.tag.soon{color:var(--gold-dark);background:#FFF8E6;border-color:var(--gold-line)}
.callout{background:var(--gold-soft);border:1px solid var(--gold-line);border-radius:var(--radius);padding:26px 30px;margin-bottom:18px}
.callout p{color:var(--text);font-size:15.5px;margin:0}
.updated{color:var(--muted);font-size:13px;margin-top:8px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.field{margin-bottom:16px}
.field label{display:block;font-size:14px;font-weight:700;margin-bottom:7px;color:var(--text)}
.field input,.field textarea{width:100%;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--text);font-family:inherit;font-size:15px;transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{min-height:140px;resize:vertical}
.info-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.info-card .row{display:flex;gap:14px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line-2)}
.info-card .row:last-child{border:none}
.info-card .ic{width:44px;height:44px;flex:none;border-radius:12px;display:grid;place-items:center;font-size:20px;background:var(--gold-soft)}
.info-card .row b{font-weight:700;font-size:15px;display:block}
.info-card .row small{color:var(--muted);font-size:14px}

/* footer */
footer.site{position:relative;z-index:1;border-top:1px solid var(--line);padding:52px 0 38px;background:var(--cream)}
.foot{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{color:var(--text-2);font-size:14px;font-weight:600;transition:color .2s}
.foot-links a:hover{color:var(--gold-ink)}
.foot .copy{color:var(--muted);font-size:13px;margin-top:18px;width:100%;border-top:1px solid var(--line);padding-top:22px}

/* hazards app-style (3 catégories réelles) */
.hz3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.hzc{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px 26px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.hzc:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.hzc-ic{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;box-shadow:var(--shadow-sm)}
.hzc-ic svg{width:42px;height:42px}
.hzc-ic.red{background:#E5332A}.hzc-ic.orange{background:#F5871F}.hzc-ic.yellow{background:var(--gold)}
.hzc h3{font-weight:700;font-size:19px;margin-bottom:8px}
.hzc p{color:var(--text-2);font-size:14.5px}

/* app screenshots */
.shots{display:flex;justify-content:center;gap:42px;flex-wrap:wrap;margin-top:6px}
.phone{width:286px;border-radius:42px;overflow:hidden;border:11px solid #15171C;box-shadow:var(--shadow);background:#15171C}
.phone img{display:block;width:100%;height:auto}

/* hero app screenshots (duo) */
.hero-shots{display:flex;justify-content:center;align-items:center;padding:6px 0}
.hero-shots .phone{width:230px;flex:none;border-width:9px;border-radius:36px}
.hero-shots .p-front{z-index:2;transform:rotate(-3deg);box-shadow:0 34px 60px -26px rgba(22,36,58,.45)}
.hero-shots .p-back{z-index:1;margin-left:-122px;margin-top:38px;transform:rotate(5deg)}

/* reveal + focus */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
:focus-visible{outline:2px solid var(--gold-dark);outline-offset:3px;border-radius:6px}

@media(max-width:900px){
  .hero-grid,.proof,.contact-grid{grid-template-columns:1fr;gap:36px}
  .hero-photo{max-width:460px;margin:0 auto;width:100%;aspect-ratio:16/13}
  .steps,.feat,.hz3{grid-template-columns:1fr}
  .phone{width:250px}
  .hero-shots .phone{width:170px;border-width:8px}
  .hero-shots .p-back{margin-left:-80px;margin-top:24px}
  .hz-grid,.metrics{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .menu-btn{display:grid;place-items:center}
  .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--white);border-bottom:1px solid var(--line);padding:8px 24px 18px;box-shadow:var(--shadow)}
  .nav-links.open a{padding:14px 0;border-bottom:1px solid var(--line);width:100%}
  .nav-links.open .btn{margin-top:10px}
  .sec{padding:64px 0}
}
@media(max-width:480px){
  .hz-grid,.metrics{grid-template-columns:1fr}
  .hazards,.block{padding:24px}
  .final-box{padding:52px 22px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
