/* ========== HALASHI · Shared stylesheet ========== */
:root{
  --navy:#0f1340;
  --navy-2:#0a0d2e;
  --navy-3:#161a52;
  --red:#e0556a;
  --red-2:#c44060;
  --white:#ffffff;
  --ink:#e7e9ff;
  --muted:#9aa0d6;
  --line:rgba(255,255,255,.12);
  --green:#1fbf6f;
  --nav-h:72px;
  /* ── Tokens thème ── */
  --text:#ffffff;
  --card-bg:rgba(255,255,255,.025);
  --card-bg-2:rgba(255,255,255,.03);
  --card-bg-3:rgba(255,255,255,.04);
  --nav-bg:rgba(15,19,64,.55);
  --nav-bg-scrolled:rgba(15,19,64,.85);
  --input-bg:rgba(0,0,0,.20);
  --input-bg-focus:rgba(0,0,0,.30);
  --kanji-opacity:rgba(255,255,255,.025);
  --kanji-accent:rgba(224,85,106,.04);
  --story-kanji:rgba(255,255,255,.025);
}

/* ── Thème Clair (blanc · bleu · noir — sans rouge) ── */
[data-theme="light"]{
  --navy:#f4f5ff;
  --navy-2:#ffffff;
  --navy-3:#e4e7ff;
  --red:#0f1340;
  --red-2:#0a0d2e;
  --ink:#1e2870;
  --muted:#5060a8;
  --line:rgba(15,19,64,.12);
  --text:#0f1340;
  --card-bg:rgba(15,19,64,.04);
  --card-bg-2:rgba(15,19,64,.05);
  --card-bg-3:rgba(15,19,64,.06);
  --nav-bg:rgba(244,245,255,.82);
  --nav-bg-scrolled:rgba(248,249,255,.96);
  --input-bg:rgba(15,19,64,.06);
  --input-bg-focus:rgba(15,19,64,.09);
  --kanji-opacity:rgba(15,19,64,.04);
  --kanji-accent:rgba(15,19,64,.05);
  --story-kanji:rgba(15,19,64,.03);
}

/* ── Thème Sombre (bleu → noir) ── */
[data-theme="dark"]{
  --navy:#0b0c16;
  --navy-2:#0e1020;
  --navy-3:#151830;
  --ink:#c0c4e0;
  --muted:#7078a8;
  --line:rgba(100,120,255,.14);
  --text:#ffffff;
  --card-bg:rgba(30,40,120,.08);
  --card-bg-2:rgba(30,40,120,.12);
  --card-bg-3:rgba(30,40,120,.16);
  --nav-bg:rgba(11,12,22,.70);
  --nav-bg-scrolled:rgba(10,11,20,.94);
  --input-bg:rgba(30,40,120,.14);
  --input-bg-focus:rgba(30,40,120,.20);
  --kanji-opacity:rgba(80,100,255,.06);
  --kanji-accent:rgba(224,85,106,.07);
  --story-kanji:rgba(80,100,255,.05);
  --blue-glow:rgba(30,40,120,.50);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--navy);color:var(--text);font-family:"Noto Sans JP",system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s ease,color .3s ease}
body{min-height:100vh;line-height:1.5}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;color:inherit;cursor:pointer}
img{display:block;max-width:100%}
.ar{font-family:"Noto Naskh Arabic",serif}
main{display:block}

/* ============ NAV ============ */
.nav__logo{height:calc(var(--nav-h) + 18px);width:auto;margin:-9px 0;display:block;position:relative;z-index:2;filter:drop-shadow(0 3px 10px rgba(0,0,0,.35));}
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(20px,4vw,56px);
  transition:background .25s ease,backdrop-filter .25s ease,border-color .25s ease;
  overflow:visible;
  border-bottom:1px solid transparent;
  background:var(--nav-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.nav.scrolled{background:var(--nav-bg-scrolled);border-bottom-color:var(--line)}
.nav__brand{display:flex;align-items:center;gap:10px}
.nav__mark{
  font-family:"Potta One",system-ui,sans-serif;font-size:26px;letter-spacing:.01em;line-height:1;
  display:inline-flex;align-items:baseline;
}
.nav__mark .accent{color:var(--red)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:14px;letter-spacing:.04em;font-weight:500;color:var(--ink);position:relative;padding:6px 0}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__links a[data-active]{color:var(--text)}
.nav__links a[data-active]::after{transform:scaleX(1)}
.nav__cta{background:var(--red);color:#fff;padding:11px 18px;border-radius:999px;font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;transition:transform .15s ease,background .2s ease;display:inline-flex;align-items:center;gap:8px}
.nav__cta:hover{background:var(--red-2);transform:translateY(-1px)}
.nav__cta::after{content:"→";font-family:system-ui}
.nav__burger{display:none;width:44px;height:44px;border-radius:10px;border:1px solid var(--line);align-items:center;justify-content:center}
.nav__burger span{display:block;width:18px;height:2px;background:var(--text);position:relative}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--text);transition:transform .25s}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}
.nav.open .nav__burger span{background:transparent}
.nav.open .nav__burger span::before{transform:translateY(6px) rotate(45deg)}
.nav.open .nav__burger span::after{transform:translateY(-6px) rotate(-45deg)}

/* ── Theme toggle button ── */
.theme-toggle{
  display:flex;width:42px;height:42px;border-radius:10px;
  border:1px solid var(--line);align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;margin-right:8px;
  transition:background .2s,border-color .2s,transform .15s;
}
.theme-toggle:hover{border-color:var(--red);background:var(--card-bg-2);transform:scale(1.06)}
@media(min-width:901px){.theme-toggle{margin-right:12px}}

.mobile-menu{
  position:fixed;inset:var(--nav-h) 0 0 0;z-index:40;background:var(--navy);
  transform:translateY(-100%);transition:transform .35s cubic-bezier(.7,0,.3,1);
  padding:40px clamp(20px,6vw,40px);display:flex;flex-direction:column;gap:8px;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:"Noto Sans JP";font-weight:900;font-size:30px;padding:14px 0;border-bottom:1px solid var(--line);letter-spacing:-.01em}
.mobile-menu a[data-active]{color:var(--red)}
.mobile-menu .nav__cta{align-self:flex-start;margin-top:24px;font-size:14px;padding:14px 22px;border-bottom:none}

/* ============ COMMON / SECTIONS ============ */
section{padding:clamp(80px,12vw,160px) clamp(20px,5vw,80px);position:relative}
.container{max-width:1240px;margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;color:var(--red);
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;font-weight:700;margin-bottom:18px;
}
.eyebrow::before{content:"";width:36px;height:2px;background:var(--red)}
h2.section-title,.section-title{
  font-family:"Potta One";font-size:clamp(40px,6vw,76px);line-height:1;letter-spacing:.01em;
  margin-bottom:24px;text-wrap:balance;
}
.lead{font-size:clamp(15px,1.4vw,18px);color:var(--ink);max-width:62ch;line-height:1.7;font-weight:300}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;border-radius:999px;font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;transition:transform .15s ease,background .2s,border-color .2s}
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:var(--red-2);transform:translateY(-2px)}
.btn--ghost{border:1px solid var(--line);color:var(--text)}
.btn--ghost:hover{border-color:var(--red);background:var(--card-bg)}
.btn--big{padding:20px 32px;font-size:15px}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* Halal pill */
.halal-pill{
  display:inline-flex;align-items:center;gap:10px;margin-top:14px;
  padding:8px 14px;border-radius:999px;background:rgba(31,191,111,.10);border:1px solid rgba(31,191,111,.25);
  font-size:12px;color:#bdf0d4;letter-spacing:.04em;
}
.halal-pill .gdot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(31,191,111,.18)}

/* ============ HERO (Home only) ============ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + var(--promo-h,0px) + 10px) clamp(20px,4vw,60px) 80px;overflow:hidden;
  background:
    radial-gradient(1100px 600px at 50% 8%, rgba(224,85,106,.10), transparent 60%),
    radial-gradient(900px 700px at 50% 100%, rgba(255,255,255,.04), transparent 70%),
    var(--navy);
  transition:background .4s ease;
}

/* Overrides des rouges hardcodés en thème clair */
[data-theme="light"] .page-head::before{color:rgba(15,19,64,.06)}
[data-theme="light"] .hero__badge .dot{background:#0f1340;box-shadow:0 0 0 4px rgba(15,19,64,.15)}
[data-theme="light"] .xcard:hover{border-color:rgba(15,19,64,.35)}
[data-theme="light"] .xcard:hover .xcard__kanji{color:rgba(15,19,64,.12)}
[data-theme="light"] .value::before{background:#0f1340}
[data-theme="light"] .menu__jump a.active{box-shadow:0 4px 14px rgba(15,19,64,.20)}
[data-theme="light"] .ecard:hover{border-color:rgba(15,19,64,.40);background:rgba(15,19,64,.03)}
[data-theme="light"] .ecard:hover .ecard__arrow{background:#0f1340;border-color:#0f1340}
[data-theme="light"] .contact-card{background:rgba(15,19,64,.05);border-color:rgba(15,19,64,.18)}
[data-theme="light"] .contact-card::before{background:radial-gradient(circle,rgba(15,19,64,.18),transparent 70%)}
[data-theme="light"] .contact-card h4{color:rgba(15,19,64,.55)}
[data-theme="light"] .contact-card .email{color:#0f1340}
[data-theme="light"] .cinfo:hover{border-color:rgba(15,19,64,.35);background:rgba(15,19,64,.04)}
[data-theme="light"] .cinfo__icon{background:rgba(15,19,64,.07);border-color:rgba(15,19,64,.18);color:#0f1340}
[data-theme="light"] .tagchip.pop{background:rgba(15,19,64,.06);border-color:rgba(15,19,64,.20);color:#0f1340}
[data-theme="light"] .halal-pill{background:rgba(15,100,70,.08);border-color:rgba(15,100,70,.20);color:#0a5c3a}
[data-theme="light"] .halal-pill .gdot{background:#0a7a48;box-shadow:0 0 0 4px rgba(10,122,72,.15)}
[data-theme="light"] .social-strip a:hover{background:#0f1340;border-color:#0f1340}
[data-theme="light"] .poster--red .poster__cover{background:linear-gradient(135deg,#0f1340 0%,#161a52 100%)}

[data-theme="light"] .hero{
  background:
    radial-gradient(1100px 600px at 50% 8%, rgba(224,85,106,.08), transparent 60%),
    radial-gradient(900px 700px at 50% 100%, rgba(15,19,64,.04), transparent 70%),
    var(--navy);
}
.petals{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.petal{position:absolute;top:-40px;opacity:0;animation:fall linear infinite;will-change:transform,opacity}
@keyframes fall{
  0%{transform:translate3d(0,-40px,0) rotate(0);opacity:0}
  8%{opacity:.85}
  50%{transform:translate3d(40px,55vh,0) rotate(180deg)}
  100%{transform:translate3d(-30px,110vh,0) rotate(360deg);opacity:0}
}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,70px);align-items:center;max-width:1320px;width:100%}
.hero__left{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;}
.hero__right{display:flex;flex-direction:column;align-items:flex-start;gap:22px;text-align:left}
@media(max-width:900px){.hero__badge{display:none}}
.hero__badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border:1px solid var(--line);border-radius:999px;
  background:var(--card-bg-3);backdrop-filter:blur(6px);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);font-weight:500;
}
.hero__badge .dot{width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(224,85,106,.18)}
.hero__headline{font-family:"Potta One",system-ui,sans-serif;font-size:clamp(40px,5.5vw,68px);line-height:1.02;letter-spacing:.005em;color:var(--text);text-wrap:balance}
.hero__headline .accent{color:var(--red)}
.hero-prix{
  font-size:13px;color:rgba(255,255,255,.65);font-weight:300;letter-spacing:.02em;
}
.hero-prix strong{color:rgba(255,255,255,.90);font-weight:700;}
[data-theme="light"] .hero-prix{color:rgba(15,19,64,.55);}
[data-theme="light"] .hero-prix strong{color:rgba(15,19,64,.80);}
.hero__tag{font-family:"Noto Sans JP";font-weight:300;font-size:clamp(15px,1.4vw,18px);color:var(--ink);max-width:54ch;line-height:1.65}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}

.logo-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:0;width:100%}
.pulse{position:absolute;left:50%;top:50%;border-radius:50%;border:1px solid rgba(255,255,255,.22);transform:translate(-50%,-50%);animation:pulseRing 3.6s ease-out infinite;pointer-events:none}
.pulse.p2{animation-delay:1.2s;border-color:rgba(224,85,106,.35)}
.pulse.p3{animation-delay:2.4s}
@keyframes pulseRing{
  0%{width:140px;height:140px;opacity:.0}
  20%{opacity:.6}
  100%{width:620px;height:620px;opacity:0}
}
.hero__logo{position:relative;display:block;height:clamp(360px,82vh,820px);width:auto;max-width:100%;filter:drop-shadow(0 12px 40px rgba(0,0,0,.35))}
[data-theme="light"] .hero__logo{mix-blend-mode:multiply;filter:drop-shadow(0 8px 24px rgba(15,19,64,.15))}

.hero__meta{
  position:absolute;left:0;right:0;bottom:24px;display:flex;justify-content:space-between;
  align-items:center;padding:0 clamp(20px,4vw,56px);color:var(--muted);font-size:11px;letter-spacing:.22em;text-transform:uppercase;z-index:2;
}
.hero__meta .vline{display:inline-block;width:1px;height:32px;background:var(--line);margin:0 14px;vertical-align:middle}
.scroll-indicator{display:flex;align-items:center;justify-content:center;transition:opacity .4s ease;}
.scroll-arrow{
  width:24px;height:24px;
  border-right:2px solid rgba(255,255,255,.4);
  border-bottom:2px solid rgba(255,255,255,.4);
  transform:rotate(45deg);
  animation:scrollBounce 1.5s infinite;
}
@keyframes scrollBounce{
  0%,100%{transform:rotate(45deg) translateY(0);opacity:.4;}
  50%{transform:rotate(45deg) translateY(6px);opacity:1;}
}

/* ============ PAGE HEADER (inner pages) ============ */
.page-head{
  padding:calc(var(--nav-h) + var(--promo-h,0px) + 90px) clamp(20px,5vw,80px) 60px;
  position:relative;overflow:hidden;
}
.page-head::before{
  content:attr(data-kanji);
  position:absolute;right:-40px;top:40px;
  font-family:"Noto Sans JP";font-weight:900;font-size:clamp(180px,26vw,360px);line-height:1;
  color:rgba(224,85,106,.07);pointer-events:none;letter-spacing:-.08em;user-select:none;
  transform:translateY(var(--kanji-parallax,0px));
  will-change:transform;
}
.page-head__inner{max-width:1240px;margin:0 auto;position:relative;z-index:2}
.page-head h1{font-family:"Potta One";font-size:clamp(48px,7vw,96px);line-height:.95;letter-spacing:.005em;color:var(--text);text-wrap:balance;margin-bottom:20px}
.page-head h1 .accent{color:var(--red)}
.page-head .lead{max-width:54ch}
.page-head--compact{padding-bottom:20px;}

/* ── Supprimer fil d'ariane & eyebrow numéroté ── */
.crumb{display:none}
.eyebrow.reveal{display:none}

/* ============ HOME · Explore cards ============ */
.explore{background:linear-gradient(180deg,var(--navy) 0,var(--navy-2) 100%)}
.explore__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.xcard{
  position:relative;border-radius:22px;border:1px solid var(--line);background:var(--card-bg);
  padding:30px 26px;min-height:280px;display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;transition:transform .3s ease,border-color .3s,background .3s;
}
.xcard:hover{transform:translateY(-4px);border-color:rgba(224,85,106,.45);background:rgba(224,85,106,.04)}
.xcard__kanji{
  position:absolute;top:-30px;right:-16px;font-family:"Noto Sans JP";font-weight:900;font-size:200px;line-height:1;
  color:var(--kanji-opacity);letter-spacing:-.08em;pointer-events:none;user-select:none;transition:color .3s ease;
}
.xcard:hover .xcard__kanji{color:rgba(224,85,106,.16)}
.xcard__num{position:relative;font-family:"Potta One";color:var(--red);font-size:14px;letter-spacing:.22em}
.xcard__title{position:relative;font-family:"Potta One";font-size:32px;line-height:1;letter-spacing:.005em;margin-top:14px}
.xcard__desc{position:relative;color:var(--muted);font-size:13px;line-height:1.6;margin-top:10px}
.xcard__arrow{position:relative;align-self:flex-start;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-top:auto;transition:background .2s,border-color .2s,transform .2s}
.xcard:hover .xcard__arrow{background:var(--red);border-color:var(--red);transform:translateX(4px)}

/* ============ HISTOIRE ============ */
.story{position:relative;background:linear-gradient(180deg,var(--navy) 0,var(--navy-2) 100%)}
.story::before{content:"拉麺";position:absolute;left:-40px;top:80px;font-family:"Noto Sans JP";font-weight:900;font-size:280px;color:var(--story-kanji);line-height:1;pointer-events:none;letter-spacing:-.05em}
.story__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.story__copy p{color:var(--ink);font-weight:300;font-size:16px;line-height:1.75;margin-bottom:18px}
.story__copy p strong{color:var(--text);font-weight:500}

.values{display:flex;flex-direction:column;gap:14px}
.value{
  position:relative;background:var(--card-bg-2);border:1px solid var(--line);border-radius:14px;
  padding:24px 26px 24px 28px;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;
  transition:transform .3s ease,background .3s ease,border-color .3s ease;overflow:hidden;
}
.value::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--red)}
.value:hover{transform:translateX(4px);background:var(--card-bg-3);border-color:rgba(255,255,255,.18)}
[data-theme="light"] .value:hover{border-color:rgba(15,19,64,.18)}
.value__num{font-family:"Potta One";font-size:64px;line-height:1;color:var(--text);opacity:.95}
.value__body h4{font-family:"Noto Sans JP";font-weight:900;font-size:18px;letter-spacing:.01em;margin-bottom:6px}
.value__body p{color:var(--muted);font-size:14px;line-height:1.65}

/* ============ MENU (poster style) ============ */
.menu{background:var(--navy-2)}
.menu__head{display:flex;flex-direction:column;gap:18px;margin-bottom:28px}
.menu__head .lead{max-width:62ch}
.menu__jump{
  display:flex;gap:6px;flex-wrap:nowrap;
  overflow-x:scroll;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;scroll-behavior:smooth;
  padding:6px 0 8px;margin:0;
  border-bottom:1px solid var(--line);
  width:100%;
  -webkit-mask-image:linear-gradient(to right,black 80%,transparent 100%);
  mask-image:linear-gradient(to right,black 80%,transparent 100%);
}
.menu__jump::-webkit-scrollbar{display:none}
.menu__jump a{
  flex:0 0 auto;padding:10px 14px;border:1px solid var(--line);border-radius:999px;
  font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--ink);
  transition:background .2s,color .2s,border-color .2s;white-space:nowrap;cursor:pointer;
}
.menu__jump a:hover{color:var(--text);border-color:var(--red)}
.menu__jump a.active{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 4px 14px rgba(224,85,106,.30)}

.menu__posters{
  display:flex;gap:24px;align-items:stretch;
  overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
  padding:4px 0 18px;margin:0 -8px;scroll-padding-inline:8px;
}
.menu__posters::-webkit-scrollbar{display:none}
.poster{
  flex:0 0 min(720px, 88vw);scroll-snap-align:center;scroll-margin-inline:8px;
  border-radius:24px;overflow:hidden;border:1px solid var(--line);
  background:var(--card-bg);
  transition:transform .35s ease,border-color .35s ease;
  display:flex;flex-direction:column;
}
.poster:hover{border-color:rgba(255,255,255,.22)}
[data-theme="light"] .poster:hover{border-color:rgba(15,19,64,.18)}
.poster__cover{
  position:relative;height:130px;overflow:hidden;
  display:flex;align-items:flex-end;padding:20px 26px;
}
.poster--red .poster__cover{background:radial-gradient(120% 100% at 0% 0%,var(--red) 0%,var(--red-2) 100%)}
.poster--navy .poster__cover{background:linear-gradient(135deg,var(--navy-3) 0%,var(--navy) 100%);border-bottom:1px solid var(--line)}
/* Poster navy restez lisible en thème clair */
[data-theme="light"] .poster--navy .poster__cover{background:linear-gradient(135deg,#1e2870 0%,#0f1340 100%);border-bottom-color:rgba(255,255,255,.12)}
.poster--photo .poster__cover{background-size:cover;background-position:center;height:260px;border-bottom:1px solid var(--line)}
.poster__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,19,64,.10) 0%,rgba(15,19,64,.20) 40%,rgba(15,19,64,.78) 100%);pointer-events:none}
.poster__kanji{
  position:absolute;top:-46px;right:-20px;
  font-family:"Noto Sans JP";font-weight:900;font-size:280px;line-height:1;
  color:rgba(224,85,106,.28);letter-spacing:-.08em;pointer-events:none;user-select:none;
}
.poster--navy .poster__kanji{color:rgba(224,85,106,.28)}
.poster--photo .poster__kanji{color:rgba(224,85,106,.28);}
.poster__corner{display:none}
.poster__title{position:relative;z-index:2;color:#fff}
.poster__title h3{font-family:"Potta One";font-size:clamp(34px,3.6vw,46px);line-height:1;letter-spacing:.005em}
.poster__title .jp{display:block;font-family:"Noto Sans JP";font-weight:500;font-size:13px;letter-spacing:.2em;margin-top:8px;opacity:.85}

.poster__list{padding:24px 26px 26px;display:flex;flex-direction:column;gap:14px}
.dish{padding-bottom:14px;border-bottom:1px dashed rgba(255,255,255,.10)}
.dish:last-child{border-bottom:none;padding-bottom:0}
[data-theme="light"] .dish{border-bottom-color:rgba(15,19,64,.10)}
[data-theme="light"] .dish:last-child{border-bottom:none}
.dish--photo{display:grid;grid-template-columns:80px 1fr;gap:16px;align-items:start}
.dish__img{width:80px;height:80px;border-radius:12px;object-fit:cover;border:1px solid var(--line);background:var(--card-bg);cursor:zoom-in;transition:transform .25s,border-color .25s;}
.dish__img:hover{transform:scale(1.06);border-color:var(--red);}
.dish__body{min-width:0}
.dish__head{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:5px}
.dish__name{font-family:"Noto Sans JP";font-weight:900;font-size:16px;letter-spacing:0;line-height:1.25;color:var(--text)}
.dish__price{font-family:"Noto Sans JP";font-weight:900;font-size:17px;color:var(--text);white-space:nowrap;letter-spacing:.01em}
.dish__desc{color:var(--muted);font-size:13px;line-height:1.55;font-weight:300}
.dish__tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.tagchip{font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:4px 9px;border-radius:999px;border:1px solid var(--line);color:var(--ink);font-weight:700}
.tagchip.pop{background:rgba(224,85,106,.12);border-color:rgba(224,85,106,.35);color:#ffd0d6}
.tagchip.premium{background:var(--card-bg-3);border-color:rgba(255,255,255,.22);color:var(--text)}
.tagchip.veg{background:rgba(31,191,111,.10);border-color:rgba(31,191,111,.30);color:#bdf0d4}
.tagchip.spicy{background:rgba(255,140,40,.10);border-color:rgba(255,140,40,.35);color:#ffd2a8}

.menu__footer{margin-top:48px;display:flex;justify-content:center;flex-direction:column;align-items:center;gap:14px;text-align:center}
.menu__note{color:var(--muted);font-size:13px;max-width:520px;line-height:1.6}

/* ============ EVENTS ============ */
.events{background:linear-gradient(180deg,var(--navy-2) 0,var(--navy) 100%);position:relative}
.events__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:start}
.events__cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ecard{
  position:relative;background:var(--card-bg-2);border:1px solid var(--line);border-radius:18px;
  padding:28px 24px;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .3s ease,border-color .3s,background .3s;overflow:hidden;
}
.ecard{cursor:default}
.ecard__icon{font-size:30px;margin-bottom:14px}
.ecard h4{font-family:"Noto Sans JP";font-weight:900;font-size:19px;letter-spacing:0;line-height:1.25;margin-bottom:8px}
.ecard p{color:var(--muted);font-size:13px;line-height:1.6}
.ecard__arrow{position:absolute;right:18px;bottom:18px;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--ink);transition:background .2s,border-color .2s,color .2s}
.ecard:hover .ecard__arrow{background:var(--red);border-color:var(--red);color:#fff}

.events__side h3{font-family:"Noto Sans JP";font-weight:900;font-size:clamp(26px,2.8vw,34px);line-height:1.2;margin-bottom:18px;text-wrap:balance;letter-spacing:-.01em}
.events__side p{color:var(--ink);font-weight:300;line-height:1.7;margin-bottom:24px}
.contact-card{
  background:rgba(224,85,106,.08);border:1px solid rgba(224,85,106,.30);border-radius:18px;padding:26px;margin-bottom:20px;
  position:relative;overflow:hidden;
}
.contact-card::before{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(224,85,106,.25),transparent 70%)}
.contact-card h4{font-family:"Noto Sans JP";font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#ffc6cd;margin-bottom:10px;position:relative}
.contact-card .email{font-family:"Noto Sans JP";font-weight:900;font-size:22px;color:#fff;display:block;margin-bottom:4px;position:relative;word-break:break-word;letter-spacing:-.01em}
.contact-card .phone{color:var(--ink);font-size:14px;position:relative}

/* ============ COMMANDER ============ */
.order{background:var(--navy-2);position:relative;overflow:hidden}
.order__hero{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.order__big{
  font-family:"Potta One";font-size:clamp(60px,9vw,140px);line-height:.92;color:var(--text);letter-spacing:.005em;text-wrap:balance;
}
.order__big .accent{color:var(--red)}
.order__cta{display:flex;flex-direction:column;gap:14px;align-items:flex-start;margin-top:24px}
.order__panel{
  position:relative;background:radial-gradient(120% 100% at 0% 0%,var(--red),var(--red-2));
  border-radius:28px;padding:42px 36px;color:#fff;overflow:hidden;
}
.order__panel::before{content:"出";position:absolute;top:-50px;right:-30px;font-family:"Noto Sans JP";font-weight:900;font-size:280px;color:rgba(255,255,255,.10);line-height:1}
.order__panel h3{font-family:"Potta One";font-size:30px;line-height:1.05;margin-bottom:10px;position:relative}
.order__panel p{font-size:14px;line-height:1.65;margin-bottom:24px;color:#ffe4e8;position:relative;max-width:32ch}
.order__panel .btn{position:relative}
.order__panel .btn--white{background:#fff;color:var(--red)}
.order__panel .btn--white:hover{background:#ffd0d6}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.step{
  position:relative;background:var(--card-bg-2);border:1px solid var(--line);border-radius:18px;
  padding:30px 26px;
}
.step__num{
  font-family:"Potta One";font-size:42px;line-height:1;color:var(--red);margin-bottom:14px;
}
.step h4{font-family:"Noto Sans JP";font-weight:900;font-size:18px;margin-bottom:8px}
.step p{color:var(--muted);font-size:13px;line-height:1.6}

.delivery{margin-top:60px;display:grid;grid-template-columns:1fr 1fr;gap:30px}
.delivery__card{
  background:var(--card-bg-2);border:1px solid var(--line);border-radius:18px;padding:30px;
}
.delivery__card h4{font-family:"Noto Sans JP";font-weight:900;font-size:18px;margin-bottom:14px;letter-spacing:.01em}
.delivery__card ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.delivery__card li{color:var(--ink);font-size:14px;display:flex;align-items:center;gap:10px}
.delivery__card li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);flex:0 0 auto}
.delivery__card .platforms{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.delivery__card .plat{padding:8px 14px;border:1px solid var(--line);border-radius:999px;font-size:12px;letter-spacing:.06em;font-weight:700}

/* ============ CONTACT ============ */
.contact{background:linear-gradient(180deg,var(--navy-2) 0,var(--navy) 100%);position:relative}
.contact::before{content:"連絡";position:absolute;right:-30px;bottom:-60px;font-family:"Noto Sans JP";font-weight:900;font-size:280px;color:var(--kanji-accent);line-height:1;letter-spacing:-.05em;pointer-events:none}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact__info{display:flex;flex-direction:column;gap:22px}
.cinfo{
  display:grid;grid-template-columns:auto 1fr;gap:18px;
  background:var(--card-bg-2);border:1px solid var(--line);border-radius:18px;padding:24px 26px;
  align-items:center;transition:border-color .25s,background .25s;
}
.cinfo:hover{border-color:rgba(224,85,106,.40);background:rgba(224,85,106,.03)}
.cinfo__icon{
  width:48px;height:48px;border-radius:14px;background:rgba(224,85,106,.12);border:1px solid rgba(224,85,106,.30);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--red);
}
.cinfo__label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:4px}
.cinfo__value{font-family:"Noto Sans JP";font-weight:900;font-size:17px;color:var(--text);letter-spacing:0}
.cinfo__value a:hover{color:var(--red)}
.cinfo__sub{font-size:13px;color:var(--ink);margin-top:2px;font-weight:300}

.form{background:var(--card-bg);border:1px solid var(--line);border-radius:22px;padding:34px}
.form h3{font-family:"Potta One";font-size:26px;margin-bottom:8px}
.form .lead{margin-bottom:24px;font-size:14px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700}
.field input,.field select,.field textarea{
  background:var(--input-bg);border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  color:var(--text);font-family:"Noto Sans JP";font-size:14px;font-weight:400;transition:border-color .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);background:var(--input-bg-focus)}
.field textarea{resize:vertical;min-height:120px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .btn{margin-top:6px;width:100%;justify-content:center}

/* ====== Page Contact ====== */
.contact-page{
  padding:40px clamp(20px,5vw,80px) 100px;
  background:var(--navy);min-height:100vh;
}
.contact-page__inner{max-width:960px;margin:0 auto;}
.contact-page__grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:32px;align-items:start;
}

/* ── Infos (adresse, horaires, social) ── */
.cinfo-stack{display:flex;flex-direction:column;gap:14px;}
.cinfo2{
  background:var(--card-bg-2);border:1px solid var(--line);border-radius:18px;
  padding:22px 24px;
  transition:border-color .25s,background .25s;
}
.cinfo2:hover{border-color:rgba(100,120,255,.30);}
[data-theme="dark"] .cinfo2:hover{border-color:rgba(80,100,255,.40);}
.cinfo2__label{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);font-weight:700;margin-bottom:8px;
}
.cinfo2__value{
  font-family:"Noto Sans JP";font-weight:900;font-size:16px;color:var(--text);
  line-height:1.5;letter-spacing:-.01em;
}
.cinfo2__value a:hover{color:var(--red);}
a[href^="tel"]{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:14px;font-weight:700;color:var(--text);letter-spacing:.02em;transition:color .2s;}
a[href^="tel"]:hover{color:var(--red);}
.btn-itineraire{
  display:inline-flex;align-items:center;gap:7px;margin-top:12px;
  border:1px solid var(--line);border-radius:999px;
  padding:8px 16px;font-size:12px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink);
  transition:border-color .2s,color .2s,background .2s;
}
.btn-itineraire:hover{border-color:var(--red);color:var(--text);background:var(--card-bg);}
.btn-itineraire span{transition:transform .25s;}
.btn-itineraire:hover span{transform:translateX(3px);}
.cinfo2__sub{font-size:13px;color:var(--muted);margin-top:4px;font-weight:300;}

.hours-table{display:flex;flex-direction:column;gap:0;}
.hrow{
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  padding:9px 0;border-bottom:1px solid var(--line);font-size:13px;
}
.hrow:last-child{border-bottom:none;padding-bottom:0;}
.hrow__day{color:var(--text);font-weight:700;}
.hrow__time{color:var(--muted);text-align:right;line-height:1.5;}

.social-row{display:flex;gap:10px;margin-top:4px;}
.social-pill{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);border-radius:999px;
  padding:8px 16px;font-size:13px;font-weight:700;color:var(--ink);
  transition:border-color .2s,color .2s,background .2s;
}
.social-pill:hover{border-color:var(--red);color:var(--text);}

/* ── Formulaire style Delicity ── */
.form-blue{
  position:relative;
  border-radius:28px;overflow:hidden;
  background:linear-gradient(135deg,rgba(30,40,120,.75) 0%,var(--navy-2) 100%);
  border:1px solid rgba(255,255,255,.15);
  padding:40px 36px;
  transition:border-color .3s;
}
[data-theme="light"] .form-blue{
  background:linear-gradient(135deg,#dde1ff 0%,#f4f5ff 100%);
  border-color:rgba(15,19,64,.16);
}
[data-theme="dark"] .form-blue{
  background:linear-gradient(135deg,rgba(30,40,140,.80) 0%,rgba(14,16,32,.95) 100%);
  border-color:rgba(80,100,255,.20);
}
.form-blue::before{
  content:"連";position:absolute;right:-20px;top:-50px;
  font-family:"Noto Sans JP";font-weight:900;font-size:280px;line-height:1;
  color:rgba(255,255,255,.05);pointer-events:none;user-select:none;
}
[data-theme="light"] .form-blue::before{color:rgba(15,19,64,.04);}
[data-theme="dark"] .form-blue::before{color:rgba(80,100,255,.06);}

.form-blue h3{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(26px,3vw,34px);color:var(--text);
  margin-bottom:6px;position:relative;
}
.form-blue .sublead{
  color:var(--ink);font-size:14px;font-weight:300;line-height:1.6;
  margin-bottom:28px;position:relative;
}
.form-blue .field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;position:relative;}
.form-blue .field label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.form-blue .field input,
.form-blue .field select,
.form-blue .field textarea{
  background:rgba(0,0,0,.20);border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:13px 15px;color:var(--text);font-family:"Noto Sans JP";font-size:14px;
  transition:border-color .2s,background .2s;
}
[data-theme="light"] .form-blue .field input,
[data-theme="light"] .form-blue .field select,
[data-theme="light"] .form-blue .field textarea{
  background:rgba(15,19,64,.06);border-color:rgba(15,19,64,.14);
}
[data-theme="dark"] .form-blue .field input,
[data-theme="dark"] .form-blue .field select,
[data-theme="dark"] .form-blue .field textarea{
  background:rgba(30,40,120,.20);border-color:rgba(80,100,255,.18);
}
.form-blue .field input:focus,
.form-blue .field select:focus,
.form-blue .field textarea:focus{
  outline:none;border-color:rgba(255,255,255,.40);background:rgba(0,0,0,.30);
}
[data-theme="light"] .form-blue .field input:focus,
[data-theme="light"] .form-blue .field select:focus,
[data-theme="light"] .form-blue .field textarea:focus{
  border-color:rgba(15,19,64,.35);background:rgba(15,19,64,.09);
}
[data-theme="dark"] .form-blue .field input:focus,
[data-theme="dark"] .form-blue .field select:focus,
[data-theme="dark"] .form-blue .field textarea:focus{
  border-color:rgba(80,100,255,.50);background:rgba(30,40,120,.28);
}
.form-blue .field textarea{resize:vertical;min-height:110px;}
.form-blue .form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-blue .btn--send{
  position:relative;display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;margin-top:6px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  color:#fff;padding:16px 24px;border-radius:999px;
  font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  transition:background .2s,border-color .2s,transform .15s;cursor:pointer;
}
.form-blue .btn--send:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.40);transform:translateY(-2px);}
[data-theme="light"] .form-blue .btn--send{
  background:rgba(15,19,64,.85);border-color:rgba(15,19,64,.90);color:#fff;
}
[data-theme="light"] .form-blue .btn--send:hover{background:#0f1340;}
[data-theme="dark"] .form-blue .btn--send{
  background:linear-gradient(135deg,#1e2878,#2030a0);
  border-color:rgba(80,100,255,.50);
}
[data-theme="dark"] .form-blue .btn--send:hover{border-color:rgba(80,100,255,.80);}
.form-blue .btn--send .arrow{transition:transform .25s;}
.form-blue .btn--send:hover .arrow{transform:translateX(4px);}

/* Responsive */
@media(max-width:760px){
  .contact-page__grid{grid-template-columns:1fr;}
  .form-blue .form__row{grid-template-columns:1fr;}
  .form-blue{padding:28px 22px;}
}

/* ============ SOCIAL STRIP ============ */
.social-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.social-strip a{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--ink);
  transition:background .2s,border-color .2s,color .2s;
}
.social-strip a:hover{background:var(--red);border-color:var(--red);color:#fff}

/* ============ FOOTER ============ */
footer{padding:60px clamp(20px,5vw,80px) 30px;border-top:1px solid var(--line);background:var(--navy-2);position:relative}
.footer__grid{display:grid;grid-template-columns:1.4fr .8fr .8fr .8fr .8fr;gap:40px;margin-bottom:40px}
.footer__brand .mark{font-family:"Potta One";font-size:44px;display:inline-block;line-height:1;letter-spacing:.01em}
.footer__brand .mark .accent{color:var(--red)}
.footer__brand p{color:var(--muted);font-size:14px;line-height:1.7;margin-top:16px;max-width:340px}
.footer__col h5{font-family:"Noto Sans JP";font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;color:var(--text)}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer__col a{color:var(--ink);font-size:14px;transition:color .2s}
.footer__col a:hover{color:var(--red)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);letter-spacing:.12em;flex-wrap:wrap;gap:18px}
.footer__bottom .lang{display:flex;gap:18px;align-items:center}
.footer__bottom .lang .red{color:var(--red);font-family:"Noto Sans JP";font-weight:700;font-size:14px;letter-spacing:.04em}
.footer__bottom .lang .ar{font-family:"Noto Naskh Arabic";color:var(--text);font-size:14px;font-weight:700}


/* ── Touches bleues en dark mode ── */
[data-theme="dark"] .hero{
  background:
    radial-gradient(900px 600px at 15% 60%, var(--blue-glow), transparent 55%),
    radial-gradient(700px 500px at 85% 20%, rgba(224,85,106,.07), transparent 50%),
    var(--navy);
}
[data-theme="dark"] .page-head{
  background: linear-gradient(135deg, rgba(30,40,120,.22) 0%, transparent 55%), var(--navy);
}
[data-theme="dark"] .explore{
  background: linear-gradient(160deg, var(--navy-2) 0%, rgba(20,28,100,.60) 100%);
}
[data-theme="dark"] .story{
  background: linear-gradient(200deg, rgba(20,28,100,.55) 0%, var(--navy-2) 60%);
}
[data-theme="dark"] .menu{
  background: linear-gradient(150deg, var(--navy-2) 30%, rgba(20,28,100,.50) 100%);
}
[data-theme="dark"] .events{
  background: linear-gradient(170deg, rgba(20,28,100,.50) 0%, var(--navy) 60%);
}
[data-theme="dark"] .order-page{
  background:linear-gradient(150deg, rgba(20,28,100,.55) 0%, var(--navy-2) 100%);
}
[data-theme="dark"] .order{
  background: linear-gradient(135deg, rgba(20,28,100,.55) 0%, var(--navy-2) 100%);
}
[data-theme="dark"] .contact{
  background: linear-gradient(190deg, var(--navy-2) 30%, rgba(20,28,100,.55) 100%);
}
[data-theme="dark"] footer{
  background: linear-gradient(160deg, rgba(20,28,100,.35) 0%, var(--navy-2) 100%);
}
[data-theme="dark"] .xcard:hover{
  border-color:rgba(80,100,255,.45);background:rgba(30,40,120,.20);
}
[data-theme="dark"] .xcard:hover .xcard__kanji{color:rgba(80,100,255,.18);}

[data-theme="dark"] .poster:hover{border-color:rgba(80,100,255,.35);}
[data-theme="dark"] .poster--navy .poster__cover{
  background:linear-gradient(135deg, rgba(30,40,140,.90) 0%, rgba(20,28,100,.70) 100%);
}
[data-theme="dark"] .value:hover{border-color:rgba(80,100,255,.30);}
[data-theme="dark"] .cinfo:hover{border-color:rgba(80,100,255,.35);background:rgba(30,40,120,.15);}
[data-theme="dark"] .mobile-menu{
  background:linear-gradient(160deg, rgba(20,28,100,.95) 0%, var(--navy) 100%);
}


/* ── Menu dark mode : filtres & catégories en bleu ── */
[data-theme="dark"] .menu__jump a:hover{border-color:rgba(80,100,255,.60);color:#fff;}
[data-theme="dark"] .menu__jump a.active{
  background:linear-gradient(135deg,#1e2878,#2030a0);
  border-color:rgba(80,100,255,.70);
  box-shadow:0 4px 18px rgba(30,40,180,.40);
  color:#fff;
}
[data-theme="dark"] .poster--red .poster__cover{
  background:linear-gradient(135deg,#1e2878 0%,#151a60 100%);
}

[data-theme="dark"] .tagchip.pop{
  background:rgba(30,40,180,.18);border-color:rgba(80,100,255,.35);color:#a0aaff;
}



/* ============ PROMO BAR ============ */
.promo-bar{
  position:fixed;
  top:var(--nav-h);left:0;right:0;
  z-index:48;
  background:linear-gradient(135deg,rgba(20,28,110,.97) 0%,rgba(11,12,22,.98) 100%);
  border-bottom:1px solid rgba(80,100,255,.30);
  padding:10px clamp(20px,4vw,56px);
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-size:13px;color:var(--ink);
  transition:transform .38s cubic-bezier(.7,0,.3,1);
  will-change:transform;
}
.promo-bar.dismissed{transform:translateY(-110%);}
.promo-bar__label{font-size:12px;letter-spacing:.08em;font-weight:300;opacity:.85;}
.promo-bar__code{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:15px;color:#fff;letter-spacing:.08em;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);
  border-radius:7px;padding:2px 10px;
}
.promo-bar__detail{font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.04em;}
.promo-bar__close{
  position:absolute;right:clamp(14px,3vw,40px);
  width:28px;height:28px;border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.50);font-size:13px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s,color .2s,border-color .2s;
  flex-shrink:0;
}
.promo-bar__close::after{
  content:"";position:absolute;inset:-8px;
  border-radius:50%;
}
.promo-bar__close:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.35);}
@media(max-width:560px){
  .promo-bar{gap:7px;padding:9px 44px 9px 14px;}
  .promo-bar__label{display:none;}
  .promo-bar__detail{display:block;color:rgba(255,255,255,.80);font-size:12px;}
}

/* ============ PROMO BANNER ============ */
.promo-banner{
  position:relative;overflow:hidden;
  border-radius:18px;padding:20px 28px;margin-bottom:18px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(30,40,120,.75) 0%,rgba(14,16,32,.90) 100%);
  border:1px solid rgba(80,100,255,.30);
}
[data-theme="dark"] .promo-banner{border-color:rgba(80,100,255,.40);}
.promo-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 200px at 20% 50%,rgba(80,100,255,.12),transparent 70%);
  pointer-events:none;
}
.promo-banner__label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.65);font-weight:700;flex-shrink:0;
}
.promo-banner__code{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(24px,4vw,36px);letter-spacing:.08em;color:#fff;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.25);
  border-radius:10px;padding:4px 16px;flex-shrink:0;
}
.promo-banner__detail{
  color:rgba(255,255,255,.60);font-size:13px;font-weight:300;line-height:1.5;
}

/* ── Hero promo pill ── */
.hero__promo{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 18px;border-radius:999px;
  background:rgba(255,182,193,.12);border:1px solid rgba(255,182,193,.30);
  font-size:13px;color:rgba(255,200,210,.90);letter-spacing:.02em;font-weight:400;
}
.hero__promo strong{color:#fff;font-weight:900;letter-spacing:.08em;}
[data-theme="dark"] .hero__promo{
  background:rgba(30,40,120,.25);border-color:rgba(80,100,255,.30);
  color:rgba(180,190,255,.90);
}
[data-theme="dark"] .hero__promo strong{color:#fff;}

/* ============ SIGNUP SECTION ============ */
.signup-section{
  position:relative;overflow:hidden;
  border-radius:28px;padding:44px 40px;
  background:linear-gradient(135deg,rgba(30,40,120,.70) 0%,var(--navy-2) 100%);
  border:1px solid rgba(80,100,255,.25);
  margin-top:14px;
}
[data-theme="dark"] .signup-section{border-color:rgba(80,100,255,.35);}
.signup-section::before{
  content:"友";position:absolute;right:-20px;top:-40px;
  font-family:"Noto Sans JP";font-weight:900;font-size:260px;line-height:1;
  color:rgba(255,255,255,.04);pointer-events:none;user-select:none;
}
[data-theme="dark"] .signup-section::before{color:rgba(80,100,255,.06);}
.signup-section__inner{
  display:grid;grid-template-columns:1fr 1.4fr;gap:40px;align-items:center;position:relative;
}
.signup-section__text h3{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(22px,3.2vw,32px);color:var(--text);line-height:1.05;margin-bottom:10px;
}
.signup-section__text p{
  color:var(--ink);font-size:14px;font-weight:300;line-height:1.65;
}
.signup-form{display:flex;flex-direction:column;gap:10px;}
.signup-form__fields{display:flex;flex-direction:column;gap:8px;}
.signup-form input{
  background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:13px 16px;color:var(--text);font-family:"Noto Sans JP";font-size:14px;
  transition:border-color .2s,background .2s;
}
[data-theme="dark"] .signup-form input{
  background:rgba(30,40,120,.20);border-color:rgba(80,100,255,.18);
}
.signup-form input::placeholder{color:rgba(255,255,255,.35);}
.signup-form input:focus{
  outline:none;border-color:rgba(255,255,255,.35);background:rgba(0,0,0,.30);
}
[data-theme="dark"] .signup-form input:focus{border-color:rgba(80,100,255,.50);}
.signup-form__note{
  font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.08em;margin-top:2px;
}
.btn--signup{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.28);
  color:#fff;padding:14px 24px;border-radius:999px;
  font-weight:700;font-size:13px;letter-spacing:.07em;text-transform:uppercase;
  transition:background .2s,border-color .2s,transform .15s;cursor:pointer;
  margin-top:4px;
}
.btn--signup:hover{background:rgba(255,255,255,.24);transform:translateY(-2px);}
[data-theme="dark"] .btn--signup{
  background:linear-gradient(135deg,#1e2878,#2030a0);
  border-color:rgba(80,100,255,.50);
}
[data-theme="dark"] .btn--signup:hover{border-color:rgba(80,100,255,.80);}
.btn--signup .arrow{transition:transform .25s;}
.btn--signup:hover .arrow{transform:translateX(4px);}

/* ============ FOOTER NEWSLETTER ============ */
.footer__newsletter{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding:22px 28px;border-radius:16px;margin-bottom:44px;
  background:var(--card-bg-2);border:1px solid var(--line);
}
[data-theme="dark"] .footer__newsletter{border-color:rgba(80,100,255,.20);}
.footer__newsletter__text{
  font-size:13px;color:var(--ink);font-weight:300;
}
.footer__newsletter__text strong{color:var(--text);font-weight:700;}
.newsletter-mini{display:flex;gap:8px;flex-wrap:wrap;}
.newsletter-mini input{
  background:var(--input-bg);border:1px solid var(--line);border-radius:10px;
  padding:10px 14px;color:var(--text);font-family:"Noto Sans JP";font-size:13px;
  width:200px;transition:border-color .2s;
}
.newsletter-mini input:focus{outline:none;border-color:var(--red);}
.newsletter-mini button{
  background:var(--red);color:#fff;border:none;border-radius:10px;
  padding:10px 16px;font-weight:700;font-size:13px;letter-spacing:.04em;cursor:pointer;
  transition:background .2s,transform .15s;white-space:nowrap;
}
.newsletter-mini button:hover{background:var(--red-2);transform:translateY(-1px);}
[data-theme="dark"] .newsletter-mini button{
  background:linear-gradient(135deg,#1e2878,#2030a0);
}
[data-theme="dark"] .newsletter-mini button:hover{opacity:.9;}

/* ============ SAKURA – EXPLORE SECTION ============ */
.explore{position:relative;overflow:hidden;}
.explore__sakura-wrap{
  position:relative;width:100%;margin-bottom:8px;overflow:visible;pointer-events:none;
}
.sakura-branch{
  width:100%;height:auto;overflow:visible;display:block;
  opacity:.7;
}
[data-theme="dark"] .sakura-branch{opacity:.55;}
.explore__sakura-petals{
  position:absolute;inset:0;pointer-events:none;overflow:visible;
}
.s-petal{
  position:absolute;border-radius:50% 0 50% 0;
  background:linear-gradient(135deg,#ffb6c8,#ffd0de);
  opacity:0;
  animation:sakuraFloat 12s ease-in-out infinite;
  transform-origin:center;
}
@keyframes sakuraFloat{
  0%{opacity:0;transform:translateY(-10px) rotate(0deg);}
  15%{opacity:.55;}
  85%{opacity:.45;}
  100%{opacity:0;transform:translateY(60px) rotate(180deg);}
}
/* Responsive */
@media(max-width:700px){
  .signup-section__inner{grid-template-columns:1fr;}
  .signup-section{padding:28px 22px;}
  .footer__newsletter{flex-direction:column;align-items:flex-start;gap:14px;}
  .newsletter-mini input{width:100%;}
  .newsletter-mini{width:100%;}
  .newsletter-mini button{width:100%;}
}


/* ============ EMAIL SHIELD ============ */
.email-shield{
  display:inline-flex;align-items:center;gap:10px;
  cursor:pointer;text-decoration:none;
  border-bottom:1px dashed rgba(255,255,255,.25);
  padding-bottom:2px;
  transition:border-color .2s;
}
.email-shield:hover{border-color:var(--red);}
.email-shield__blur{
  font-family:"Noto Sans JP";font-weight:900;font-size:inherit;
  color:var(--text);letter-spacing:.01em;
  filter:blur(5px);transition:filter .35s ease;
  user-select:none;pointer-events:none;
}
.email-shield.revealed .email-shield__blur{
  filter:none;user-select:text;
}
.email-shield__cta{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:700;white-space:nowrap;
  transition:opacity .3s;flex-shrink:0;
}
.email-shield.revealed .email-shield__cta{
  opacity:0;width:0;overflow:hidden;
}




.food-visual{
  padding:0 clamp(20px,5vw,80px);
  background:var(--navy-2);
}
.food-visual__grid{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:3px;border-radius:24px;overflow:hidden;
}
.fkanji{
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:44px 16px 28px;
  background:var(--card-bg);
  transition:background .35s;
  cursor:default;overflow:hidden;position:relative;
}
.fkanji:hover{background:var(--card-bg-2);}

/* Le kanji devient une fenêtre transparente sur la photo du plat */
.fkanji__char{
  font-family:"Noto Sans JP";font-weight:900;
  font-size:clamp(110px,14vw,200px);line-height:1;
  background-image:var(--img), linear-gradient(135deg,#1e2878,#0e1020);
  background-size:170% auto, 100% 100%;
  background-position:center,center;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  transition:background-size .55s cubic-bezier(.2,.7,.2,1);
  user-select:none;display:block;
}
.fkanji:hover .fkanji__char{
  background-size:220% auto, 100% 100%;
}

.fkanji__label{
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--muted);font-weight:700;margin-top:14px;
  transition:color .3s;
}
.fkanji:hover .fkanji__label{color:var(--ink);}

@media(max-width:600px){
  .food-visual__grid{grid-template-columns:repeat(2,1fr);}
  .fkanji{padding:32px 12px 20px;}
}


/* ── Événements : icônes kanji / photo ── */
.ecard__kanji{
  font-family:"Noto Sans JP";font-weight:900;font-size:68px;line-height:1;
  background-image:var(--img), linear-gradient(135deg,#1e2878,#0e1020);
  background-size:165% auto, 100% 100%;
  background-position:center,center;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  display:block;margin-bottom:14px;
  transition:background-size .5s ease;user-select:none;
}
.ecard:hover .ecard__kanji{background-size:215% auto, 100% 100%;}


/* ── Lightbox plats ── */
.dish-lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(11,12,22,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.dish-lightbox.open{opacity:1;pointer-events:all;}
.dish-lightbox__img{
  max-width:min(480px,88vw);max-height:72vh;
  border-radius:22px;object-fit:cover;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
  animation:lbIn .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes lbIn{from{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}
.dish-lightbox__caption{
  margin-top:18px;font-family:"Noto Sans JP";font-weight:700;
  font-size:15px;color:rgba(255,255,255,.80);text-align:center;
}
.dish-lightbox__close{
  position:absolute;top:22px;right:22px;
  width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(255,255,255,.25);
  color:#fff;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s;
}
.dish-lightbox__close:hover{background:rgba(255,255,255,.15);}


/* ── Statut ouvert/fermé dans le nav (mobile) ── */
.nav__status{
  display:none;align-items:center;gap:7px;
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);margin-right:10px;flex-shrink:0;
  line-height:1.3;
}
.nav__status-dot{
  width:7px;height:7px;border-radius:50%;
  background:#1fbf6f;flex-shrink:0;align-self:flex-start;margin-top:3px;
}
@media(max-width:900px){
  .nav__status{display:flex;}
}


/* ============ SECTION AVIS ============ */
.section-avis{
  padding:clamp(80px,10vw,140px) clamp(20px,5vw,80px);
  background:linear-gradient(180deg, var(--navy-2) 0%, rgba(20,28,100,.28) 100%);
  text-align:center;
  position:relative;
}
.label-section{
  font-size:11px;letter-spacing:.30em;text-transform:uppercase;
  font-weight:700;color:var(--red);margin-bottom:16px;
  display:flex;align-items:center;justify-content:center;gap:12px;
}
.label-section::before,.label-section::after{
  content:"";width:32px;height:2px;background:var(--red);
}
.section-avis h2{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(36px,5vw,64px);line-height:1.02;
  color:var(--text);margin-bottom:52px;
}
.section-avis h2 .accent{color:var(--red);}

.avis-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;max-width:1100px;margin:0 auto 44px;
}
.avis-card{
  background:var(--card-bg-2);
  border:1px solid rgba(224,85,106,.22);
  border-radius:20px;padding:28px 26px;
  text-align:left;
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .3s,transform .3s,background .3s;
  position:relative;overflow:hidden;
}
.avis-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--red),rgba(224,85,106,.3));
  border-radius:20px 20px 0 0;
}
.avis-card:hover{
  border-color:rgba(224,85,106,.50);
  transform:translateY(-4px);
  background:var(--card-bg-3);
}
.stars{color:var(--red);font-size:16px;letter-spacing:2px;}
.avis-card blockquote{
  font-size:14px;line-height:1.72;color:var(--ink);
  font-weight:300;font-style:italic;flex:1;
  quotes:none;
}
.avis-card cite{
  font-size:12px;font-weight:700;letter-spacing:.08em;
  color:var(--muted);font-style:normal;
}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid var(--line);border-radius:999px;
  padding:14px 26px;font-size:13px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);
  transition:border-color .2s,color .2s,background .2s;
}
.btn-secondary:hover{border-color:var(--red);color:var(--text);background:var(--card-bg);}

@media(max-width:900px){
  .avis-grid{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .avis-grid{grid-template-columns:1fr;}
  .section-avis{text-align:left;}
  .label-section{justify-content:flex-start;}
  .label-section::before{display:none;}
}


/* ============ FORMULAIRE DEVIS (événements) ============ */
.form-devis{
  position:relative;overflow:hidden;
  border-radius:22px;
  background:linear-gradient(135deg,rgba(30,40,120,.70) 0%,var(--navy-2) 100%);
  border:1px solid rgba(80,100,255,.22);
  padding:32px 30px;
}
[data-theme="dark"] .form-devis{
  background:linear-gradient(135deg,rgba(30,40,140,.82) 0%,rgba(14,16,32,.96) 100%);
  border-color:rgba(80,100,255,.32);
}
[data-theme="light"] .form-devis{
  background:linear-gradient(135deg,#dde1ff 0%,#f4f5ff 100%);
  border-color:rgba(15,19,64,.16);
}
.form-devis h3{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(22px,2.8vw,28px);color:var(--text);
  margin-bottom:6px;
}
.form-note{
  color:var(--ink);font-size:13px;font-weight:300;line-height:1.6;margin-bottom:22px;
}
.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;
}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;}
.form-group label{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.form-group input,
.form-group select,
.form-group textarea{
  background:rgba(0,0,0,.20);border:1px solid rgba(255,255,255,.12);
  border-radius:10px;padding:11px 14px;
  color:var(--text);font-family:"Noto Sans JP";font-size:13px;
  transition:border-color .2s,background .2s;outline:none;
}
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea{
  background:rgba(15,19,64,.06);border-color:rgba(15,19,64,.14);
}
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea{
  background:rgba(30,40,120,.20);border-color:rgba(80,100,255,.18);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:rgba(255,255,255,.38);background:rgba(0,0,0,.28);
}
[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus{
  border-color:rgba(80,100,255,.55);
}
[data-theme="light"] .form-group input:focus,
[data-theme="light"] .form-group select:focus,
[data-theme="light"] .form-group textarea:focus{
  border-color:rgba(15,19,64,.38);background:rgba(15,19,64,.09);
}
.form-group input[type="date"]{color-scheme:dark;}
[data-theme="light"] .form-group input[type="date"]{color-scheme:light;}
.form-group textarea{resize:vertical;min-height:100px;}
.btn-primary{
  width:100%;margin-top:6px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.26);
  color:#fff;padding:14px 22px;border-radius:999px;
  font-weight:700;font-size:13px;letter-spacing:.07em;text-transform:uppercase;
  cursor:pointer;transition:background .2s,border-color .2s,transform .15s;
  font-family:"Noto Sans JP";
}
.btn-primary:hover{background:rgba(255,255,255,.22);transform:translateY(-2px);}
[data-theme="light"] .btn-primary{
  background:rgba(15,19,64,.85);border-color:rgba(15,19,64,.90);color:#fff;
}
[data-theme="light"] .btn-primary:hover{background:#0f1340;}
[data-theme="dark"] .btn-primary{
  background:linear-gradient(135deg,#1e2878,#2030a0);
  border-color:rgba(80,100,255,.50);
}
[data-theme="dark"] .btn-primary:hover{border-color:rgba(80,100,255,.80);}

@media(max-width:600px){
  .form-row{grid-template-columns:1fr;}
  .form-devis{padding:24px 20px;}
}


/* ============ HERO BANNER — 4 carrés ============ */
.hero__banner{
  position:relative;margin:0;
  width:100%;max-width:460px;
  transform:rotate(-2deg);
  transition:transform .4s ease;
  filter:drop-shadow(0 16px 40px rgba(0,0,0,.45));
}
.hero__banner:hover{transform:rotate(0deg);}

.hero__banner-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:6px;border-radius:18px;overflow:hidden;
}
.hero__banner-cell{
  position:relative;aspect-ratio:1/1;overflow:hidden;
  background-image:url('assets/HALASHI_Banner.jpg');
  background-size:200% 200%;
  background-position:var(--bx) var(--by);
  transition:transform .4s ease;
}
.hero__banner-cell:hover{transform:scale(1.03);}
.hero__banner-cell:first-child{border-radius:12px 0 0 0;}
.hero__banner-cell:nth-child(2){border-radius:0 12px 0 0;}
.hero__banner-cell:nth-child(3){border-radius:0 0 0 12px;}
.hero__banner-cell:last-child{border-radius:0 0 12px 0;}

.hero__banner-kanji{
  position:absolute;bottom:8px;left:10px;
  font-family:"Noto Sans JP";font-weight:900;
  font-size:clamp(28px,3.5vw,42px);line-height:1;
  color:rgba(255,255,255,.85);
  text-shadow:0 2px 8px rgba(0,0,0,.60);
  pointer-events:none;user-select:none;
}

.hero__banner-img-hidden{
  position:absolute;width:1px;height:1px;
  opacity:0;pointer-events:none;
}

.hero__wordmark{
  font-family:"Potta One",system-ui,sans-serif;
  font-size:clamp(32px,4.5vw,52px);
  letter-spacing:.06em;line-height:1;
  color:var(--text);margin-top:18px;text-align:center;
}
.hero__wordmark .accent{color:var(--red);}

/* Mobile : image visible, réduite, sans rotation */
@media(max-width:900px){
  .hero__banner{
    max-width:100%;transform:none;
    display:none;
  }
}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px){
  .explore__grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1.4fr 1fr 1fr;gap:30px}
}
@media (max-width: 900px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  /* Masquer le logo HALASHI sur mobile */
  .hero__left{display:none}
  .hero{min-height:0;padding-top:calc(var(--nav-h) + var(--promo-h,0px) + 48px);padding-bottom:52px}
  .hero__inner{grid-template-columns:1fr;gap:24px;text-align:center}
  .hero__right{align-items:center;text-align:center}
  .hero__cta{justify-content:center}
  .story__grid{grid-template-columns:1fr;gap:40px}
  .events__grid{grid-template-columns:1fr;gap:40px}
  .order__hero{grid-template-columns:1fr;gap:40px}
  .steps{grid-template-columns:1fr;gap:14px}
  .delivery{grid-template-columns:1fr;gap:14px}
  .contact__grid{grid-template-columns:1fr;gap:40px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:560px){
  .pulse{display:none}
  .hero__headline{font-size:36px}
  .events__cards{grid-template-columns:1fr}
  .explore__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .menu__head{flex-direction:column;align-items:flex-start}
  .form__row{grid-template-columns:1fr}
  .hero__meta{display:none}
  .story::before,.events::before,.contact::before{display:none}
  .value{grid-template-columns:auto 1fr;gap:14px;padding:18px 20px}
  .value__num{font-size:48px}
  .btn{padding:14px 22px;font-size:13px}
  section{padding:80px 20px}
  .page-head{padding-top:calc(var(--nav-h) + 60px)}
}
