/* ================= OTOKAR RÉUNION ================= */
:root{
  --rouge:#e2001a;
  --rouge-fonce:#b40015;
  --noir:#0e0e10;
  --anthracite:#1a1c1f;
  --gris:#5b6068;
  --gris-clair:#e7e8ea;
  --beige:#f4f2ee;
  --blanc:#ffffff;
  --ombre:0 18px 50px rgba(14,14,16,.16);
  --ombre-douce:0 6px 24px rgba(14,14,16,.08);
  --radius:18px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk",sans-serif;
  color:var(--noir);background:var(--blanc);
  line-height:1.6;font-size:17px;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;line-height:1.05;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1200px,92vw);margin:0 auto}
.accent{color:var(--rouge)}
.kicker{font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rouge);margin-bottom:16px;display:block}

/* ---------- HEADER ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--gris-clair)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:24px}
.brand{display:flex;align-items:center;gap:15px}
.brand .logo{height:34px;width:auto;display:block}
.brand .zone{
  align-self:stretch;display:flex;align-items:center;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--rouge);padding-left:15px;border-left:1.5px solid var(--gris-clair);
}
.menu{display:flex;gap:30px;align-items:center;font-weight:600;font-size:.98rem}
.menu a{position:relative;padding:4px 0;color:var(--anthracite)}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--rouge);transition:width .25s ease}
.menu a:hover::after,.menu a.current::after{width:100%}
.menu a.current{color:var(--noir)}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.burger span{width:26px;height:2.5px;background:var(--noir);border-radius:2px;transition:.3s}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--rouge);color:#fff;font-weight:700;padding:13px 24px;border-radius:100px;border:none;cursor:pointer;font-size:.98rem;font-family:inherit;transition:transform .2s ease,background .2s ease}
.btn:hover{background:var(--rouge-fonce);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--noir);border:1.5px solid var(--noir)}
.btn.ghost:hover{background:var(--noir);color:#fff}
.btn.light{background:#fff;color:var(--noir)}
.btn.light:hover{background:var(--beige)}
.btn.ondark.ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.btn.ondark.ghost:hover{background:#fff;color:var(--noir)}

/* ---------- SECTIONS ---------- */
section{padding:96px 0}
.section-head{max-width:760px;margin-bottom:56px}
.section-head h2{font-size:clamp(2rem,4vw,3.1rem);margin-bottom:18px}
.section-head p{font-size:1.12rem;color:var(--gris)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;color:#fff;overflow:hidden;background:
  radial-gradient(circle at 82% 8%,rgba(226,0,26,.20),transparent 46%),
  radial-gradient(circle at 4% 92%,rgba(226,0,26,.10),transparent 44%),
  linear-gradient(180deg,var(--noir),#16181c)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:54px 54px;opacity:.5}
.hero .wrap{position:relative;padding:84px 0 0;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:8px 16px;border-radius:100px;margin-bottom:26px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--rouge)}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.5rem);margin-bottom:22px}
.hero p.lead{font-size:1.2rem;color:#c7cad0;max-width:34ch;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:flex;gap:36px;padding-top:30px;border-top:1px solid rgba(255,255,255,.12)}
.hero-stats .n{font-family:"Bricolage Grotesque";font-weight:800;font-size:2rem;color:#fff}
.hero-stats .l{font-size:.86rem;color:#9aa0a8;line-height:1.3}
.hero-visual{position:relative}
.hero-visual img{width:100%;border-radius:var(--radius);filter:drop-shadow(0 30px 50px rgba(0,0,0,.5))}
.hero-tag{position:absolute;bottom:26px;left:-14px;background:#fff;color:var(--noir);border-radius:14px;padding:14px 18px;box-shadow:var(--ombre);font-weight:700}
.hero-tag span{display:block;font-size:.78rem;color:var(--gris);font-weight:600}
.hero-wave{display:block;width:100%;height:auto;margin-top:-2px}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{position:relative;color:#fff;background:
  radial-gradient(circle at 88% 12%,rgba(226,0,26,.22),transparent 50%),
  linear-gradient(180deg,var(--noir),#17191d);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:54px 54px;opacity:.45}
.page-hero .wrap{position:relative;padding:70px 0 64px}
.crumb{font-size:.86rem;color:#9aa0a8;margin-bottom:22px}
.crumb a:hover{color:#fff}
.crumb span{color:var(--rouge)}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.8rem);max-width:18ch;margin-bottom:18px}
.page-hero p{font-size:1.15rem;color:#c7cad0;max-width:54ch}
.page-hero .kicker{color:#ff5a6e}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--rouge);color:#fff;overflow:hidden;padding:14px 0}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 28s linear infinite;font-weight:700;letter-spacing:.04em;font-size:.95rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- TABS + VEHICLE CARDS ---------- */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
.tab{padding:11px 22px;border-radius:100px;border:1.5px solid var(--gris-clair);background:#fff;font-weight:700;font-size:.95rem;cursor:pointer;font-family:inherit;color:var(--anthracite);transition:.2s}
.tab.active{background:var(--noir);color:#fff;border-color:var(--noir)}
.tab:hover:not(.active){border-color:var(--noir)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.panel{display:none}
.panel.active{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.card{background:#fff;border:1px solid var(--gris-clair);border-radius:var(--radius);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--ombre)}
.card .media{background:var(--beige);padding:26px;display:flex;align-items:center;justify-content:center;min-height:180px}
.card .media img{width:100%;object-fit:contain}
.card .body{padding:24px;flex:1;display:flex;flex-direction:column}
.tagline{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:6px 13px;border-radius:100px;margin-bottom:14px;background:var(--beige);color:var(--anthracite);border:1px solid var(--gris-clair)}
.tagline::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--rouge)}
.tagline.diesel::before{background:var(--noir)}
.tagline.gnv::before{background:var(--gris)}
.card h3{font-size:1.45rem;margin-bottom:6px}
.card .sub{color:var(--gris);font-size:.94rem;margin-bottom:18px}
.specs{list-style:none;margin-top:auto;border-top:1px solid var(--gris-clair);padding-top:16px;display:grid;gap:8px}
.specs li{display:flex;justify-content:space-between;font-size:.9rem}
.specs li span:first-child{color:var(--gris)}
.specs li span:last-child{font-weight:700}
.card .more{margin-top:18px;font-weight:700;font-size:.92rem;color:var(--rouge);display:inline-flex;align-items:center;gap:7px}
.card .more svg{width:16px;height:16px;stroke:var(--rouge);fill:none;stroke-width:2;transition:transform .2s}
.card:hover .more svg{transform:translateX(4px)}

/* ---------- REASONS ---------- */
.tone-beige{background:var(--beige)}
.reason-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.reason{background:#fff;border-radius:var(--radius);padding:34px;border:1px solid var(--gris-clair)}
.reason .ico{width:52px;height:52px;border-radius:13px;background:var(--noir);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.reason .ico svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:1.8}
.reason h3{font-size:1.35rem;margin-bottom:12px}
.reason p{color:var(--gris);font-size:1rem}

/* ---------- SPLIT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--ombre)}
.split .stack{display:grid;gap:22px;margin-top:28px}
.split .stack div{padding-left:22px;border-left:3px solid var(--rouge)}
.split .stack h4{font-size:1.2rem;margin-bottom:6px}
.split .stack p{color:var(--gris)}

/* ---------- DARK SERVICES ---------- */
.dark{background:var(--noir);color:#fff}
.dark .section-head h2{color:#fff}
.dark .section-head p{color:#b6bbc2}
.dark .kicker{color:#ff5a6e}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.serv{background:var(--anthracite);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:32px}
.serv .num{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.1rem;color:var(--rouge);margin-bottom:16px}
.serv h3{font-size:1.3rem;margin-bottom:12px}
.serv p{color:#aeb3ba;font-size:.97rem}

/* ---------- FAQ ---------- */
.faq-grid{display:grid;gap:14px;max-width:880px}
details{background:#fff;border:1px solid var(--gris-clair);border-radius:14px;padding:6px 24px;transition:.2s}
details[open]{border-color:var(--noir);box-shadow:var(--ombre-douce)}
summary{list-style:none;cursor:pointer;font-family:"Bricolage Grotesque";font-weight:700;font-size:1.12rem;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:20px}
summary::-webkit-details-marker{display:none}
summary .plus{flex:none;width:26px;height:26px;border-radius:50%;background:var(--beige);position:relative;transition:.3s}
summary .plus::before,summary .plus::after{content:"";position:absolute;background:var(--noir);left:50%;top:50%;transform:translate(-50%,-50%);transition:.3s}
summary .plus::before{width:12px;height:2px}
summary .plus::after{width:2px;height:12px}
details[open] summary .plus{background:var(--rouge)}
details[open] summary .plus::before,details[open] summary .plus::after{background:#fff}
details[open] summary .plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
details .answer{padding:0 0 22px;color:var(--gris)}

/* ---------- ABOUT / STATS ---------- */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.stat{background:#fff;border:1px solid var(--gris-clair);border-radius:var(--radius);padding:32px}
.stat .n{font-family:"Bricolage Grotesque";font-weight:800;font-size:2.6rem;color:var(--rouge);line-height:1}
.stat .l{color:var(--gris);margin-top:10px;font-size:.98rem}
.prose{max-width:760px}
.prose p{color:var(--gris);margin-bottom:18px;font-size:1.08rem}
.prose h3{font-size:1.5rem;margin:36px 0 14px}
.value-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.value{padding:28px;border:1px solid var(--gris-clair);border-radius:var(--radius);background:#fff}
.value h4{font-size:1.2rem;margin-bottom:10px}
.value p{color:var(--gris)}

/* ---------- CONTACT / FORMS ---------- */
.contact-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:48px;align-items:start}
.contact-info h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:20px}
.contact-info p{color:var(--gris);margin-bottom:30px}
.info-list{display:grid;gap:18px}
.info-list .row{display:flex;gap:14px;align-items:flex-start}
.info-list .row svg{width:22px;height:22px;stroke:var(--rouge);fill:none;stroke-width:1.8;flex:none;margin-top:3px}
.info-list .row b{display:block}
.info-list .row span{color:var(--gris);font-size:.95rem}

.formcard{background:#fff;border-radius:var(--radius);padding:38px;border:1px solid var(--gris-clair);box-shadow:var(--ombre)}
.formcard .fc-head{margin-bottom:26px}
.formcard .fc-head h2{font-size:1.7rem;margin-bottom:8px}
.formcard .fc-head p{color:var(--gris);font-size:.98rem}
fieldset{border:none;margin:0 0 26px}
.legend{font-family:"Bricolage Grotesque";font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gris);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.legend::after{content:"";flex:1;height:1px;background:var(--gris-clair)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px}
.field .req{color:var(--rouge)}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--gris-clair);border-radius:11px;font-family:inherit;font-size:.98rem;background:#fafafa;color:var(--noir);transition:.2s}
.field input::placeholder,.field textarea::placeholder{color:#9aa0a8}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--rouge);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.08)}
.field textarea{resize:vertical;min-height:120px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235b6068' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:40px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* selectable option cards (radios) */
.options{display:grid;gap:12px}
.options.cols-4{grid-template-columns:repeat(4,1fr)}
.options.cols-3{grid-template-columns:repeat(3,1fr)}
.opt{position:relative}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.opt label{display:flex;flex-direction:column;gap:4px;padding:16px;border:1.5px solid var(--gris-clair);border-radius:13px;cursor:pointer;transition:.2s;background:#fafafa;height:100%}
.opt label b{font-size:.98rem}
.opt label small{color:var(--gris);font-size:.82rem;font-weight:500}
.opt input:checked+label{border-color:var(--rouge);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.08)}
.opt input:focus-visible+label{border-color:var(--noir)}

/* quantity stepper */
.stepper{display:inline-flex;align-items:center;border:1.5px solid var(--gris-clair);border-radius:11px;overflow:hidden;background:#fafafa}
.stepper button{width:46px;height:48px;border:none;background:#fff;font-size:1.3rem;cursor:pointer;color:var(--noir);font-family:inherit;transition:.15s}
.stepper button:hover{background:var(--beige)}
.stepper input{width:64px;text-align:center;border:none;background:transparent;font-size:1.05rem;font-weight:700;font-family:inherit}
.stepper input:focus{outline:none}

.consent{display:flex;gap:11px;font-size:.85rem;color:var(--gris);margin:6px 0 22px;align-items:flex-start}
.consent input{margin-top:4px;width:18px;height:18px;accent-color:var(--rouge);flex:none}
.form-note{font-size:.82rem;color:var(--gris);margin-top:14px;text-align:center}
.form-ok{display:none;text-align:center;padding:30px;border:1.5px solid #cfe9d6;background:#f1faf3;border-radius:14px;color:#1c7a40;font-weight:600}
.form-ok.show{display:block}

/* ---------- CTA BAND ---------- */
.cta-band{background:var(--rouge);color:#fff;border-radius:var(--radius);padding:54px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-band h2{font-size:clamp(1.7rem,3vw,2.4rem);max-width:20ch}
.cta-band p{color:rgba(255,255,255,.85);margin-top:8px}

/* ---------- FOOTER ---------- */
footer{background:var(--noir);color:#c7cad0;padding:72px 0 30px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .brand{margin-bottom:18px}
.foot-brand .brand .logo{height:30px}
.foot-brand .brand .zone{border-left-color:rgba(255,255,255,.22)}
.foot-brand p{font-size:.95rem;max-width:34ch;color:#9aa0a8}
.foot-col h4{font-family:"Hanken Grotesk";font-weight:700;color:#fff;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px}
.foot-col a{display:block;padding:6px 0;font-size:.95rem;color:#9aa0a8;transition:.2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:26px;font-size:.86rem;color:#8a8f97}
.foot-bottom a{color:#8a8f97}
.foot-bottom a:hover{color:#fff}

/* ---------- LEGAL PAGE ---------- */
.legal{max-width:820px}
.legal h2{font-size:1.5rem;margin:38px 0 12px}
.legal h2:first-child{margin-top:0}
.legal p{color:var(--gris);margin-bottom:14px}
.legal ul{color:var(--gris);margin:0 0 14px 20px}
.legal li{margin-bottom:6px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;padding-top:56px}
  .hero-visual{order:-1}
  .split,.contact-grid{grid-template-columns:1fr;gap:34px}
  .grid3,.panel.active,.serv-grid,.reason-grid,.value-grid,.stat-row,.three{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .options.cols-4{grid-template-columns:1fr 1fr}
}
.menu-cta{display:none}
@media(max-width:760px){
  .menu{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:8px 6vw 22px;border-bottom:1px solid var(--gris-clair);box-shadow:0 24px 40px rgba(14,14,16,.12);transform:translateY(-135%);transition:transform .32s cubic-bezier(.2,.8,.2,1);visibility:hidden}
  .menu.open{transform:none;visibility:visible}
  .menu a{padding:16px 2px;border-bottom:1px solid var(--gris-clair);width:100%}
  .menu a::after{display:none}
  .menu .menu-cta{display:block;width:100%;margin-top:16px;background:var(--rouge);color:#fff;text-align:center;padding:15px;border-radius:100px;font-weight:700;border-bottom:none}
  .menu .menu-cta:active{background:var(--rouge-fonce)}
  .burger{display:flex}
  .nav .head-cta{display:none}
}
@media(max-width:640px){
  .grid3,.panel.active,.serv-grid,.reason-grid,.value-grid,.stat-row,.two,.three,.options.cols-4,.options.cols-3,.foot-top{grid-template-columns:1fr}
  .hero .wrap{padding-top:48px}
  .hero h1{font-size:clamp(2.1rem,8.5vw,2.8rem)}
  .hero p.lead{max-width:none}
  .hero-actions .btn{flex:1;justify-content:center}
  .hero-stats{flex-wrap:wrap;gap:20px}
  .hero-stats>div{flex:1;min-width:42%}
  .hero-tag{left:0;bottom:12px;padding:11px 14px;font-size:.95rem}
  .marquee-track{font-size:.85rem;gap:40px}
  .page-hero .wrap{padding:54px 0 52px}
  section{padding:60px 0}
  .section-head{margin-bottom:40px}
  .formcard{padding:24px 20px}
  .cta-band{padding:30px 24px;text-align:center;justify-content:center}
  .cta-band .btn{width:100%;justify-content:center}
  .stepper{width:100%}.stepper input{flex:1;width:auto}
  .foot-bottom{flex-direction:column;text-align:center}
}
@media(max-width:380px){
  .brand .logo{height:28px}
  .brand .zone{padding-left:11px;letter-spacing:.18em}
  .nav{gap:12px}
}

/* ---------- SOCIALS ---------- */
.socials{display:flex;align-items:center;gap:10px;margin-top:20px}
.socials .lbl{font-size:.82rem;color:#8a8f97;font-weight:600;margin-right:2px}
.socials a{width:40px;height:40px;border-radius:11px;border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;transition:.2s}
.socials a:hover{background:var(--rouge);border-color:var(--rouge);transform:translateY(-2px)}
.socials svg{width:18px;height:18px;fill:#fff}

/* ---------- MODAL (mentions) ---------- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:22px}
.modal.open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(10,10,12,.62);backdrop-filter:blur(5px);animation:ovIn .25s ease}
.modal-card{position:relative;background:#fff;border-radius:22px;max-width:720px;width:100%;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 40px 90px rgba(0,0,0,.45);animation:modIn .34s cubic-bezier(.2,.85,.25,1);overflow:hidden}
.modal-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--rouge)}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:26px 30px 22px;border-bottom:1px solid var(--gris-clair)}
.modal-head .kicker{margin:0 0 6px}
.modal-head h2{font-size:1.45rem;line-height:1.1}
.modal-close{flex:none;width:42px;height:42px;border-radius:50%;border:1.5px solid var(--gris-clair);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.modal-close:hover{background:var(--noir);border-color:var(--noir);transform:rotate(90deg)}
.modal-close svg{width:18px;height:18px;stroke:var(--noir);stroke-width:2.2;fill:none}
.modal-close:hover svg{stroke:#fff}
.modal-body{padding:24px 30px 32px;overflow-y:auto}
.modal-body h3{font-size:1.04rem;margin:24px 0 8px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700}
.modal-body h3:first-child{margin-top:0}
.modal-body p{color:var(--gris);font-size:.96rem;margin-bottom:12px}
.modal-body ul{color:var(--gris);font-size:.96rem;margin:0 0 12px 20px}
.modal-body li{margin-bottom:6px}
.modal-foot{padding:18px 30px;border-top:1px solid var(--gris-clair);display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.modal-foot .link-out{align-self:center;font-size:.86rem;color:var(--gris);margin-right:auto}
.modal-foot .link-out a{color:var(--rouge);font-weight:700}
body.no-scroll{overflow:hidden}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
@keyframes modIn{from{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:none}}
@media(max-width:640px){
  .modal{padding:0;align-items:flex-end}
  .modal-card{max-height:94vh;border-radius:22px 22px 0 0;animation:sheetIn .34s cubic-bezier(.2,.85,.25,1)}
  .modal-head,.modal-body,.modal-foot{padding-left:20px;padding-right:20px}
  .modal-foot .btn{width:100%;justify-content:center}
  .modal-foot .link-out{margin:0 0 6px;width:100%;text-align:center}
}
@keyframes sheetIn{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){
  .modal-overlay,.modal-card{animation:none}
  .menu{transition:none}
}
