/* Alias tokens --sr-* pour les composants partagés (direction B) */
:root{
  --sr-bg:#FCEFD6; --sr-surface:#FFFFFF; --sr-surface2:#F7E2BC;
  --sr-ink:#231A12; --sr-muted:#6A5C4C; --sr-line:#231A12;
  --sr-accent:#E23528; --sr-accent2:#F3B81F; --sr-on-accent:#FFFFFF;
  --sr-radius:18px; --sr-bw:3px; --sr-shadow:5px 5px 0 #231A12;
  --sr-fdisp:"Archivo Black",sans-serif;
}

:root{
    --paper:#FCEFD6; --paper2:#F7E2BC; --card:#FFFFFF; --ink:#231A12;
    --ketchup:#E23528; --ketchup-dk:#B5261B;
    --mustard:#F3B81F; --pickle:#3F7D34; --ink-soft:#6A5C4C;
    --line:#E7D2A9;
    --f-disp:"Archivo Black", system-ui, sans-serif;
    --f-body:"Archivo", system-ui, sans-serif;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--f-body);font-size:16px;line-height:1.55;font-weight:500;-webkit-font-smoothing:antialiased;}
  h1,h2,h3{font-family:var(--f-disp);margin:0;line-height:.95;text-transform:uppercase;letter-spacing:-0.01em;}
  p{margin:0;} a{color:inherit;text-decoration:none;} img{display:block;max-width:100%;}
  .wrap{max-width:1240px;margin:0 auto;padding:0 28px;}

  .btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-body);font-weight:800;font-size:15px;border:3px solid var(--ink);cursor:pointer;padding:14px 24px;border-radius:999px;transition:transform .14s ease, box-shadow .14s ease;box-shadow:4px 4px 0 var(--ink);}
  .btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);}
  .btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
  .btn--ketchup{background:var(--ketchup);color:#fff;}
  .btn--mustard{background:var(--mustard);color:var(--ink);}
  .btn--white{background:#fff;color:var(--ink);}
  .btn--sm{padding:10px 16px;font-size:13px;box-shadow:3px 3px 0 var(--ink);}
  .btn--sm:hover{box-shadow:5px 5px 0 var(--ink);}

  .sticker{display:inline-flex;align-items:center;gap:7px;font-family:var(--f-disp);font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:7px 13px;border-radius:999px;border:2.5px solid var(--ink);background:var(--mustard);}
  .sticker--ketchup{background:var(--ketchup);color:#fff;}
  .sticker--pickle{background:var(--pickle);color:#fff;}

  /* bar */
  .bar{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:3px solid var(--ink);}
  .bar__in{display:flex;align-items:center;justify-content:space-between;height:72px;}
  .logo{font-family:var(--f-disp);font-size:27px;display:flex;align-items:center;gap:8px;}
  .logo .b{background:var(--ketchup);color:#fff;padding:2px 10px;border-radius:8px;transform:rotate(-3deg);display:inline-block;}
  .nav{display:flex;gap:24px;}
  .nav a{font-weight:700;font-size:14px;}
  .nav a:hover{color:var(--ketchup);}
  .barcta{display:flex;align-items:center;gap:14px;}
  .cartpill{font-family:var(--f-disp);font-size:14px;background:var(--ink);color:var(--mustard);padding:9px 14px;border-radius:999px;}

  /* hero */
  .hero{position:relative;overflow:hidden;border-bottom:3px solid var(--ink);}
  .hero__in{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;padding:64px 0 70px;position:relative;}
  .dots{position:absolute;inset:0;background-image:radial-gradient(var(--paper2) 2px, transparent 2px);background-size:22px 22px;opacity:.7;z-index:0;}
  .hero__txt{position:relative;z-index:2;}
  .kick{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-disp);font-size:13px;letter-spacing:.04em;text-transform:uppercase;background:var(--ink);color:var(--mustard);padding:8px 14px;border-radius:999px;margin-bottom:20px;}
  .hero h1{font-size:clamp(54px,8vw,118px);}
  .hero h1 .k{color:var(--ketchup);-webkit-text-stroke:2px var(--ink);}
  .hero h1 .m{color:var(--mustard);-webkit-text-stroke:2px var(--ink);}
  .hero p.lead{font-size:19px;color:var(--ink-soft);font-weight:600;max-width:470px;margin:22px 0 30px;}
  .hero__cta{display:flex;gap:14px;flex-wrap:wrap;}
  .hero__art{position:relative;z-index:2;}
  .hero__disc{aspect-ratio:1/1;border-radius:50%;border:5px solid var(--ink);overflow:hidden;background:var(--card);box-shadow:10px 10px 0 var(--ink);}
  .hero__disc img{width:100%;height:100%;object-fit:cover;}
  .spin{position:absolute;top:-26px;right:-18px;width:120px;height:120px;background:var(--mustard);border:3px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--f-disp);font-size:15px;line-height:.9;text-transform:uppercase;transform:rotate(-12deg);}
  .ribbon{position:absolute;bottom:24px;left:-14px;background:var(--ketchup);color:#fff;border:3px solid var(--ink);border-radius:12px;padding:10px 16px;font-family:var(--f-disp);font-size:18px;transform:rotate(-5deg);}

  .marq{background:var(--ketchup);color:#fff;border-bottom:3px solid var(--ink);overflow:hidden;}
  .marq__in{display:flex;gap:36px;white-space:nowrap;animation:scroll 20s linear infinite;padding:12px 0;font-family:var(--f-disp);font-size:18px;text-transform:uppercase;}
  .marq__in span{display:inline-flex;gap:36px;}
  @keyframes scroll{to{transform:translateX(-50%);}}

  .section{padding:80px 0;}
  .shead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px;flex-wrap:wrap;}
  .shead h2{font-size:clamp(34px,4.4vw,60px);}
  .shead h2 em{font-style:normal;color:var(--ketchup);}

  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  .card{background:var(--card);border:3px solid var(--ink);border-radius:22px;overflow:hidden;display:flex;flex-direction:column;box-shadow:6px 6px 0 var(--ink);transition:transform .16s ease, box-shadow .16s ease;}
  .card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink);}
  .card__img{position:relative;aspect-ratio:4/3;overflow:hidden;border-bottom:3px solid var(--ink);}
  .card__img img{width:100%;height:100%;object-fit:cover;}
  .card__img .flag{position:absolute;top:12px;left:12px;}
  .card__b{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1;}
  .card__b h3{font-size:24px;}
  .card__b p{color:var(--ink-soft);font-size:13.5px;font-weight:600;flex:1;}
  .card__row{display:flex;align-items:center;justify-content:space-between;margin-top:6px;}
  .price{font-family:var(--f-disp);font-size:26px;color:var(--ketchup);}

  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  .step{background:var(--card);border:3px solid var(--ink);border-radius:22px;padding:28px 24px;box-shadow:6px 6px 0 var(--ink);}
  .step .n{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border-radius:50%;background:var(--mustard);border:3px solid var(--ink);font-family:var(--f-disp);font-size:24px;}
  .step h3{font-size:22px;margin:16px 0 8px;}
  .step p{color:var(--ink-soft);font-size:14px;font-weight:600;}

  .locs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
  .loc{background:var(--card);border:3px solid var(--ink);border-radius:20px;padding:24px;box-shadow:6px 6px 0 var(--ink);}
  .loc h3{font-size:21px;}
  .loc .open{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:12px;color:var(--pickle);margin-top:10px;text-transform:uppercase;letter-spacing:.06em;}
  .loc p{color:var(--ink-soft);font-size:14px;font-weight:600;margin-top:12px;}

  .cta-strip{background:var(--mustard);border:3px solid var(--ink);border-radius:26px;padding:50px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;box-shadow:8px 8px 0 var(--ink);}
  .cta-strip h2{font-size:clamp(32px,4.2vw,56px);}

  footer{background:var(--ink);color:var(--paper);padding:56px 0 32px;margin-top:18px;}
  .foot{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;}
  footer h4{font-family:var(--f-disp);font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--mustard);margin:0 0 16px;}
  footer ul{list-style:none;padding:0;margin:0;display:grid;gap:9px;}
  footer li a{color:rgba(252,239,214,.72);font-size:14px;font-weight:600;}
  footer li a:hover{color:#fff;}
  .foot__bottom{display:flex;justify-content:space-between;margin-top:42px;padding-top:22px;border-top:2px solid rgba(252,239,214,.18);color:rgba(252,239,214,.55);font-size:12px;font-weight:600;flex-wrap:wrap;gap:10px;}

  @media(max-width:900px){.hero__in{grid-template-columns:1fr;}.grid,.steps,.locs{grid-template-columns:1fr;}.foot{grid-template-columns:1fr 1fr;}.nav{display:none;}}

/* footer logo */
.foot .logo{color:#FCEFD6;font-size:30px;}
