/* =====================================================================
   VAPONOT — Éditorial / poster (light, ink, vermillon)
   Redesign overhaul · CSS natif · aucune dépendance
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Instrument+Sans:wght@400;500;600&family=Space+Mono:wght@400;700&display=swap');

:root{
  --paper:#f3f1ea;        /* papier chaud clair */
  --paper-2:#e9e5da;      /* teinte de section */
  --ink:#17140f;          /* encre presque noire */
  --ink-2:#4b463d;        /* corps atténué */
  --ink-3:#8a8378;        /* légendes */
  --accent:#ff4a1c;       /* vermillon (pop unique) */
  --accent-2:#e63c11;     /* vermillon appuyé */
  --on-accent:#fff6f2;
  --dark:#151310;         /* bloc sombre délibéré */
  --dark-paper:#f0ece2;   /* texte sur sombre */
  --line:rgba(23,20,15,.16);
  --line-soft:rgba(23,20,15,.08);

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.19,1,.22,1);
  --r:14px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Instrument Sans',system-ui,sans-serif;
  background:var(--paper);color:var(--ink);
  line-height:1.6;overflow-x:clip;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:var(--on-accent)}

/* Paper grain (fixe, non interactif) */
body::after{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ---------- Typo ---------- */
h1,h2,h3,h4,.display{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;line-height:.98;letter-spacing:-.02em}
.display-xl{font-size:clamp(3rem,10vw,8.5rem)}
h1{font-size:clamp(2.7rem,7vw,6rem)}
h2{font-size:clamp(2.1rem,5vw,4rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.9rem)}
p{color:var(--ink-2)}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-2);max-width:54ch}
.mono{font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.acc{color:var(--accent)}
em,.ital{font-style:italic;line-height:1.1}

/* Underline-swipe link */
.ulink{position:relative;display:inline-block}
.ulink::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.ulink:hover::after{transform:scaleX(1);transform-origin:left}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);position:relative;z-index:2}
.section{position:relative;padding:clamp(72px,12vw,150px) 0}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* ---------- Buttons ---------- */
.btn{
  --py:15px;display:inline-flex;align-items:center;gap:12px;padding:var(--py) 26px;border-radius:999px;
  font-family:'Instrument Sans';font-weight:600;font-size:.98rem;line-height:1;white-space:nowrap;
  border:1.5px solid var(--ink);transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s;will-change:transform;
}
.btn svg{width:17px;height:17px}
.btn-fill{background:var(--ink);color:var(--paper)}
.btn-fill:hover{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.btn-accent:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn-line{background:transparent;color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--paper)}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
/* on dark */
.on-dark .btn{border-color:var(--dark-paper);color:var(--dark-paper)}
.on-dark .btn-fill{background:var(--dark-paper);color:var(--dark)}
.on-dark .btn-fill:hover{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.on-dark .btn-accent{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.on-dark .btn-accent:hover{background:var(--dark-paper);border-color:var(--dark-paper);color:var(--dark)}

/* ---------- Header ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .45s var(--ease)}
.header.hide{transform:translateY(-100%)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px;transition:background .4s,border-color .4s}
.nav-inner{position:fixed;top:0;left:0;right:0;padding-inline:var(--gutter)}
.header.scrolled .nav{background:color-mix(in srgb,var(--paper) 82%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.wordmark{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.4rem;letter-spacing:-.03em;display:flex;align-items:baseline;gap:1px}
.wordmark .sq{width:9px;height:9px;background:var(--accent);display:inline-block;margin-left:3px;border-radius:2px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:9px 15px;font-size:.94rem;font-weight:500;color:var(--ink-2);border-radius:999px;transition:color .25s,background .25s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink);background:color-mix(in srgb,var(--ink) 8%,transparent)}
.nav-right{display:flex;align-items:center;gap:14px}
.burger{display:none;width:44px;height:44px;border:1.5px solid var(--ink);border-radius:12px;position:relative}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:27px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ---------- Age strip ---------- */
.agebar{background:var(--ink);color:var(--paper);font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;text-align:center;padding:7px 16px;position:relative;z-index:3}
.agebar b{color:var(--accent)}

/* =====================================================================
   HERO — éditorial asymétrique, produit en diagonale qui déborde
   ===================================================================== */
.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:112px 0 40px;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero-copy{max-width:640px}
.hero h1{margin:0 0 26px}
.hero h1 .ital{color:var(--accent)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-strip{margin-top:auto;padding-top:34px;display:flex;flex-wrap:wrap;gap:34px;align-items:baseline;border-top:1px solid var(--line)}
.fact .n{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.9rem;line-height:1}
.fact .l{font-size:.82rem;color:var(--ink-2);margin-top:3px}

/* Produit héro : gros objet en diagonale, débordant */
.hero-art{position:relative;height:100%;min-height:420px}
.hero-art .blob{position:absolute;inset:8% -20% 6% 6%;background:var(--accent);border-radius:46% 54% 60% 40%/50% 44% 56% 50%;z-index:0;filter:saturate(1.05)}
.hero-art .prod{position:absolute;z-index:2;top:50%;left:50%;width:min(70%,340px);transform:translate(-46%,-50%) rotate(9deg);filter:drop-shadow(0 40px 40px rgba(0,0,0,.32));animation:heroFloat 11s ease-in-out infinite;will-change:transform}
@keyframes heroFloat{
  0%  {transform:translate(-46%,-50%) rotate(9deg)}
  25% {transform:translate(-41%,-55%) rotate(5deg)}
  50% {transform:translate(-46%,-59%) rotate(9deg)}
  75% {transform:translate(-51%,-55%) rotate(13deg)}
  100%{transform:translate(-46%,-50%) rotate(9deg)}
}
.hero-art .tag{position:absolute;z-index:3;background:var(--ink);color:var(--paper);font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:7px 12px;border-radius:999px}
.hero-art .tag.t1{top:14%;right:2%}
.hero-art .tag.t2{bottom:12%;left:-2%;background:var(--paper);color:var(--ink);border:1.5px solid var(--ink)}

/* ---------- Marquee (une seule sur le site) ---------- */
.marquee{border-block:1px solid var(--ink);background:var(--paper);overflow:hidden;padding:16px 0}
.marquee .track{display:flex;gap:0;width:max-content;animation:scrollx 34s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .item{font-family:'Bricolage Grotesque';font-weight:700;font-size:clamp(1.3rem,2.4vw,2rem);letter-spacing:-.01em;padding:0 30px;display:flex;align-items:center;gap:30px;white-space:nowrap}
.marquee .item::after{content:"";width:9px;height:9px;background:var(--accent);border-radius:2px;flex:none}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- Décorations produits sur les bords (au scroll) ---------- */
.deco{position:absolute;z-index:0;pointer-events:none;filter:drop-shadow(0 30px 34px rgba(0,0,0,.22))}
.deco.l{left:clamp(24px,5vw,110px)}
.deco.r{right:clamp(24px,5vw,110px)}
.deco img{width:100%;height:auto}
@media(max-width:1000px){.deco{display:none}}

/* =====================================================================
   SECTION HEAD (éditorial, pas d'eyebrow répété)
   ===================================================================== */
.head{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:end;margin-bottom:54px}
.head .idx{font-family:'Space Mono',monospace;font-size:.8rem;color:var(--accent);padding-bottom:8px}
.head h2{max-width:16ch}
.head.solo{display:block}

/* ---------- Services : liste éditoriale numérotée (pas de 3 cartes) ---------- */
.svc{border-top:1px solid var(--ink)}
.svc-row{display:grid;grid-template-columns:70px 1fr auto;gap:28px;align-items:center;padding:30px 6px;border-bottom:1px solid var(--line);position:relative;transition:padding .4s var(--ease),color .4s}
.svc-row .num{font-family:'Space Mono',monospace;font-size:.9rem;color:var(--ink-3)}
.svc-row h3{margin-bottom:6px;transition:transform .4s var(--ease)}
.svc-row p{max-width:52ch;font-size:1rem}
.svc-row .go{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:.4s var(--ease);flex:none}
.svc-row .go svg{width:20px;height:20px;transition:transform .4s var(--ease)}
.svc-row:hover{padding-left:22px}
.svc-row:hover .go{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.svc-row:hover .go svg{transform:translateX(3px)}

/* =====================================================================
   BOUTIQUE — galerie que l'on fait glisser (étagère)
   ===================================================================== */
.shelf-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:34px}
.shelf-head .hint{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--ink-3);display:flex;align-items:center;gap:8px}
.shelf{display:flex;gap:22px;overflow-x:auto;padding:6px 0 26px;scroll-snap-type:x mandatory;cursor:grab;scrollbar-width:none}
.shelf::-webkit-scrollbar{display:none}
.shelf.drag{cursor:grabbing;scroll-snap-type:none}
.card{flex:0 0 clamp(260px,30vw,340px);scroll-snap-align:start;border:1.5px solid var(--ink);border-radius:var(--r);background:var(--paper);overflow:hidden;transition:transform .5s var(--ease)}
.card .pic{aspect-ratio:4/5;background:var(--paper-2);display:grid;place-items:center;position:relative;overflow:hidden;border-bottom:1.5px solid var(--ink)}
.card .pic img{max-height:74%;width:auto;transition:transform .6s var(--ease);pointer-events:none}
.card:hover .pic img{transform:scale(1.06) rotate(-3deg)}
.card .pic .cat{position:absolute;top:12px;left:12px;font-family:'Space Mono',monospace;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;background:var(--ink);color:var(--paper);padding:4px 9px;border-radius:999px}
.card .meta{padding:18px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.card .meta h3{font-size:1.2rem}
.card .meta .brand{font-family:'Space Mono',monospace;font-size:.68rem;color:var(--ink-3);text-transform:uppercase}
.card .meta .dot{width:34px;height:34px;border-radius:50%;background:var(--accent);color:var(--on-accent);display:grid;place-items:center;flex:none}
.card .meta .dot svg{width:16px;height:16px}

/* =====================================================================
   BÉNÉFICES arrêt tabac — grille asymétrique tuiles
   ===================================================================== */
.tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.tile{border:1.5px solid var(--ink);border-radius:var(--r);padding:26px;display:flex;flex-direction:column;justify-content:space-between;min-height:190px;transition:background .4s,color .4s,transform .4s var(--ease)}
.tile .k{font-family:'Space Mono',monospace;font-size:.72rem;color:var(--ink-3)}
.tile h3{font-size:1.35rem;margin-top:14px}
.tile p{font-size:.94rem;margin-top:8px}
.tile:hover{transform:translateY(-4px)}
.tile.fill{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.tile.fill .k,.tile.fill p{color:var(--on-accent);opacity:.9}
.tile.ink{background:var(--ink);color:var(--dark-paper);border-color:var(--ink)}
.tile.ink .k,.tile.ink p{color:var(--dark-paper);opacity:.82}
.c2{grid-column:span 2}.c3{grid-column:span 3}.c4{grid-column:span 4}.c6{grid-column:span 6}

/* =====================================================================
   FIDÉLITÉ — LE bloc sombre délibéré (color-block story, 1x)
   ===================================================================== */
.dark{background:var(--dark);color:var(--dark-paper);position:relative;overflow:hidden}
.dark::after{content:"";position:fixed} /* no-op keep grain */
.dark h1,.dark h2,.dark h3{color:var(--dark-paper)}
.dark p{color:color-mix(in srgb,var(--dark-paper) 78%,transparent)}
.dark .head .idx{color:var(--accent)}
.loyalty-grid{display:grid;grid-template-columns:1fr .9fr;gap:56px;align-items:center}
.loyalty-copy .lead{color:color-mix(in srgb,var(--dark-paper) 86%,transparent)}
.checks{margin-top:28px;display:grid;gap:14px}
.checks li{display:flex;gap:13px;align-items:flex-start;color:color-mix(in srgb,var(--dark-paper) 88%,transparent)}
.checks li svg{width:22px;height:22px;color:var(--accent);flex:none;margin-top:1px}

/* Carte à tampons façon ticket */
.punch{background:var(--dark-paper);color:var(--ink);border-radius:16px;padding:26px;position:relative;box-shadow:0 40px 80px -30px rgba(0,0,0,.6);transform:rotate(-3deg);transition:transform .5s var(--ease)}
.punch:hover{transform:rotate(0) translateY(-4px)}
.punch::before,.punch::after{content:"";position:absolute;width:26px;height:26px;background:var(--dark);border-radius:50%;top:50%;transform:translateY(-50%)}
.punch::before{left:-13px}.punch::after{right:-13px}
.punch .pt{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}
.punch .pt .w{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.15rem}
.punch .pt .w small{display:block;font-family:'Space Mono',monospace;font-weight:400;font-size:.64rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.punch .chip{font-family:'Space Mono',monospace;font-size:.72rem;background:var(--accent);color:var(--on-accent);padding:5px 11px;border-radius:999px}
.dots{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:6px 0}
.dots .d{aspect-ratio:1;border-radius:50%;border:1.6px dashed var(--line);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:700;color:var(--ink-3)}
.dots .d.on{border-style:solid;border-color:var(--ink);background:var(--ink);color:var(--dark-paper)}
.dots .d.win{border-color:var(--accent);background:var(--accent);color:var(--on-accent)}
.punch .pf{margin-top:20px;padding-top:16px;border-top:1.6px dashed var(--line);display:flex;justify-content:space-between;font-family:'Space Mono',monospace;font-size:.72rem;color:var(--ink-2)}
.punch .pf b{color:var(--ink)}

/* =====================================================================
   PRODUIT VEDETTE / STORY — split éditorial avec produit diagonale
   ===================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,80px);align-items:center}
.split.rev .media{order:2}
.media{position:relative;aspect-ratio:1;border:1.5px solid var(--ink);border-radius:var(--r);background:var(--paper-2);display:grid;place-items:center;overflow:hidden}
.media .slab{position:absolute;inset:auto -12% -14% -12%;height:60%;background:var(--accent);z-index:0;transform:rotate(-6deg)}
.media img{position:relative;z-index:1;max-height:78%;width:auto;transform:rotate(6deg);filter:drop-shadow(0 34px 36px rgba(0,0,0,.3))}
.media .stamp{position:absolute;z-index:2;top:16px;right:16px;font-family:'Space Mono',monospace;font-size:.7rem;text-transform:uppercase;background:var(--paper);border:1.5px solid var(--ink);padding:8px 12px;border-radius:999px}
.split-body h2{margin-bottom:18px}
.spec{margin-top:26px;border-top:1px solid var(--line)}
.spec div{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.spec div span:first-child{color:var(--ink-2)}
.spec div span:last-child{font-family:'Space Mono',monospace;font-size:.82rem}

/* ---------- CTA band ---------- */
.cta{border:1.5px solid var(--ink);border-radius:20px;padding:clamp(34px,5vw,64px);text-align:center;position:relative;overflow:hidden;background:var(--paper)}
.cta h2{max-width:16ch;margin:0 auto 18px}
.cta .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.info{display:grid;gap:2px;border-top:1px solid var(--ink)}
.info .it{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:20px 4px;border-bottom:1px solid var(--line);align-items:baseline}
.info .it .k{font-family:'Space Mono',monospace;font-size:.72rem;text-transform:uppercase;color:var(--ink-3)}
.info .it .v{font-size:1.02rem}
.info .it .v a:hover{color:var(--accent)}
.hours{display:grid;gap:0}
.hours .r{display:flex;justify-content:space-between;padding:7px 0;font-size:.96rem;border-bottom:1px dashed var(--line)}
.hours .r span:first-child{color:var(--ink-2)}
.hours .r.off span:last-child{color:var(--ink-3)}
form.form{display:grid;gap:16px}
.field{display:grid;gap:7px}
.field label{font-family:'Space Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}
.field input,.field textarea,.field select{width:100%;padding:14px 16px;border:1.5px solid var(--ink);border-radius:11px;background:var(--paper);color:var(--ink);font:inherit;font-size:.98rem;transition:box-shadow .2s,border-color .2s}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.field textarea{resize:vertical;min-height:130px}
.map{border:1.5px solid var(--ink);border-radius:var(--r);overflow:hidden;margin-top:40px}
.map iframe{width:100%;height:340px;border:0;display:block;filter:grayscale(.4) contrast(1.05)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:var(--dark-paper);padding:72px 0 32px;position:relative;z-index:2}
.footer a{color:color-mix(in srgb,var(--dark-paper) 74%,transparent)}
.footer a:hover{color:var(--accent)}
.foot-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand .wordmark{color:var(--dark-paper);font-size:2rem}
.foot-brand p{color:color-mix(in srgb,var(--dark-paper) 66%,transparent);margin-top:14px;max-width:34ch}
.foot-col h5{font-family:'Space Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:color-mix(in srgb,var(--dark-paper) 60%,transparent);margin-bottom:16px}
.foot-col a{display:block;padding:6px 0;font-size:.96rem}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:42px;height:42px;border:1px solid rgba(255,255,255,.16);border-radius:12px;display:grid;place-items:center;transition:.3s var(--ease)}
.socials a:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);transform:translateY(-3px)}
.socials svg{width:19px;height:19px}
.foot-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:26px;font-family:'Space Mono',monospace;font-size:.72rem;color:color-mix(in srgb,var(--dark-paper) 56%,transparent)}

/* =====================================================================
   PAGE HERO (pages internes)
   ===================================================================== */
.phead{padding:130px 0 46px;position:relative;overflow:hidden}
.crumb{font-family:'Space Mono',monospace;font-size:.72rem;text-transform:uppercase;color:var(--ink-3);margin-bottom:20px}
.crumb a:hover{color:var(--accent)}
.phead h1{max-width:16ch}
.phead p{margin-top:20px;max-width:56ch;font-size:1.08rem}
.phead .bleed{position:absolute;z-index:0;pointer-events:none;filter:drop-shadow(0 30px 34px rgba(0,0,0,.28))}
.phead .bleed.r{right:-40px;top:30%;width:clamp(150px,18vw,280px);transform:rotate(14deg)}

/* ---------- Reveal ---------- */
[data-r]{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-r].in{opacity:1;transform:none}
[data-r="l"]{transform:translateX(-36px)}[data-r="r"]{transform:translateX(36px)}
[data-r="l"].in,[data-r="r"].in{transform:none}
[data-r="clip"]{opacity:1;clip-path:inset(0 100% 0 0);transform:none;transition:clip-path 1s var(--ease)}
[data-r="clip"].in{clip-path:inset(0 0 0 0)}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}[data-d="4"]{transition-delay:.32s}[data-d="5"]{transition-delay:.4s}

/* ---------- Legal ---------- */
.legal{max-width:74ch}
.legal h2{margin:44px 0 14px;font-size:clamp(1.5rem,3vw,2.1rem)}
.legal h3{margin:26px 0 8px;font-size:1.15rem}
.legal p,.legal li{color:var(--ink-2);font-size:1rem}
.legal ul{margin:10px 0 0 20px;list-style:disc;display:grid;gap:6px}
.legal a{color:var(--accent)}
.legal .box{border:1.5px solid var(--ink);border-radius:var(--r);padding:22px 24px;margin-top:16px}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:1000px){
  .hero .wrap{grid-template-columns:1fr}
  .hero-art{min-height:340px;margin-top:10px}
  .loyalty-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .tiles{grid-template-columns:repeat(4,1fr)}
  .c4{grid-column:span 4}.c3{grid-column:span 2}.c2{grid-column:span 2}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:860px){
  .nav-links{position:fixed;inset:70px 0 auto 0;flex-direction:column;align-items:stretch;gap:2px;background:var(--paper);border-bottom:1px solid var(--line);padding:14px var(--gutter) 24px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.35s var(--ease)}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:14px 8px;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .nav-links a.active{background:none;color:var(--accent)}
  .burger{display:block}
  .nav-right .btn{display:none}
  .split,.split.rev .media{grid-template-columns:1fr}
  .split.rev .media{order:0}
  .head{grid-template-columns:1fr;gap:10px}
  .tiles{grid-template-columns:1fr 1fr}
  .c4,.c3,.c2,.c6{grid-column:span 2}
}
@media(max-width:560px){
  .svc-row{grid-template-columns:1fr auto;gap:14px}
  .svc-row .num{display:none}
  .tiles{grid-template-columns:1fr}
  .c4,.c3,.c2,.c6{grid-column:span 1}
  .foot-top{grid-template-columns:1fr}
  .info .it{grid-template-columns:1fr;gap:4px}
  .punch{transform:none}
  .dots{grid-template-columns:repeat(5,1fr)}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto}
  [data-r]{opacity:1;transform:none;clip-path:none}
  .marquee .track{animation:none}
}
