/* 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;min-height:380px;}
  .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;white-space:nowrap;animation:ticker-scroll 20s linear infinite;padding:12px 0;font-family:var(--f-disp);font-size:18px;text-transform:uppercase;}
  .marq__in span{display:inline-block;flex-shrink:0;}
  @keyframes ticker-scroll{from{transform:translateX(0);}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;}


/* ═══════════════════════════════════════════
     MOBILE NAV — Direction B : Pop Smash
     Tiroir latéral, liens-étiquettes, slide-in
     ═══════════════════════════════════════════ */

  /* Burger */
  .sr-menu-toggle{
    display:none;
    flex-direction:column;justify-content:center;align-items:center;gap:5px;
    width:46px;height:46px;
    cursor:pointer;
    background:var(--ink);
    border:3px solid var(--ink);
    border-radius:999px;
    box-shadow:3px 3px 0 var(--ink);
    transition:transform .15s ease, box-shadow .15s ease;
    flex-shrink:0;
  }
  .sr-menu-toggle:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
  .sr-menu-toggle.open{
    background:var(--ketchup);
    border-color:var(--ketchup);
    transform:translate(-2px,-2px);
    box-shadow:5px 5px 0 var(--ink);
  }
  /* Barres */
  .sr-menu-toggle span{
    display:block;width:20px;height:3px;
    background:var(--paper);border-radius:3px;
    transition:transform .25s cubic-bezier(.23,1,.32,1), opacity .15s ease, width .2s ease;
    transform-origin:center;
  }
  .sr-menu-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
  .sr-menu-toggle.open span:nth-child(2){opacity:0;width:0;}
  .sr-menu-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

  /* Scrim */
  .sr-nav-scrim{
    display:block;visibility:hidden;
    position:fixed;inset:0;z-index:69;
    background:rgba(35,26,18,.5);
    opacity:0;
    transition:opacity .3s ease, visibility .3s ease;
  }
  .sr-nav-scrim.open{visibility:visible;opacity:1;}

  /* Tiroir */
  .sr-nav-drawer{
    position:fixed;top:0;right:0;
    width:min(340px,90vw);height:100%;z-index:70;
    background:var(--paper);
    border-left:3px solid var(--ink);
    box-shadow:-6px 0 0 var(--ink);
    display:flex;flex-direction:column;
    padding:80px 28px 40px;gap:6px;
    overflow-y:auto;
    transform:translateX(110%);
    transition:transform .35s cubic-bezier(.32,0,.07,1);
    visibility:hidden;
  }
  .sr-nav-drawer.open{transform:translateX(0);visibility:visible;}

  /* Bouton fermeture */
  .sr-nav-drawer .sr-nav-close{
    position:absolute;top:18px;right:20px;
    font-size:32px;cursor:pointer;line-height:1;
    background:none;border:none;
    font-family:var(--f-disp);
    transition:transform .2s, color .2s;
  }
  .sr-nav-drawer .sr-nav-close:hover{transform:rotate(15deg);color:var(--ketchup);}

  /* Liens — stagger slide depuis la droite */
  .sr-nav-drawer > a{
    font-family:var(--f-disp);font-size:28px;text-transform:uppercase;
    color:var(--ink);
    padding:12px 16px;
    border:3px solid var(--ink);border-radius:999px;
    box-shadow:4px 4px 0 var(--ink);
    transition:transform .14s ease, box-shadow .14s ease,
               background .15s, color .15s, border-color .15s,
               opacity .35s ease, translate .35s cubic-bezier(.23,1,.32,1);
    display:block;
    opacity:0;translate:30px 0;
  }
  .sr-nav-drawer.open > a{opacity:1;translate:0 0;}
  .sr-nav-drawer.open > a:nth-child(2){transition-delay:.05s;}
  .sr-nav-drawer.open > a:nth-child(3){transition-delay:.10s;}
  .sr-nav-drawer.open > a:nth-child(4){transition-delay:.15s;}
  .sr-nav-drawer.open > a:nth-child(5){transition-delay:.20s;}
  .sr-nav-drawer.open > a:nth-child(6){transition-delay:.25s;}
  .sr-nav-drawer > a:hover,
  .sr-nav-drawer > a[aria-current]{
    background:var(--ketchup);color:#fff;border-color:var(--ketchup);
    transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);
  }

  /* CTA */
  .sr-nav-drawer .sr-nav-cta{
    margin-top:24px;display:flex;flex-direction:column;gap:12px;
    opacity:0;translate:0 16px;
    transition:opacity .35s ease .3s, translate .35s ease .3s;
  }
  .sr-nav-drawer.open .sr-nav-cta{opacity:1;translate:0 0;}

  @media(max-width:900px){
    .sr-menu-toggle{display:flex;}
    .nav{display:none;}
    .barcta .cartpill,.barcta .btn:not(.sr-menu-toggle){display:none;}
    .barcta{gap:10px;}
  }


/* Lien Mon compte dans le header */
.sr-account-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--sr-bar-text, var(--ink, #F5F3EC));
  text-decoration: none;
  opacity: .75;
  transition: opacity .15s;
  padding: 4px;
  border-radius: 50%;
}
.sr-account-link:hover { opacity: 1; }
.sr-account-link svg { display: block; }
