/* =================================================================
   C.A.P AUTO MONTLOUIS — Point S
   Design : atelier / automobile · graphite + rouge racing
   Typo   : Saira Condensed (display) + Manrope (texte)
   ================================================================= */

:root{
  --ink:#15181D;          /* graphite presque noir */
  --ink-2:#1D2127;
  --ink-3:#5A626E;        /* gris texte secondaire */
  --steel:#2A2F38;
  --line:#E2E5EA;
  --line-2:#D2D7DE;
  --paper:#FFFFFF;
  --paper-2:#F4F6F8;      /* béton clair */
  --paper-3:#ECEFF3;
  --red:#E11324;          /* rouge racing / Point S */
  --red-2:#B70D1C;
  --red-soft:#FCE7E9;
  --amber:#F5B301;        /* jaune sécurité, accent ponctuel */
  --white:#FFFFFF;
  --radius:4px;
  --radius-lg:8px;
  --shadow:0 10px 30px -12px rgba(21,24,29,.18);
  --shadow-lg:0 28px 60px -24px rgba(21,24,29,.34);
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4,.display{
  font-family:"Saira Condensed",Impact,sans-serif;
  font-weight:700;
  line-height:.98;
  letter-spacing:.005em;
  text-transform:uppercase;
}
h1{font-size:clamp(2.7rem,7vw,5.6rem)}
h2{font-size:clamp(2rem,4.6vw,3.6rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.9rem);line-height:1.04}
p{text-wrap:pretty}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.section{padding:clamp(64px,9vw,124px) 0}
.bg-paper{background:var(--paper)}
.bg-paper-2{background:var(--paper-2)}
.bg-ink{background:var(--ink);color:#E7E9ED}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}

/* ---------- Accessibilité ---------- */
.skip{position:absolute;left:-9999px;top:0;background:var(--red);color:#fff;padding:12px 18px;z-index:200;font-weight:700}
.skip:focus{left:8px;top:8px}
:focus-visible{outline:2.5px solid var(--red);outline-offset:2px}

/* ---------- Eyebrow / titres ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:"Saira Condensed",sans-serif;
  text-transform:uppercase;letter-spacing:.16em;font-weight:600;
  font-size:.92rem;color:var(--red);margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.bg-ink .eyebrow{color:var(--amber)}
.bg-ink .eyebrow::before{background:var(--amber)}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-3);max-width:60ch;line-height:1.6}
.bg-ink .lead{color:#AEB5C0}

/* ---------- Boutons ---------- */
.btn{
  --b:var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Saira Condensed",sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:1.02rem;line-height:1;
  padding:15px 26px;border:2px solid var(--b);border-radius:var(--radius);
  cursor:pointer;transition:.25s var(--ease);background:transparent;color:var(--ink);
  white-space:nowrap;
}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn--solid{background:var(--red);border-color:var(--red);color:#fff}
.btn--solid:hover{background:var(--red-2);border-color:var(--red-2);transform:translateY(-2px)}
.btn--dark{background:var(--ink);border-color:var(--ink);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--outline{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:#fff}
.btn--outline-light{border-color:rgba(255,255,255,.4);color:#fff}
.btn--outline-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--amber{background:var(--amber);border-color:var(--amber);color:var(--ink)}
.btn--amber:hover{filter:brightness(1.06);transform:translateY(-2px)}
.btn--sm{padding:11px 18px;font-size:.92rem}
.btn--lg{padding:18px 34px;font-size:1.12rem}

/* ---------- En-tête / navigation ---------- */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line);transition:.3s}
.nav.is-stuck{box-shadow:0 8px 24px -16px rgba(21,24,29,.4)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.nav__logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.nav__mark{
  display:grid;place-items:center;width:42px;height:42px;border-radius:var(--radius);
  background:var(--ink);color:#fff;font-family:"Saira Condensed",sans-serif;font-weight:700;
  font-size:1.2rem;letter-spacing:.02em;position:relative;overflow:hidden;
}
.nav__mark::after{content:"";position:absolute;inset:0;border-left:4px solid var(--red);}
.nav__word{font-family:"Saira Condensed",sans-serif;font-weight:700;text-transform:uppercase;font-size:1.32rem;letter-spacing:.01em;line-height:.95}
.nav__word small{display:block;font-size:.62rem;letter-spacing:.22em;color:var(--red);font-weight:600}
.nav__menu{display:flex;align-items:center;gap:7px;margin-left:auto}
.nav__menu a{
  font-family:"Saira Condensed",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;font-size:1.02rem;padding:9px 13px;border-radius:var(--radius);color:var(--ink-2);
  transition:.2s;position:relative;
}
.nav__menu a:hover{color:var(--red)}
.nav__menu a.is-current{color:var(--red)}
.nav__menu a.is-current::after{content:"";position:absolute;left:13px;right:13px;bottom:2px;height:2px;background:var(--red)}
.nav__cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav__cart{position:relative;display:grid;place-items:center;width:42px;height:42px;border:1.5px solid var(--line-2);border-radius:var(--radius);color:var(--ink);transition:.2s}
.nav__cart:hover{border-color:var(--ink);color:var(--red)}
.nav__badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:var(--red);color:#fff;font-size:11px;font-weight:700;font-style:normal;display:grid;place-items:center;font-family:"Manrope"}
.nav__burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1.5px solid var(--line-2);border-radius:var(--radius);background:none;cursor:pointer;align-items:center;justify-content:center}
.nav__burger span{width:21px;height:2px;background:var(--ink);transition:.25s}
.nav__burger.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.is-active span:nth-child(2){opacity:0}
.nav__burger.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:1000px){
  .nav__menu{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--ink);padding:14px 26px 28px;transform:translateY(-120%);transition:transform .35s var(--ease);
    border-bottom:3px solid var(--red);max-height:calc(100vh - 74px);overflow:auto;
  }
  .nav__menu.is-open{transform:translateY(0)}
  .nav__menu a{color:#E7E9ED;font-size:1.3rem;padding:15px 4px;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav__menu a.is-current::after{display:none}
  .nav__menu a.is-current{color:var(--amber)}
  .nav__burger{display:flex}
  .nav__cta .btn{display:none}
  body.nav-open{overflow:hidden}
}

/* ---------- HERO ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:clamp(70px,11vw,130px) 0 clamp(60px,8vw,100px)}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background:
    radial-gradient(900px 500px at 80% -10%,rgba(225,19,36,.34),transparent 60%),
    repeating-linear-gradient(115deg,rgba(255,255,255,.025) 0 2px,transparent 2px 26px);
}
.hero__inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero__tag{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:8px 16px;border-radius:40px;font-size:.86rem;font-weight:600;letter-spacing:.04em;margin-bottom:26px}
.hero__tag b{color:var(--amber)}
.hero h1{color:#fff;margin-bottom:24px}
.hero h1 em{font-style:normal;color:var(--red);position:relative}
.hero h1 .line{display:block}
.hero p{color:#B6BCC6;font-size:1.18rem;max-width:48ch;margin-bottom:34px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero__stats{display:flex;gap:34px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding-top:26px}
.hero__stat b{font-family:"Saira Condensed",sans-serif;font-size:2.4rem;color:#fff;line-height:1;display:block}
.hero__stat span{font-size:.84rem;color:#969DA9;text-transform:uppercase;letter-spacing:.08em}

/* Carte "rendez-vous express" dans le hero */
.hero__card{background:#fff;color:var(--ink);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-lg);position:relative;border-top:4px solid var(--red)}
.hero__card h3{font-size:1.4rem;margin-bottom:6px}
.hero__card .sub{color:var(--ink-3);font-size:.95rem;margin-bottom:20px}
.hero__card ul{display:grid;gap:13px;margin-bottom:24px}
.hero__card li{display:flex;align-items:flex-start;gap:11px;font-size:.97rem;font-weight:500}
.hero__card li svg{flex-shrink:0;color:var(--red);margin-top:2px}
.hero__card .btn{width:100%;justify-content:center}

@media(max-width:880px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__stats{gap:26px}
}

/* ---------- Bandeau réassurance ---------- */
.strip{background:var(--ink-2);color:#fff;padding:0}
.strip__row{display:grid;grid-template-columns:repeat(4,1fr)}
.strip__item{display:flex;align-items:center;gap:13px;padding:22px 24px;border-right:1px solid rgba(255,255,255,.08)}
.strip__item:last-child{border-right:none}
.strip__item svg{color:var(--amber);flex-shrink:0}
.strip__item b{display:block;font-family:"Saira Condensed",sans-serif;text-transform:uppercase;font-size:1.05rem;letter-spacing:.02em}
.strip__item span{font-size:.82rem;color:#9AA1AD}
@media(max-width:820px){.strip__row{grid-template-columns:1fr 1fr}.strip__item:nth-child(2){border-right:none}.strip__item:nth-child(1),.strip__item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.08)}}
@media(max-width:480px){.strip__row{grid-template-columns:1fr}.strip__item{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}}

/* ---------- Section heading ---------- */
.sec-head{max-width:62ch;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head p{margin-top:18px;color:var(--ink-3);font-size:1.08rem}

/* ---------- Services / grille de cartes ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc{background:var(--paper);padding:38px 32px;transition:.3s var(--ease);position:relative}
.svc:hover{background:var(--ink);color:#fff;transform:translateY(-3px);z-index:2;box-shadow:var(--shadow-lg)}
.svc__ico{width:54px;height:54px;border-radius:var(--radius);background:var(--red-soft);display:grid;place-items:center;color:var(--red);margin-bottom:22px;transition:.3s}
.svc:hover .svc__ico{background:var(--red);color:#fff}
.svc h3{margin-bottom:11px}
.svc p{color:var(--ink-3);font-size:.98rem;margin-bottom:18px}
.svc:hover p{color:#AEB5C0}
.svc__link{font-family:"Saira Condensed",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.95rem;color:var(--red);display:inline-flex;gap:7px;align-items:center}
.svc:hover .svc__link{color:var(--amber)}
@media(max-width:880px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

/* ---------- Split image / contenu ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:420px;background:var(--ink-2)}
.split__media .ph{position:absolute;inset:0;display:grid;place-items:center;color:rgba(255,255,255,.14)}
.split__badge{position:absolute;left:0;bottom:0;background:var(--red);color:#fff;padding:18px 24px;max-width:230px}
.split__badge b{font-family:"Saira Condensed",sans-serif;font-size:2.2rem;display:block;line-height:1}
.split__badge span{font-size:.84rem;text-transform:uppercase;letter-spacing:.08em}
.split__list{display:grid;gap:16px;margin-top:26px}
.split__list li{display:flex;gap:13px;align-items:flex-start;font-weight:500}
.split__list svg{flex-shrink:0;color:var(--red);margin-top:3px}
@media(max-width:820px){.split{grid-template-columns:1fr}.split--rev .split__media{order:0}.split__media{min-height:300px}}

/* ---------- Étapes / process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:s}
.step{position:relative;padding-top:14px;border-top:3px solid var(--ink)}
.step__n{font-family:"Saira Condensed",sans-serif;font-size:1rem;font-weight:700;color:var(--red);letter-spacing:.1em}
.step h3{font-size:1.3rem;margin:8px 0 10px}
.step p{color:var(--ink-3);font-size:.96rem}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr;gap:30px 26px}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}

/* ---------- Marques / logos pneus ---------- */
.brands{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center}
.brands span{
  font-family:"Saira Condensed",sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;font-size:1.25rem;color:var(--ink-3);padding:12px 22px;border:1.5px solid var(--line-2);
  border-radius:var(--radius);background:#fff;transition:.2s;
}
.brands span:hover{color:var(--ink);border-color:var(--ink)}

/* ---------- Avis clients ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;position:relative}
.review__stars{color:var(--amber);letter-spacing:3px;margin-bottom:14px;font-size:1.05rem}
.review p{font-size:1.02rem;line-height:1.6;margin-bottom:20px}
.review__by{display:flex;align-items:center;gap:12px}
.review__av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:"Saira Condensed",sans-serif;font-weight:700}
.review__by b{display:block;font-size:.96rem}
.review__by span{font-size:.82rem;color:var(--ink-3)}
@media(max-width:880px){.reviews{grid-template-columns:1fr}}

/* ---------- Bandeau CTA ---------- */
.cta-band{background:var(--red);color:#fff;border-radius:var(--radius-lg);padding:clamp(36px,5vw,60px);display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border:30px solid rgba(255,255,255,.1);border-radius:50%}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:rgba(255,255,255,.9);margin-top:8px;position:relative;max-width:48ch}
.cta-band .btn{position:relative}

/* ---------- Page-head générique ---------- */
.page-head{background:var(--ink);color:#fff;padding:clamp(56px,8vw,92px) 0 clamp(40px,5vw,56px);position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(700px 360px at 85% 0,rgba(225,19,36,.3),transparent 60%),repeating-linear-gradient(115deg,rgba(255,255,255,.025) 0 2px,transparent 2px 24px)}
.page-head .wrap{position:relative}
.page-head h1{color:#fff;margin-top:8px}
.page-head .lead{margin-top:18px}
.crumb{font-size:.86rem;color:#9AA1AD;margin-bottom:16px;letter-spacing:.03em}
.crumb a{color:#C9CED6}.crumb a:hover{color:var(--amber)}

/* ---------- Tableau valeurs / chiffres ---------- */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.fact{background:#fff;padding:30px 26px}
.fact b{font-family:"Saira Condensed",sans-serif;font-size:2.6rem;color:var(--red);display:block;line-height:1}
.fact span{font-size:.92rem;color:var(--ink-3)}
@media(max-width:820px){.facts{grid-template-columns:1fr 1fr}}

/* ---------- Prose (pages légales) ---------- */
.prose{max-width:78ch;margin:0 auto}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:46px 0 16px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.25rem;margin:28px 0 10px}
.prose p,.prose li{color:#3A4049;font-size:1.02rem;line-height:1.72}
.prose p{margin-bottom:15px}
.prose ul{margin:0 0 18px 0;display:grid;gap:9px}
.prose ul li{position:relative;padding-left:24px}
.prose ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--red);border-radius:1px}
.prose a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--ink)}
.prose .tbl{width:100%;border-collapse:collapse;margin:14px 0 24px;font-size:.96rem}
.prose .tbl td{border:1px solid var(--line-2);padding:11px 14px;vertical-align:top}
.prose .tbl td:first-child{font-weight:600;background:var(--paper-2);width:38%}
.legal-meta{background:var(--paper-2);border-left:3px solid var(--red);padding:20px 24px;margin-bottom:30px;font-size:.96rem}
.legal-meta b{font-family:"Saira Condensed",sans-serif;font-size:1.1rem;text-transform:uppercase}

/* ---------- Formulaires ---------- */
.form{display:grid;gap:18px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-weight:600;font-size:.92rem;letter-spacing:.01em}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;padding:13px 15px;border:1.5px solid var(--line-2);border-radius:var(--radius);
  background:#fff;color:var(--ink);transition:.2s;width:100%;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--red);outline:none;box-shadow:0 0 0 3px var(--red-soft)}
.field--check{flex-direction:row;align-items:flex-start;gap:11px}
.field--check input{width:19px;height:19px;margin-top:3px;flex-shrink:0;accent-color:var(--red)}
.field--check label{font-weight:500;font-size:.92rem;color:var(--ink-3)}
.field--check a{color:var(--red);text-decoration:underline}
.alert{padding:15px 18px;border-radius:var(--radius);background:#E7F6EC;border:1px solid #B6E0C2;color:#1C6B36;font-weight:500;font-size:.96rem}
.alert--ko{background:var(--red-soft);border-color:#F3B8BD;color:var(--red-2)}
.flex{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.mt-24{margin-top:24px}
@media(max-width:600px){.form__row{grid-template-columns:1fr}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px)}
.contact-info{display:grid;gap:22px;align-content:start}
.contact-info .ci{display:flex;gap:15px;align-items:flex-start}
.contact-info .ci svg{flex-shrink:0;color:var(--red);margin-top:3px}
.contact-info .ci b{font-family:"Saira Condensed",sans-serif;text-transform:uppercase;font-size:1.1rem;display:block;letter-spacing:.02em}
.contact-info .ci a{color:var(--ink-2)}.contact-info .ci a:hover{color:var(--red)}
.hours{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;margin-top:6px}
.hours div{display:flex;justify-content:space-between;gap:18px;padding:12px 18px;border-bottom:1px solid var(--line);font-size:.95rem}
.hours div:last-child{border-bottom:none}
.hours div b{font-family:"Manrope";font-weight:700}
.map{margin-top:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);min-height:260px;filter:grayscale(.25) contrast(1.05)}
.map iframe{width:100%;height:100%;min-height:260px;border:0;display:block}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.foot{background:var(--ink);color:#A9B0BC;padding:clamp(56px,7vw,88px) 0 30px}
.foot__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot__brand{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.foot__brand .nav__mark{background:#fff;color:var(--ink)}
.foot__brand .nav__word{color:#fff}
.foot__about{font-size:.95rem;line-height:1.65;max-width:34ch}
.foot__sign{margin-top:16px;font-size:.88rem;color:#7B828F}
.foot h5{font-family:"Saira Condensed",sans-serif;text-transform:uppercase;color:#fff;font-size:1.1rem;letter-spacing:.04em;margin-bottom:16px}
.foot ul{display:grid;gap:10px}
.foot ul a{font-size:.95rem;color:#A9B0BC;transition:.2s}
.foot ul a:hover{color:var(--amber)}
.foot__contact p{font-size:.95rem;line-height:1.7}
.foot__contact a{color:#C9CED6}.foot__contact a:hover{color:var(--amber)}
.foot__bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:.84rem;color:#7B828F}
.foot__bottom a{color:#9AA1AD;text-decoration:underline}
@media(max-width:820px){.foot__top{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:500px){.foot__top{grid-template-columns:1fr}}

/* ---------- Cookies ---------- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;max-width:520px;margin:0 auto;background:var(--ink);color:#E7E9ED;padding:20px 22px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:160;transform:translateY(160%);transition:transform .4s var(--ease);border-left:4px solid var(--red)}
.cookie.is-on{transform:translateY(0)}
.cookie p{font-size:.9rem;margin-bottom:14px;line-height:1.55}
.cookie strong{color:#fff}
.cookie__row{display:flex;gap:12px;align-items:center}
.cookie__link{font-size:.86rem;color:#9AA1AD;text-decoration:underline}

/* ---------- Reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}[data-reveal]{opacity:1;transform:none}}
