/* =========================================================
   PIKA WONKA · feuille de style
   DA : billet d'admission / ticket d'or imprimé × pop japonaise
   papier crème · encre chocolat · vrai foil doré · rouge vermillon
   ========================================================= */

:root{
  /* PAPIER / FONDS */
  --paper:#f4e8cf; --paper-2:#efe0c2; --paper-3:#e8d6b2; --card:#fbf3e2;
  /* ENCRE */
  --ink:#2a1c12; --ink-2:#4a3825; --ink-soft:#705537; --ink-faint:#9a8160;
  /* OR / FOIL */
  --gold:#e5a82b; --gold-d:#b9821a; --gold-dd:#8a5e0e; --gold-h:#ffe7a0; --gold-deep:#5e3f0a;
  /* ROUGE / MACHINE */
  --rouge:#d8361f; --rouge-d:#a8230f; --rouge-dd:#7a1607; --machine:#cf2f1d; --machine-d:#9c211c;
  /* BLEU + AUBERGINE accents */
  --bleu:#2a4b8d; --prune:#3a2150;
  /* LIGNES */
  --line:rgba(42,28,18,.22); --line-2:rgba(42,28,18,.4);

  --foil:linear-gradient(100deg,#6e4a0c 0%,#a9781a 20%,#dcad34 40%,#f3cb5e 50%,#cf991f 62%,#9a6b12 82%,#6e4a0c 100%);
  --foil-solid:linear-gradient(160deg,#f7e08f,#e5a82b 50%,#b9821a);
  --shadow-card:6px 8px 0 rgba(42,28,18,.9);
  --shadow-soft:0 18px 40px rgba(42,28,18,.22);
  --radius:6px;

  --maxw:1180px;
  --font-display:'Fraunces',Georgia,serif;
  --font-mono:'Space Mono',ui-monospace,monospace;
  --font-jp:'Noto Sans JP',sans-serif;
  --font-body:'Fraunces',Georgia,serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:28px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-optical-sizing:auto;
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  overflow-x:hidden;
  font-weight:400;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.jp{font-family:var(--font-jp)}
.nowrap{white-space:nowrap}
.container{width:min(100% - 40px,var(--maxw));margin-inline:auto}
::selection{background:var(--ink);color:var(--gold-h)}

/* foil text helper -------------------------------------- */
.foil{
  background:var(--foil);background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
  text-shadow:0 1px 0 rgba(42,28,18,.22);
  animation:foilShift 7s linear infinite;
}
@keyframes foilShift{to{background-position:220% 0}}

/* =========================================================
   AMBIANCE DE FOND : papier + trame Ben-Day + grain
   ========================================================= */
.bg-fx{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.bg-fx__halftone{position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(168,35,15,.10) 1.1px,transparent 1.3px);
  background-size:16px 16px;background-position:0 0}
.bg-fx__grain{position:absolute;inset:0;opacity:.045;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='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* =========================================================
   BRAND / WORDMARK
   ========================================================= */
.brand{display:inline-flex;align-items:center;gap:9px}
.brand__bolt{width:26px;height:26px;flex:0 0 auto;filter:drop-shadow(1px 1px 0 rgba(42,28,18,.25))}
.brand__type{display:flex;align-items:baseline;gap:6px;font-family:var(--font-display);
  font-weight:900;font-size:26px;line-height:1;letter-spacing:-.5px}
.brand__pika{color:var(--rouge)}
.brand__wonka{font-style:italic}
.brand--stack .brand__type--stack{flex-direction:column;gap:0;font-size:46px;line-height:.92}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{position:sticky;top:0;z-index:60;
  background:rgba(244,232,207,.86);backdrop-filter:blur(10px);
  border-bottom:2px solid var(--ink);
  transition:box-shadow .3s,background .3s}
.site-header.scrolled{background:rgba(244,232,207,.96);box-shadow:0 6px 0 rgba(42,28,18,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;height:70px}
.nav-links{display:flex;gap:28px}
.nav-links a{font-family:var(--font-mono);font-weight:400;font-size:12.5px;text-transform:uppercase;
  letter-spacing:1px;color:var(--ink-soft);position:relative;padding:6px 0;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--rouge);transition:right .25s ease}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}

.nav-actions{display:flex;align-items:center;gap:10px}
.ig-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-weight:700;
  font-size:12px;letter-spacing:.5px;color:var(--ink);border:2px solid var(--ink);background:var(--card);
  padding:8px 13px;border-radius:999px;transition:transform .15s,box-shadow .15s,background .2s;
  box-shadow:2px 2px 0 var(--ink)}
.ig-pill:hover{background:var(--gold-h);transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.ig-pill:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}

.cart-btn{position:relative;display:inline-grid;place-items:center;width:44px;height:44px;
  border-radius:11px;border:2px solid var(--ink);background:var(--card);color:var(--ink);
  cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .15s,box-shadow .15s,background .2s}
.cart-btn:hover{background:var(--gold-h);transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.cart-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}
.cart-btn__count{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;
  background:var(--rouge);color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:700;border-radius:999px;
  display:grid;place-items:center;border:2px solid var(--paper);
  transform:scale(1);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.cart-btn__count[data-empty="true"]{display:none}
.cart-btn__count.bump{transform:scale(1.4)}

/* bouton panier flottant ------------------------------- */
.cart-fab{position:fixed;top:20px;right:20px;z-index:70;display:inline-grid;place-items:center;
  width:52px;height:52px;border-radius:14px;border:2.5px solid var(--ink);background:var(--foil-solid);
  color:var(--ink);cursor:pointer;box-shadow:4px 4px 0 var(--ink);
  transition:transform .15s,box-shadow .15s}
.cart-fab:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.cart-fab:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.cart-fab .cart-btn__count{top:-8px;right:-8px}

.burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border-radius:11px;
  border:2px solid var(--ink);background:var(--card);cursor:pointer;align-items:center;justify-content:center;
  box-shadow:2px 2px 0 var(--ink)}
.burger span{width:18px;height:2.4px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .2s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

.mobile-menu{display:flex;flex-direction:column;padding:8px 20px 18px;gap:2px;
  border-bottom:2px solid var(--ink);background:var(--paper)}
.mobile-menu a{padding:14px 6px;font-family:var(--font-mono);font-size:13px;text-transform:uppercase;
  letter-spacing:.5px;color:var(--ink-soft);border-bottom:1px dashed var(--line)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu__ig{color:var(--rouge)!important;font-weight:700}

/* =========================================================
   BOUTONS — style « tampon » avec ombre dure
   ========================================================= */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-mono);font-weight:700;font-size:13px;letter-spacing:.6px;text-transform:uppercase;
  padding:14px 24px;border-radius:11px;border:2px solid var(--ink);cursor:pointer;
  transition:transform .14s,box-shadow .14s,filter .2s;overflow:hidden;white-space:nowrap;text-align:center}
.btn svg{transition:transform .25s}
.btn--sm{padding:10px 16px;font-size:11.5px;border-radius:9px}
.btn--lg{padding:18px 32px;font-size:15px;border-radius:13px}
.btn--block{width:100%}

.btn--gold{color:var(--ink);background:var(--foil-solid);box-shadow:4px 4px 0 var(--ink)}
.btn--gold::after{content:"";position:absolute;inset:0;transform:translateX(-130%) skewX(-20deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);width:55%}
.btn--gold:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn--gold:hover::after{transition:transform .7s ease;transform:translateX(280%) skewX(-20deg)}
.btn--gold:hover svg{transform:translateX(3px)}
.btn--gold:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}

.btn--ghost{color:var(--ink);background:var(--card);box-shadow:4px 4px 0 var(--ink)}
.btn--ghost:hover{background:var(--gold-h);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn--ghost:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}

.btn:focus-visible,a:focus-visible,button:focus-visible{outline:3px solid var(--rouge);outline-offset:3px}

/* =========================================================
   ÉLÉMENTS RÉUTILISABLES
   ========================================================= */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:700;
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);
  border:2px solid var(--ink);background:var(--card);
  padding:7px 14px;border-radius:999px;margin-bottom:22px;box-shadow:2px 2px 0 var(--ink)}
.eyebrow__star{font-style:normal;color:var(--rouge)}
.eyebrow__jp{color:var(--ink-faint);letter-spacing:2px;font-size:10.5px}

.section{padding:96px 0;position:relative}
.section-head{max-width:680px;margin:0 auto 56px;text-align:center;position:relative;z-index:2}
.section-title{font-family:var(--font-display);font-weight:900;font-size:clamp(32px,5.6vw,60px);line-height:1.0;
  letter-spacing:-1.2px;color:var(--ink)}
.section-title .foil{font-style:italic}
.section-sub{margin-top:18px;color:var(--ink-soft);font-size:clamp(16px,2vw,18.5px);font-weight:400;line-height:1.6}
.section-sub b{color:var(--ink);font-weight:600}

/* séparateur ticket perforé */
.ticket-divider{position:relative;height:1px;width:min(100% - 40px,var(--maxw));margin:8px auto;
  display:flex;align-items:center;justify-content:center}
.ticket-divider span{flex:1;height:0;border-top:2px dashed var(--line-2)}
.ticket-divider::before,.ticket-divider::after{content:"";width:20px;height:20px;border-radius:50%;
  background:var(--paper);border:2px solid var(--line-2);flex:0 0 auto}
.ticket-divider::before{margin-right:-2px}
.ticket-divider::after{margin-left:-2px}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;padding:70px 0 56px;overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:40px;min-height:min(80vh,650px)}
.hero__content{max-width:560px}
.hero__title{font-family:var(--font-display);font-weight:900;line-height:.86;letter-spacing:-3px;
  font-size:clamp(72px,13vw,168px)}
.hero__title-pika{display:block;color:var(--rouge);text-shadow:4px 4px 0 rgba(42,28,18,.18)}
.hero__title-wonka{display:block;font-style:italic;filter:drop-shadow(3px 3px 0 rgba(42,28,18,.22))}
.hero__jp{font-family:var(--font-jp);font-weight:700;font-size:clamp(15px,2.4vw,20px);color:var(--ink-soft);
  letter-spacing:4px;margin-top:14px}
.hero__lead{margin-top:24px;font-size:clamp(16px,2.1vw,19px);color:var(--ink-soft);line-height:1.62}
.hero__lead b{color:var(--ink);font-weight:600}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero__chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:28px}
.chip{font-family:var(--font-mono);font-size:11.5px;font-weight:400;text-transform:uppercase;letter-spacing:.5px;
  color:var(--ink-soft);background:var(--card);border:1.5px solid var(--line-2);padding:7px 13px;border-radius:999px}
.chip b{color:var(--rouge);font-weight:700}

.hero__visual{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:500px;padding-top:20px}

/* LE TICKET D'OR ---------------------------------------- */
.ticket{position:relative;z-index:1;width:min(100%,440px);display:grid;grid-template-columns:96px 1fr;
  background:var(--foil-solid);border:2.5px solid var(--ink);border-radius:14px;
  box-shadow:10px 12px 0 rgba(42,28,18,.85),inset 0 2px 0 rgba(255,255,255,.5);
  transform:rotate(-4deg);transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.hero__visual:hover .ticket{transform:rotate(-2deg) scale(1.015)}
.ticket::before{content:"";position:absolute;inset:6px;border:1.5px dashed rgba(42,28,18,.45);border-radius:9px;pointer-events:none}
/* trous de perforation entre la souche et le corps */
.ticket__stub{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;padding:22px 8px;border-right:2.5px dashed var(--ink)}
.ticket__stub::before,.ticket__stub::after{content:"";position:absolute;right:-9px;width:16px;height:16px;
  background:var(--paper);border:2.5px solid var(--ink);border-radius:50%}
.ticket__stub::before{top:-9px}
.ticket__stub::after{bottom:-9px}
.ticket__admit{font-family:var(--font-display);font-weight:900;font-style:italic;font-size:21px;line-height:.92;
  color:var(--ink);text-transform:uppercase;text-align:center;letter-spacing:-.5px}
.ticket__no{font-family:var(--font-mono);font-weight:700;font-size:10px;letter-spacing:1px;color:var(--gold-deep);
  writing-mode:vertical-rl;transform:rotate(180deg)}
.ticket__main{padding:26px 24px 22px;display:flex;flex-direction:column;gap:6px;text-align:center;justify-content:center}
.ticket__kicker{font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--gold-deep)}
.ticket__deal{font-family:var(--font-display);font-weight:900;font-style:italic;font-size:clamp(34px,7vw,48px);
  line-height:.95;letter-spacing:-1.5px;
  /* foil plus dramatique sur fond or : on remet une teinte sombre lisible */
  -webkit-text-fill-color:initial;background:none;color:var(--ink);animation:none}
.ticket__sub{font-family:var(--font-jp);font-weight:700;font-size:12px;letter-spacing:2px;color:var(--gold-deep)}
.ticket__barcode{height:34px;margin-top:10px;border-radius:2px;
  background:repeating-linear-gradient(90deg,var(--ink) 0 2px,transparent 2px 4px,var(--ink) 4px 5px,transparent 5px 9px,var(--ink) 9px 12px,transparent 12px 14px)}

.hero__mascot-halo{position:absolute;z-index:0;inset:0;margin:auto;
  width:clamp(260px,90%,460px);height:clamp(260px,90%,460px);border-radius:50%;
  background:repeating-conic-gradient(from 0deg,rgba(229,168,43,.16) 0deg 7deg,transparent 7deg 14deg);
  -webkit-mask:radial-gradient(circle,#000 26%,transparent 70%);mask:radial-gradient(circle,#000 26%,transparent 70%);
  animation:spin 70s linear infinite}
.hero__mascot{position:relative;z-index:3;width:min(84%,380px);height:auto;
  transform:rotate(2deg);
  filter:drop-shadow(8px 18px 16px rgba(42,28,18,.42));animation:floaty 6s ease-in-out infinite}
.coin{position:absolute;z-index:5;top:2%;right:4%;width:clamp(80px,11vw,112px);
  filter:drop-shadow(3px 6px 0 rgba(42,28,18,.55));animation:coinBob 4.5s ease-in-out infinite;transform:rotate(-10deg)}
.stamp{position:absolute;z-index:5;left:1%;bottom:4%;width:96px;height:96px;border-radius:50%;
  display:grid;place-items:center;color:var(--rouge);border:3px double var(--rouge);
  background:rgba(216,54,31,.06);transform:rotate(-14deg);opacity:.92;
  box-shadow:inset 0 0 0 1px rgba(216,54,31,.4)}
.stamp span{font-family:var(--font-mono);font-weight:700;font-size:11px;line-height:1.25;letter-spacing:.5px;
  text-align:center;text-transform:uppercase}
.stamp b{font-family:var(--font-jp);font-size:18px}
.hero__sparkles span{position:absolute;left:var(--x);top:var(--y);width:14px;height:14px;color:var(--gold-d);
  animation:twinkle 2.8s ease-in-out infinite var(--d)}
.hero__sparkles span::before{content:"✦";position:absolute;inset:0;font-size:14px;line-height:1}

/* =========================================================
   MARQUEE — bande de billetterie
   ========================================================= */
.marquee{background:var(--ink);border-block:2.5px solid var(--ink);overflow:hidden;
  padding:13px 0;transform:rotate(-1deg) scale(1.03);margin:18px 0}
.marquee__track{display:inline-flex;gap:30px;white-space:nowrap;will-change:transform;
  animation:marquee 30s linear infinite;align-items:center}
.marquee__track span{font-family:var(--font-display);font-weight:900;font-style:italic;font-size:19px;
  letter-spacing:0;color:var(--gold-h);display:inline-flex;align-items:center}
.marquee__track .jp{font-family:var(--font-jp);font-weight:900;font-style:normal}
.marquee__dot{color:var(--rouge)!important;font-style:normal!important}

/* =========================================================
   CONCEPT · feature grid (coupons)
   ========================================================= */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.feat{position:relative;background:var(--card);border:2.5px solid var(--ink);
  border-radius:var(--radius);padding:26px 22px 24px;box-shadow:var(--shadow-card);
  transition:transform .2s,box-shadow .2s}
.feat:hover{transform:translate(-3px,-3px);box-shadow:9px 11px 0 rgba(42,28,18,.9)}
.feat__num{position:absolute;top:14px;right:16px;font-family:var(--font-mono);font-weight:700;font-size:13px;
  color:var(--ink-faint);letter-spacing:1px}
.feat__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:12px;
  background:var(--paper-2);border:2px solid var(--ink);margin-bottom:16px}
.feat__icon svg{width:30px;height:30px}
.feat h3{font-family:var(--font-display);font-weight:900;font-size:20px;letter-spacing:-.3px;margin-bottom:6px;color:var(--ink)}
.feat p{font-size:14.5px;color:var(--ink-soft);line-height:1.5}

/* =========================================================
   MACHINES
   ========================================================= */
.machines__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.steps{list-style:none;display:flex;flex-direction:column;gap:12px;margin:30px 0 30px}
.step{display:flex;gap:15px;align-items:flex-start;background:var(--card);
  border:2.5px solid var(--ink);border-radius:12px;padding:15px 17px;box-shadow:3px 3px 0 var(--ink);
  transition:transform .2s,box-shadow .2s}
.step:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.step__num{flex:0 0 auto;width:36px;height:36px;border-radius:9px;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:900;font-size:19px;color:var(--ink);
  background:var(--foil-solid);border:2px solid var(--ink)}
.step b{display:block;font-family:var(--font-display);font-weight:600;font-size:16.5px;color:var(--ink)}
.step span{font-size:13.5px;color:var(--ink-soft)}

.partner-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:var(--ink);border:2.5px solid var(--ink);border-radius:12px;padding:17px 20px}
.partner-cta p{font-size:14.5px;color:var(--paper-2);margin:0}
.partner-cta b{color:var(--gold-h)}

/* gachapon / distributeur dessiné */
.machines__visual{display:grid;place-items:center}
.gacha{width:min(100%,330px);aspect-ratio:300/420;border-radius:26px;position:relative;overflow:hidden;
  background:linear-gradient(168deg,var(--machine),var(--machine-d) 72%,var(--rouge-dd));
  box-shadow:10px 12px 0 rgba(42,28,18,.85),inset 0 2px 0 rgba(255,255,255,.22);
  border:2.5px solid var(--ink);padding:16px;display:flex;flex-direction:column;gap:14px;
  transform:perspective(900px) rotateY(-9deg) rotateX(3deg);transition:transform .5s}
.gacha::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 36% at 50% 0%,rgba(255,255,255,.2),transparent 60%)}
.machines__visual:hover .gacha{transform:perspective(900px) rotateY(-3deg) rotateX(1deg)}
.gacha__ribbon{font-family:var(--font-display);font-weight:900;color:var(--ink);background:var(--card);text-align:center;
  border-radius:9px;padding:9px 6px;font-size:19px;letter-spacing:-.3px;position:relative;z-index:2;
  border:2px solid var(--ink);box-shadow:0 3px 0 rgba(42,28,18,.2)}
.gacha__ribbon small{display:block;font-family:var(--font-jp);font-weight:700;font-size:9.5px;color:var(--gold-dd);letter-spacing:2px;margin-top:1px}
.gacha__window{position:relative;flex:1;border-radius:16px;background:radial-gradient(120% 90% at 50% 0%,#fdf6e6,#e3d2af);
  border:3px solid rgba(42,28,18,.3);box-shadow:inset 0 6px 20px rgba(42,28,18,.28);z-index:2;
  display:grid;place-items:center;overflow:hidden}
.gacha__card{width:46%;aspect-ratio:63/88;border-radius:9px;background:var(--foil-solid);
  border:2px solid var(--ink);display:grid;place-items:center;position:relative;
  box-shadow:0 10px 22px rgba(42,28,18,.3);transform:rotate(-6deg);animation:floaty 5s ease-in-out infinite}
.gacha__card::before{content:"";position:absolute;inset:6px;border:1.5px dashed var(--gold-dd);border-radius:5px}
.gacha__bolt{width:34%;display:block;position:relative;z-index:2}
.gacha__card-label{position:absolute;bottom:9px;font-family:var(--font-mono);font-weight:700;font-size:11px;color:var(--ink);letter-spacing:2px}
.gacha__price{position:absolute;top:12px;right:12px;font-family:var(--font-display);font-weight:900;font-size:19px;
  color:var(--ink);background:var(--foil-solid);border:2px solid var(--ink);border-radius:999px;
  padding:5px 13px;box-shadow:0 4px 0 rgba(42,28,18,.3);transform:rotate(6deg)}
.gacha__knob{height:54px;border-radius:14px;background:linear-gradient(180deg,#fdf6e6,#d8c4a0);
  border:2px solid var(--ink);display:grid;place-items:center;position:relative;z-index:2}
.gacha__knob span{width:40px;height:40px;border-radius:50%;background:conic-gradient(#e3d2af,#bba374,#e3d2af);
  border:3px solid var(--ink);box-shadow:inset 0 0 0 5px rgba(255,255,255,.3)}
.gacha__chute{height:46px;border-radius:12px;background:rgba(42,28,18,.32);border:2px solid var(--ink);
  display:grid;place-items:center;position:relative;z-index:2}
.gacha__chute span{font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:3px;color:rgba(255,255,255,.8)}

/* =========================================================
   AR FAVORITES (rail horizontal)
   ========================================================= */
.section--ar{background:var(--paper-2);border-block:2.5px solid var(--ink)}
.ar-rail{display:flex;gap:20px;overflow-x:auto;padding:14px 4px 26px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--ink) transparent}
.ar-rail::-webkit-scrollbar{height:9px}
.ar-rail::-webkit-scrollbar-thumb{background:var(--ink);border-radius:999px}
.ar-rail::-webkit-scrollbar-track{background:rgba(42,28,18,.1);border-radius:999px}
.ar-card{flex:0 0 auto;width:204px;scroll-snap-align:center;border-radius:10px;overflow:hidden;
  position:relative;border:2.5px solid var(--ink);background:var(--card);
  box-shadow:var(--shadow-card);transition:transform .3s,box-shadow .3s}
.ar-card:nth-child(even){transform:rotate(1.4deg)}
.ar-card:nth-child(odd){transform:rotate(-1.4deg)}
.ar-card img{width:100%;aspect-ratio:148/210;object-fit:cover}
.ar-card::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;opacity:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.5) 47%,rgba(246,201,14,.45) 53%,transparent 70%);
  transform:translateX(-30%);transition:opacity .3s}
.ar-card:hover{transform:translateY(-8px) rotate(0deg);box-shadow:8px 12px 0 rgba(42,28,18,.9)}
.ar-card:hover::after{opacity:1;animation:holo 1.1s ease}
.ar-card__tag{position:absolute;left:0;right:0;bottom:0;text-align:center;
  font-family:var(--font-display);font-weight:900;font-size:14px;letter-spacing:-.2px;color:var(--gold-h);
  background:linear-gradient(transparent,rgba(42,28,18,.92));padding:22px 6px 9px;z-index:2}
.ar-card__ar{position:absolute;top:9px;right:9px;z-index:2;font-family:var(--font-mono);font-weight:700;font-size:10px;
  letter-spacing:.5px;color:var(--ink);background:var(--foil-solid);border:2px solid var(--ink);
  padding:3px 8px;border-radius:6px}
.ar-foot{text-align:center;margin-top:22px;color:var(--ink-soft);font-size:16px}
.ar-foot a{color:var(--rouge);font-weight:600;font-style:italic;border-bottom:2px solid var(--rouge)}
.ar-foot a:hover{color:var(--rouge-d)}

/* =========================================================
   BOUTIQUE / SHOP
   ========================================================= */
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.product{background:var(--card);border:2.5px solid var(--ink);
  border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow-card);transition:transform .2s,box-shadow .2s}
.product:hover{transform:translate(-3px,-3px);box-shadow:9px 11px 0 rgba(42,28,18,.9)}
.product__media{position:relative;overflow:hidden;background:var(--paper-3);aspect-ratio:148/200;
  border-bottom:2.5px solid var(--ink)}
.product__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product:hover .product__media img{transform:scale(1.06)}
.product__ar{position:absolute;top:10px;left:10px;z-index:2;font-family:var(--font-mono);font-weight:700;font-size:10px;
  letter-spacing:.5px;color:var(--ink);background:var(--foil-solid);border:2px solid var(--ink);
  padding:4px 9px;border-radius:6px;box-shadow:2px 2px 0 var(--ink)}
.product__media::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;opacity:0;
  background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.4) 50%,transparent 65%);transition:opacity .3s}
.product:hover .product__media::after{opacity:1;animation:holo 1.2s ease}
.product__body{padding:15px 15px 17px;display:flex;flex-direction:column;gap:3px;flex:1}
.product__name{font-family:var(--font-display);font-weight:900;font-size:20px;letter-spacing:-.4px;color:var(--ink);line-height:1.05}
.product__jp{font-family:var(--font-jp);font-size:11.5px;color:var(--ink-faint);font-weight:500}
.product__row{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:13px}
.product__price{font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--rouge)}
.product__price small{font-family:var(--font-mono);font-weight:400;font-size:11px;color:var(--ink-faint)}
.product__add{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-weight:700;font-size:11px;
  text-transform:uppercase;letter-spacing:.5px;color:var(--ink);background:var(--foil-solid);border:2px solid var(--ink);
  border-radius:9px;padding:9px 13px;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .14s,box-shadow .14s,filter .2s}
.product__add:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.product__add:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--ink)}
.product__add svg{width:15px;height:15px}
.product__add.added{filter:saturate(.5)}
.shop-note{text-align:center;margin-top:34px;color:var(--ink-faint);font-size:14px;font-style:italic}

/* =========================================================
   CONTACT — grand coupon
   ========================================================= */
.section--contact{padding:104px 0}
.contact{position:relative;text-align:center;max-width:660px;margin-inline:auto;
  background:linear-gradient(165deg,#33240f,#1b1108);border:2.5px solid var(--ink);border-radius:18px;
  padding:62px 32px;box-shadow:12px 14px 0 rgba(42,28,18,.45);overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(229,168,43,.13) 1.1px,transparent 1.3px);background-size:15px 15px;
  pointer-events:none}
.contact::after{content:"";position:absolute;top:-50%;left:50%;transform:translateX(-50%);
  width:120%;height:120%;background:radial-gradient(circle,rgba(229,168,43,.12),transparent 60%);pointer-events:none}
.contact .eyebrow,.contact .section-title,.contact__sub,.contact .btn,.contact__hint{position:relative;z-index:2}
.contact .eyebrow{background:rgba(244,232,207,.06);border-color:var(--gold-dd);color:var(--gold-h);box-shadow:none}
.contact .eyebrow__star{color:var(--gold-h)}
.contact .section-title{color:var(--paper)}
.contact__sub{margin-bottom:30px;color:#cdbfa3}
.contact__sub b{color:var(--gold-h)}
.contact__hint{margin-top:18px;color:#9a8a6c;font-family:var(--font-mono);font-size:12.5px;letter-spacing:.5px}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{border-top:2.5px solid var(--ink);background:var(--paper-2);padding-top:56px}
.site-footer__inner{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:40px}
.site-footer__jp{display:block;color:var(--ink-faint);letter-spacing:3px;margin-top:8px;font-size:13px}
.site-footer__tag{color:var(--ink-soft);font-size:14.5px;margin-top:12px;max-width:340px}
.site-footer__nav{display:flex;flex-direction:column;gap:11px;align-items:flex-start}
.site-footer__nav a{font-family:var(--font-mono);color:var(--ink-soft);font-size:12.5px;text-transform:uppercase;
  letter-spacing:.5px;transition:color .2s}
.site-footer__nav a:hover{color:var(--rouge)}
.site-footer__bar{border-top:2px dashed var(--line-2);padding:20px 0;color:var(--ink-faint);font-size:12px}
.site-footer__bar-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;font-family:var(--font-mono)}

/* =========================================================
   PANIER (drawer)
   ========================================================= */
.cart-overlay,.order-overlay{position:fixed;inset:0;background:rgba(42,28,18,.5);backdrop-filter:blur(3px);
  z-index:80;opacity:0;transition:opacity .3s}
.cart-overlay.show,.order-overlay.show{opacity:1}
.cart-drawer{position:fixed;top:0;right:0;height:100dvh;width:min(420px,92vw);z-index:90;
  background:var(--paper);border-left:2.5px solid var(--ink);
  box-shadow:-16px 0 0 rgba(42,28,18,.12);display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1)}
.cart-drawer.show{transform:translateX(0)}
.cart-drawer__head{display:flex;align-items:center;justify-content:space-between;
  padding:22px 22px 16px;border-bottom:2px dashed var(--line-2)}
.cart-drawer__head h3{font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:-.5px}
.cart-drawer__close{width:38px;height:38px;border-radius:10px;border:2px solid var(--ink);
  background:var(--card);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;box-shadow:2px 2px 0 var(--ink);
  transition:background .2s,transform .14s,box-shadow .14s}
.cart-drawer__close:hover{background:var(--gold-h);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.cart-drawer__items{flex:1;overflow-y:auto;padding:14px 18px;display:flex;flex-direction:column;gap:12px}
.cart-item{display:flex;gap:13px;background:var(--card);border:2px solid var(--ink);
  border-radius:12px;padding:11px;align-items:center;box-shadow:2px 2px 0 var(--ink)}
.cart-item__img{width:50px;height:66px;border-radius:6px;object-fit:cover;flex:0 0 auto;background:var(--paper-3);border:1.5px solid var(--ink)}
.cart-item__info{flex:1;min-width:0}
.cart-item__name{font-family:var(--font-display);font-weight:900;font-size:16px;color:var(--ink);line-height:1.05}
.cart-item__price{font-family:var(--font-mono);font-size:11.5px;color:var(--rouge);font-weight:700;margin-top:3px}
.cart-item__qty{display:inline-flex;align-items:center;gap:0;margin-top:8px;border:2px solid var(--ink);
  border-radius:8px;overflow:hidden;background:var(--paper)}
.cart-item__qty button{width:28px;height:26px;background:transparent;border:none;color:var(--ink);
  font-size:16px;cursor:pointer;transition:background .15s}
.cart-item__qty button:hover{background:var(--gold-h)}
.cart-item__qty span{min-width:28px;text-align:center;font-family:var(--font-mono);font-size:13px;font-weight:700}
.cart-item__remove{align-self:flex-start;background:none;border:none;color:var(--ink-faint);cursor:pointer;
  font-size:20px;line-height:1;padding:2px 4px;transition:color .2s}
.cart-item__remove:hover{color:var(--rouge)}
.cart-drawer__empty{flex:1;display:none;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:14px;color:var(--ink-soft);padding:30px}
.cart-drawer__empty-bolt{font-size:42px;filter:drop-shadow(2px 3px 0 rgba(42,28,18,.2))}
.cart-drawer.is-empty .cart-drawer__items{display:none}
.cart-drawer.is-empty .cart-drawer__empty{display:flex}
.cart-drawer.is-empty .cart-drawer__foot{display:none}
.cart-drawer__foot{padding:18px 20px 22px;border-top:2px dashed var(--line-2);background:var(--paper-2)}
.cart-drawer__total{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cart-drawer__total span{font-family:var(--font-mono);color:var(--ink-soft);font-size:13px;text-transform:uppercase;letter-spacing:1px}
.cart-drawer__total b{font-family:var(--font-display);font-weight:900;font-size:26px;color:var(--rouge)}
.cart-drawer__note{margin-top:12px;font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);text-align:center;line-height:1.5}

/* =========================================================
   MODALE COMMANDE
   ========================================================= */
.order-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%) scale(.96);z-index:95;
  width:min(520px,92vw);max-height:88dvh;overflow-y:auto;
  background:var(--card);border:2.5px solid var(--ink);
  border-radius:18px;padding:32px 28px;box-shadow:12px 14px 0 rgba(42,28,18,.85);opacity:0;
  transition:opacity .3s,transform .3s}
.order-modal.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.order-modal__close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:10px;
  border:2px solid var(--ink);background:var(--paper);color:var(--ink);font-size:20px;cursor:pointer;box-shadow:2px 2px 0 var(--ink)}
.order-modal__close:hover{background:var(--gold-h)}
.order-modal__title{font-family:var(--font-display);font-weight:900;font-size:30px;margin:6px 0 10px;letter-spacing:-.8px}
.order-modal__lead{color:var(--ink-soft);font-size:15px;margin-bottom:16px}
.order-modal__lead b{color:var(--ink)}
.order-modal__recap{background:var(--paper);border:2px dashed var(--line-2);border-radius:10px;
  padding:16px;font-family:var(--font-mono);font-size:12.5px;color:var(--ink);white-space:pre-wrap;
  line-height:1.7;max-height:230px;overflow-y:auto;margin-bottom:18px}
.order-modal__actions{display:flex;gap:12px;flex-wrap:wrap}
.order-modal__actions .btn{flex:1;min-width:160px}

/* =========================================================
   TOAST
   ========================================================= */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:120;
  background:var(--ink);border:2px solid var(--ink);color:var(--paper);
  padding:13px 20px;border-radius:11px;font-family:var(--font-mono);font-weight:700;font-size:13px;
  box-shadow:5px 5px 0 rgba(42,28,18,.35);
  opacity:0;transition:opacity .3s,transform .3s;display:flex;align-items:center;gap:9px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast b{color:var(--gold-h)}

/* =========================================================
   REVEAL ON SCROLL
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.feat.reveal:nth-child(2){transition-delay:.08s}
.feat.reveal:nth-child(3){transition-delay:.16s}
.feat.reveal:nth-child(4){transition-delay:.24s}

/* =========================================================
   KEYFRAMES
   ========================================================= */
@keyframes floaty{0%,100%{transform:rotate(2deg) translateY(0)}50%{transform:rotate(2deg) translateY(-12px)}}
@keyframes coinBob{0%,100%{transform:translateY(0) rotate(-10deg)}50%{transform:translateY(-10px) rotate(-4deg)}}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.4) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(90deg)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes holo{from{transform:translateX(-30%)}to{transform:translateX(60%)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .shop-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .nav-links{display:none}
  .burger{display:flex}
  .hero{padding:30px 0 42px}
  .hero__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;min-height:0}
  .hero__content{display:contents}
  .hero__content .eyebrow{order:1;margin-bottom:0}
  .hero__title{order:2}
  .hero__jp{order:3;margin-top:2px}
  .hero__visual{order:4;min-height:0;padding-top:0;width:100%;margin:2px 0 4px}
  .hero__lead{order:5;max-width:48ch;margin-top:2px}
  .hero__cta{order:6;justify-content:center;width:100%;max-width:430px}
  .hero__chips{order:7;justify-content:center}
  .hero__mascot{width:min(56%,196px);margin-top:0}
  .hero__mascot-halo{width:clamp(220px,74%,330px);height:clamp(220px,74%,330px)}
  .coin,.stamp{display:none}
  .machines__grid{grid-template-columns:1fr;gap:40px}
  .machines__visual{order:-1}
  .section{padding:74px 0}
  .ig-pill span{display:none}
  .ig-pill{padding:9px}
  .cart-fab{top:auto;bottom:18px;right:16px;width:54px;height:54px}
}
@media (max-width:620px){
  .shop-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:1fr 1fr}
  .section-head{margin-bottom:40px}
  .product__add span{display:none}
  .site-footer__inner{flex-direction:column;gap:26px}
  .order-modal__actions .btn{min-width:100%}
  .stamp{width:78px;height:78px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
}
@media (max-width:420px){
  .shop-grid{grid-template-columns:1fr 1fr;gap:14px}
  .hero__title{font-size:clamp(60px,20vw,86px)}
  .ticket{grid-template-columns:78px 1fr}
}

/* =========================================================
   ACCESSIBILITÉ : motion réduit
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero__mascot{transform:rotate(2deg)}
}
