:root{
  --bg:#2b2340;
  --bg-deep:#241d35;
  --panel:#403351;
  --primary:#9e69ee;
  --accent:#3ffeca;
  --text:#ffffff;
  --muted:#b3a9c6;
  --line:rgba(255,255,255,.10);
  --dur:.5s;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:"Source Sans 3",system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.6;overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.muted{color:var(--muted)}
h1,h2,h3,.display{font-family:"Montserrat",sans-serif;font-weight:800;letter-spacing:.005em;text-transform:uppercase}

#scroller{height:100svh;overflow-y:auto;overflow-x:hidden;scroll-snap-type:y mandatory;scroll-behavior:smooth}
.snap{height:100svh;scroll-snap-align:start;position:relative;overflow:hidden}

/* Loader */
#loader{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:20px;background:var(--bg-deep);transition:opacity .7s ease}
#loader.hide{opacity:0;pointer-events:none}
#loader span{font-family:"Montserrat";font-weight:800;letter-spacing:.42em;font-size:13px;color:var(--muted);padding-left:.42em}
#loader .ring{width:44px;height:44px;border-radius:50%;border:3px solid rgba(158,105,238,.22);border-top-color:var(--primary);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Header */
#header{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(20px,5vw,52px);pointer-events:none}
#header *{pointer-events:auto}
.hbrand{display:flex;align-items:center;gap:12px;font-family:"Montserrat";font-weight:800;letter-spacing:.22em;font-size:17px;text-transform:uppercase}
.hbrand img{width:32px;height:32px;object-fit:contain}
.lang-switch{display:flex;align-items:center;gap:7px;font-family:"Montserrat";font-weight:700;font-size:13px}
.lang-switch button{background:none;border:0;color:var(--muted);cursor:pointer;font:inherit;padding:6px;letter-spacing:.05em;transition:color .3s}
.lang-switch button.active{color:var(--primary)}
.lang-switch button:hover{color:var(--text)}
.lang-switch button:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}
.lang-switch .sep{color:#5a4f70}
.skip{position:fixed;left:-999px;top:10px;z-index:100;background:var(--primary);color:#fff;padding:10px 16px;border-radius:6px;font-weight:700}
.skip:focus{left:14px}

/* Side index */
#sidedex{position:fixed;right:clamp(14px,2.4vw,34px);top:50%;transform:translateY(-50%);z-index:55;
  display:flex;flex-direction:column;gap:11px;max-height:78vh}
#sidedex a{display:flex;align-items:center;gap:10px;justify-content:flex-end;color:var(--muted);font-size:11px;
  font-family:"Montserrat";font-weight:700;letter-spacing:.06em;opacity:.5;transition:opacity .3s,color .3s}
#sidedex a .dot{width:20px;height:3px;background:currentColor;transition:width .3s,background .3s}
#sidedex a .nm{display:none;text-transform:uppercase}
#sidedex a:hover{opacity:1;color:var(--text)}
#sidedex a:hover .nm{display:block}
#sidedex a.active{opacity:1;color:var(--brand,var(--primary))}
#sidedex a.active .dot{width:42px}
#sidedex a.active .nm{display:block}

/* Intro */
.intro-bg{position:absolute;inset:0;background:
  radial-gradient(ellipse 72% 62% at 50% 42%,#3a2d56 0%,#2b2340 55%,#241d35 100%)}
.intro-bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 45%,transparent 0,transparent 36%,rgba(36,29,53,.72) 76%)}
.logo-field{position:absolute;inset:0;z-index:2}
.chip{position:absolute;top:50%;left:50%;width:clamp(96px,12vw,150px);aspect-ratio:16/10;
  background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:12px;
  box-shadow:0 18px 44px -16px rgba(0,0,0,.75);cursor:pointer;
  transform:translate(-50%,-50%) scale(.35);opacity:0;
  transition:transform 1.05s var(--ease),opacity .8s ease,box-shadow .35s ease;will-change:transform}
.chip img{max-width:100%;max-height:100%;object-fit:contain}
.chip:hover{box-shadow:0 26px 56px -14px rgba(158,105,238,.7);z-index:9}
.intro.in .chip{opacity:1}
.intro-copy{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);z-index:5;text-align:center;
  padding:0 24px;pointer-events:none;opacity:0;transition:opacity 1s ease .7s}
.intro.in .intro-copy{opacity:1}
.intro-copy h1{font-size:clamp(3rem,12vw,9rem);font-weight:800;letter-spacing:.02em;line-height:.92;
  text-shadow:0 12px 54px rgba(0,0,0,.75)}
.intro-copy h1.brandmark{margin:0 auto;line-height:0}
.intro-copy h1.brandmark img{width:clamp(170px,26vw,360px);height:auto;margin:0 auto;
  filter:drop-shadow(0 24px 60px rgba(158,105,238,.45)) drop-shadow(0 6px 22px rgba(0,0,0,.55))}
.eyebrow{color:var(--accent);font-family:"Montserrat";font-weight:700;letter-spacing:.28em;text-transform:uppercase;font-size:clamp(.66rem,1.4vw,.82rem);margin-bottom:18px}
.intro-copy .sub{color:var(--muted);font-size:clamp(.95rem,1.7vw,1.15rem);font-weight:600;margin-top:18px;max-width:560px;margin-inline:auto}
.scroll-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:6;display:flex;
  flex-direction:column;align-items:center;gap:12px;color:var(--muted);font-family:"Montserrat";font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:700;opacity:0;transition:opacity 1s ease 1.2s}
.intro.in .scroll-cue{opacity:1}
.scroll-cue>span{width:24px;height:38px;border:2px solid rgba(255,255,255,.28);border-radius:13px;position:relative}
.scroll-cue>span::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;background:var(--accent);
  border-radius:2px;transform:translateX(-50%);animation:cue 1.6s ease-in-out infinite}
@keyframes cue{0%{opacity:0;top:7px}40%{opacity:1}100%{opacity:0;top:18px}}

/* Brand section */
.brand{display:grid;grid-template-columns:1.05fr 1fr;align-items:center;
  background:
   linear-gradient(180deg,rgba(36,29,53,.4),rgba(36,29,53,.4)),
   radial-gradient(ellipse 90% 92% at 16% 50%,color-mix(in srgb,var(--brand) 34%,#2b2340) 0%,#2b2340 62%)}
.brand .visual{position:relative;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.brand .visual::before{content:"";position:absolute;width:122%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--brand) 60%,transparent) 0%,transparent 60%);filter:blur(8px)}
.brand .panel{position:relative;width:min(70%,560px);aspect-ratio:16/10;background:#fff;border-radius:18px;
  display:flex;align-items:center;justify-content:center;padding:clamp(28px,4vw,60px);
  box-shadow:0 50px 92px -38px rgba(0,0,0,.9);transform:translateY(42px) scale(.94);opacity:0;
  transition:transform 1s var(--ease),opacity .8s ease}
.brand.show .panel{transform:none;opacity:1}
.brand .panel img{max-width:100%;max-height:100%;object-fit:contain}
.brand .info{padding:clamp(28px,6vw,90px) clamp(24px,7vw,110px) clamp(28px,6vw,90px) clamp(20px,3vw,40px);max-width:660px}
.brand .num{font-family:"Montserrat";font-weight:700;font-size:clamp(.78rem,1.5vw,.92rem);letter-spacing:.24em;color:var(--brand)}
.brand h2{font-size:clamp(2.4rem,6.2vw,5.2rem);font-weight:800;line-height:.98;margin:14px 0 8px}
.brand .cuisine{font-family:"Montserrat";font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);font-size:clamp(.78rem,1.5vw,.95rem)}
.brand .flag{display:inline-flex;align-items:center;gap:7px;margin-left:12px;vertical-align:middle}
.brand .cf{width:24px;height:18px;object-fit:cover;border-radius:3px;
  box-shadow:0 0 0 1px rgba(255,255,255,.22);display:block}
.brand .desc{margin:26px 0;color:#e3def0;font-size:clamp(.98rem,1.5vw,1.14rem)}
.brand .dishes{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:36px;list-style:none}
.brand .dishes li{font-size:.82rem;font-weight:600;color:var(--text);background:rgba(255,255,255,.07);
  border:1px solid var(--line);padding:7px 14px;border-radius:999px}
.brand .cta{display:inline-flex;align-items:center;gap:11px;font-family:"Montserrat";font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;font-size:.84rem;padding:17px 34px;border-radius:8px;
  background:var(--brand);color:#fff;transition:transform .25s var(--ease),filter .25s,box-shadow .25s}
.brand .cta:hover{transform:translateY(-3px);filter:brightness(1.08);box-shadow:0 16px 34px -14px var(--brand)}
.brand .cta.disabled{background:rgba(255,255,255,.07);color:var(--muted);border:1px solid var(--line);cursor:default}
.brand .cta svg{width:16px;height:16px}
.brand .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s var(--ease)}
.brand.show .reveal{opacity:1;transform:none}
.brand.show .reveal:nth-child(2){transition-delay:.08s}
.brand.show .reveal:nth-child(3){transition-delay:.16s}
.brand.show .reveal:nth-child(4){transition-delay:.24s}
.brand.show .reveal:nth-child(5){transition-delay:.32s}
.brand.show .reveal:nth-child(6){transition-delay:.4s}

/* End */
.end{display:flex;align-items:center;background:var(--bg-deep);border-top:1px solid var(--line)}
.end .wrap{max-width:880px;margin:0 auto;padding:0 clamp(22px,6vw,48px)}
.kicker{color:var(--accent);font-family:"Montserrat";font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.74rem;margin-bottom:12px}
.end h2{font-size:clamp(1.8rem,4.6vw,3.1rem);font-weight:800;line-height:1.08}
.lead{margin:20px 0 38px;color:var(--muted);font-size:clamp(1rem,1.7vw,1.16rem)}
.company{display:grid;grid-template-columns:1fr 1fr;gap:34px;border-top:1px solid var(--line);padding-top:30px}
.company h3{font-family:"Montserrat";font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:13px}
.company p{font-size:.98rem}
.company a{border-bottom:1px solid var(--primary)}
.foot{margin-top:34px;font-size:.8rem}

.fallback-note{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--muted)}

@media (max-width:880px){
  /* normal document scroll — no snap/clipping (fixes off-screen CTA) */
  html,body{overflow-x:hidden;overflow-y:auto;height:auto}
  #scroller{height:auto;overflow:visible;scroll-snap-type:none;scroll-behavior:smooth}
  .snap{height:auto;min-height:100svh;overflow:visible;scroll-snap-align:none}
  #sidedex{display:none}

  /* Intro: tidy stacked layout, chips in a clean wrap grid (no overlap) */
  .intro{display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:104px 18px 64px;text-align:center}
  .intro-bg{position:absolute;inset:0}
  .intro-copy{position:static;transform:none;order:1;opacity:1}
  .intro-copy h1.brandmark img{width:clamp(150px,50vw,220px)}
  .logo-field{position:static;order:2;display:flex;flex-wrap:wrap;justify-content:center;
    gap:10px;margin-top:28px;max-width:540px}
  .chip{position:static!important;top:auto!important;left:auto!important;transform:none!important;
    opacity:1!important;width:clamp(82px,26vw,108px);transition:box-shadow .3s ease}
  .scroll-cue{position:static;order:3;transform:none;margin-top:30px}

  /* Brand sections: stacked, content flows, CTA always visible */
  .brand{grid-template-columns:1fr;align-items:stretch}
  .brand .visual{height:auto;min-height:0;padding:104px 20px 4px}
  .brand .visual::before{width:78%}
  .brand .panel{width:min(82%,400px);transform:none!important;opacity:1!important}
  .brand .info{padding:22px clamp(20px,7vw,34px) 72px;max-width:none;display:block}
  .brand .reveal{opacity:1!important;transform:none!important}
  .brand h2{font-size:clamp(2rem,9vw,3rem)}
  .brand .cta{width:100%;justify-content:center}

  .end{height:auto;min-height:100svh;display:block;padding:104px 0 72px}
  .company{grid-template-columns:1fr;gap:24px}
}
@media (prefers-reduced-motion:reduce){
  #scroller{scroll-snap-type:none;scroll-behavior:auto}
  .chip,.intro-copy,.scroll-cue,.brand .panel,.brand .reveal{transition:none!important;opacity:1!important;transform:none!important}
  #loader .ring,.scroll-cue>span::after{animation:none}
  .chip{position:relative;display:inline-flex;margin:8px;transform:none;top:auto;left:auto}
  .logo-field{position:relative;display:flex;flex-wrap:wrap;justify-content:center;align-content:center;padding:90px 20px 40px}
}
