/* ============================================================
   Non-Stop — global styles & design tokens
   ============================================================ */
:root {
  /* Parent neutral shell — warm near-black + warm white */
  --ink: #0E0D0B;
  --ink-soft: #1A1815;
  --ink-2: #26221d;
  --paper: #F7F5F0;
  --paper-dim: #ECE8DF;
  --muted: #8C857A;
  --line: rgba(247,245,240,0.12);
  --line-dark: rgba(14,13,11,0.12);

  --fz-display: "Anton", "Arial Narrow", sans-serif;
  --fz-body: "Hanken Grotesk", system-ui, sans-serif;
  --fz-mono: "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1240px;
  --pad: clamp(18px, 5vw, 64px);
  --radius: 4px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
/* ankrule kerides jäta fikseeritud menüü jagu ruumi */
[id] { scroll-margin-top: 76px; }
body {
  margin: 0;
  font-family: var(--fz-body);
  background: var(--ink);
  color: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
img { display: block; max-width: 100%; }

/* logo fill follows currentColor */
.ns-logo svg { height: 100%; width: auto; display: block; }
.ns-logo svg .cls-1, .ns-logo svg .cls-2 { fill: currentColor; }

/* ---- typographic helpers ---- */
.display {
  font-family: var(--fz-display);
  font-weight: 400;
  line-height: 0.86;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.kicker {
  font-family: var(--fz-mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
}
.wrap { max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--fz-mono); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em; font-size: 13px;
  padding: 14px 20px; border-radius: 999px;
  background: var(--paper); color: var(--ink);
  transition: transform .18s cubic-bezier(.2,.8,.2,1), background .18s, color .18s, box-shadow .18s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn .wolt-dot { width: 8px; height: 8px; border-radius: 50%; background: #00C2E8; }
.btn.btn-dark { background: var(--ink); color: var(--paper); }
.btn.btn-outline { background: transparent; color: var(--paper); box-shadow: inset 0 0 0 1.5px currentColor; }

/* ---- nav ---- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px var(--pad);
  transition: background .3s, box-shadow .3s, padding .3s;
}
.nav.scrolled { background: rgba(14,13,11,0.82); backdrop-filter: blur(14px); box-shadow: 0 1px 0 var(--line); padding-top: 10px; padding-bottom: 10px; }
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a { font-family: var(--fz-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--paper); opacity: .72; transition: opacity .2s; }
.nav-links a:hover { opacity: 1; }
.nav-links a.nav-cta {
  opacity: 1; color: #fff; background: #E2231A; padding: 7px 15px; border-radius: 999px;
  box-shadow: 0 6px 18px -6px rgba(226,35,26,0.7);
  transition: background .2s, box-shadow .2s, transform .18s;
}
.nav-links a.nav-cta:hover { background: #f5362c; transform: translateY(-1px); box-shadow: 0 8px 22px -6px rgba(226,35,26,0.85); }
.nav-right { display: flex; align-items: center; gap: 14px; }
.lang {
  display: inline-flex; font-family: var(--fz-mono); font-size: 11px; font-weight: 700;
  border-radius: 999px; overflow: hidden; box-shadow: inset 0 0 0 1.5px var(--line);
}
.lang button { padding: 7px 11px; letter-spacing: .1em; opacity: .55; transition: .18s; display: inline-flex; align-items: center; gap: 5px; }
.lang button.on { background: var(--paper); color: var(--ink); opacity: 1; }
.lang-flag { font-size: 13px; line-height: 1; }
.nav-toggle { display: none; }

/* ---- generic section ---- */
.section { padding: clamp(64px, 9vw, 120px) 0; position: relative; }
.sec-head { display: flex; flex-direction: column; gap: 14px; margin-bottom: clamp(34px, 5vw, 64px); }
.sec-title { font-size: clamp(40px, 7vw, 92px); line-height: 0.98; }

/* ---- photo placeholder ---- */
.ph {
  position: relative; overflow: hidden; border-radius: var(--radius);
  background:
    repeating-linear-gradient(135deg, transparent 0 15px, rgba(255,255,255,0.05) 15px 17px),
    var(--ph-bg, #2a2620);
  display: flex; align-items: center; justify-content: center; text-align: center;
}
.ph::after {
  content: "▤  " attr(data-label);
  font-family: var(--fz-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ph-fg, rgba(255,255,255,0.62));
  padding: 10px 14px; border: 1px solid currentColor; border-radius: 999px; opacity: .85;
}
.ph-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ph:has(.ph-img)::after { display: none; }

/* scroll snap for brand sections */
.snap-host { }
.no-scrollbar { scrollbar-width: none; -ms-overflow-style: none; }
.no-scrollbar::-webkit-scrollbar { display: none; }

@media (max-width: 860px) {
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
}

/* ---- hero ---- */
.hero-photo { position: absolute; inset: 0; z-index: 0; }
.hero-carousel { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.6s ease-in-out; }
.hero-slide.on { opacity: 1; }
.hero-slide img { width: 100%; height: 100%; object-fit: cover; object-position: center; transform: scale(1.02); transition: transform 6s ease-out; }
.hero-slide.on img { transform: scale(1.13); }
.hero-dots { position: absolute; right: clamp(18px, 5vw, 64px); bottom: 26px; z-index: 3; display: flex; gap: 9px; }
.hero-dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(247,245,240,0.32); transition: background .25s, transform .25s, width .25s; padding: 0; }
.hero-dot.on { background: var(--paper); width: 26px; border-radius: 999px; }
.hero-dot:hover { background: rgba(247,245,240,0.6); }
.hero-content { position: relative; z-index: 2; width: 100%; flex: 1; display: flex; flex-direction: column; justify-content: space-between; gap: 40px; padding-top: clamp(112px, 16vh, 172px); padding-bottom: clamp(30px, 5vh, 60px); }
.hero-bottom { display: flex; flex-direction: column; gap: clamp(22px, 3.4vw, 38px); max-width: 1000px; }
.hero-actions { display: flex; gap: 26px; flex-wrap: wrap; align-items: center; }

/* ---- hero sport-badge CTA ---- */
.cta-badge {
  position: relative; display: inline-flex; align-items: stretch; gap: 0;
  background: #FFD400; color: #0c0c0c; border-radius: 13px;
  box-shadow: 0 0 0 3px #0c0c0c, 0 0 0 6px #FFD400, 0 0 0 8px rgba(12,12,11,0.92), 0 16px 34px -12px rgba(0,0,0,0.6);
  padding-left: 22px; overflow: hidden;
  transition: transform .16s cubic-bezier(.2,.8,.2,1);
}
.cta-badge:hover { transform: translateY(-2px) rotate(-0.6deg); }
.cta-badge:active { transform: translateY(0); }
.cta-badge-text {
  font-family: var(--fz-display); font-style: italic; font-size: 27px; letter-spacing: .01em;
  text-transform: uppercase; padding: 13px 16px 13px 0; line-height: 1; white-space: nowrap; align-self: center;
}
.cta-badge-arrow {
  display: flex; align-items: center; justify-content: center;
  background: #0c0c0c; color: #FFD400; font-size: 25px; font-weight: 700; padding: 0 19px;
  letter-spacing: -2px; transition: padding .16s;
}
.cta-badge:hover .cta-badge-arrow { padding: 0 15px 0 23px; }
/* secondary badge — dark body, yellow accents, same silhouette */
.cta-badge-alt {
  background: #1a1714; color: var(--paper);
  box-shadow: 0 0 0 3px #FFD400, 0 0 0 6px #1a1714, 0 0 0 8px rgba(255,212,0,0.5), 0 16px 34px -12px rgba(0,0,0,0.6);
}
.cta-badge-alt .cta-badge-text { color: var(--paper); font-style: italic; }
.cta-badge-alt .cta-badge-arrow { background: #FFD400; color: #0c0c0c; }
/* klubi-badge — punane, ainult telefonis (desktopil on Liitu kliendiks navis) */
.cta-badge-join {
  display: none;
  background: #E2231A; color: #fff;
  box-shadow: 0 0 0 3px #0c0c0c, 0 0 0 6px #E2231A, 0 0 0 8px rgba(12,12,11,0.92), 0 16px 34px -12px rgba(0,0,0,0.6);
}
.cta-badge-join .cta-badge-text { color: #fff; }
.cta-badge-join .cta-badge-arrow { background: #0c0c0c; color: #E2231A; }
/* sama » glüüf, pööratud alla */
.cta-badge-join .arr-down { display: inline-block; transform: rotate(90deg); transition: transform .16s; }
/* hover: liigub alla (mitte üles) ja nool nihkub allapoole (mitte paremale) */
.cta-badge-join:hover { transform: translateY(2px) rotate(0.6deg); }
.cta-badge-join:hover .cta-badge-arrow { padding: 0 19px; }
.cta-badge-join:hover .arr-down { transform: rotate(90deg) translateX(4px); }
/* sticky bar uses the badge full-width */
.sticky-badge { width: 100%; }
.sticky-badge .cta-badge-text { flex: 1; }
.cta-ghost {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--fz-mono); font-weight: 700; font-size: 13px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--paper); padding: 17px 26px; border-radius: 999px;
  box-shadow: inset 0 0 0 2px rgba(247,245,240,0.6);
  transition: transform .16s, box-shadow .16s, background .16s;
}
.cta-ghost:hover { transform: translateY(-2px); box-shadow: inset 0 0 0 2px var(--paper); background: rgba(247,245,240,0.06); }
.hero-photo-veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(14,13,11,0.96) 0%, rgba(14,13,11,0.78) 38%, rgba(14,13,11,0.32) 70%, rgba(14,13,11,0.55) 100%),
    linear-gradient(0deg, rgba(14,13,11,0.85) 0%, transparent 40%);
}
.hero-h1 { font-size: clamp(56px, 13vw, 144px); line-height: 0.9; }
.hero-line { transform: none; }
.hero-sub { }

@media (prefers-reduced-motion: no-preference) {
  .hero-line { animation: ns-rise .9s cubic-bezier(.16,1,.3,1) backwards; }
  .hero-sub { animation: ns-rise .9s .3s cubic-bezier(.16,1,.3,1) backwards; }
}

@keyframes ns-rise { from { transform: translateY(0.2em); } to { transform: translateY(0); } }
@keyframes ns-marquee { from { transform: translateX(0); } to { transform: translateX(-33.333%); } }
@keyframes ns-kenburns { from { transform: scale(1.05); } to { transform: scale(1.16) translate(-2%, -1%); } }

/* ---- brand logo ticker ---- */
.ticker-item { display: inline-flex; align-items: center; padding: 0 38px; border-right: 1px solid var(--line); height: 56px; }
.brand-logo { user-select: none; -webkit-user-drag: none; }

/* ---- sticky mobile CTA ---- */
.sticky-via { font-family: var(--fz-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; font-size: 13px; opacity: .55; }
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 55;
  padding: 12px var(--pad) calc(12px + env(safe-area-inset-bottom));
  background: linear-gradient(0deg, var(--ink) 60%, transparent);
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
  display: none;
}
@media (max-width: 860px) {
  .nav-order-desktop { display: none; }
  .sticky-cta { display: block; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slide img { transition: none !important; transform: none !important; }
  .hero-slide.on img, .hero-line, .hero-sub { animation: none !important; opacity: 1 !important; transform: none !important; }
}

/* ---- brand selector ---- */
.brand-detail { animation: ns-detail .45s cubic-bezier(.16,1,.3,1); }
@keyframes ns-detail { from { opacity: 0; transform: translateY(16px) scale(.99); } to { opacity: 1; transform: none; } }

/* full-width branded banner with clickable hotspots */
.brand-banner { position: relative; border-radius: 12px; overflow: hidden; line-height: 0; }
.brand-banner-img { width: 100%; height: auto; display: block; }
.brand-banner-hot {
  position: absolute; top: 77%; height: 15%; border: 0; background: transparent; cursor: pointer;
  border-radius: 999px; padding: 0;
}
.brand-banner-hot.hot-order { left: 4%; width: 19.5%; }
.brand-banner-hot.hot-menu { left: 24%; width: 18%; }
.brand-banner-hot:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
@media (hover: hover) { .brand-banner-hot:hover { box-shadow: inset 0 0 0 2px rgba(255,255,255,0.35); } }
@media (max-width: 600px) { .brand-banner-hot { top: 75%; height: 18%; } }

/* banner art with HTML overlay (kicker/desc/buttons) */
.brand-banner-art { container-type: inline-size; background: var(--ac, #111); line-height: normal; }
.bba-content { position: absolute; left: 5%; top: 50%; transform: translateY(-50%); width: 39%; display: flex; flex-direction: column; gap: 0.7cqw; }
.bba-kicker { font-family: var(--fz-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .2em; color: var(--btxt, #fff); opacity: 0.85; font-size: max(10px, 1.2cqw); }
.bba-title { font-size: max(34px, 6.6cqw); color: var(--btxt, #fff); margin: 0; line-height: 0.86; text-shadow: 0 3px 14px rgba(0,0,0,0.18); }
.bba-desc { color: var(--btxt, #fff); font-weight: 600; font-size: max(12px, 1.7cqw); line-height: 1.28; margin: 0.3cqw 0 0; max-width: 32ch; text-shadow: 0 2px 10px rgba(0,0,0,0.22); }
.bba-actions { display: flex; gap: 1.1cqw; flex-wrap: wrap; margin-top: 1cqw; }
.bba-btn {
  display: inline-flex; align-items: center; gap: 0.6cqw; white-space: nowrap;
  font-family: var(--fz-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  font-size: max(10px, 1.3cqw); padding: max(9px, 1.0cqw) max(14px, 2.1cqw); border-radius: 999px;
  transition: transform .18s, filter .18s, background .18s, color .18s;
}
.bba-btn:hover { transform: translateY(-2px); }
.bba-order { background: #161311; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.28); }
.bba-order:hover { background: #000; }
.bba-dot { width: max(5px, 0.7cqw); height: max(5px, 0.7cqw); border-radius: 50%; background: var(--ac); flex: none; }
.bba-menu { background: #fff; color: #161311; }
.bba-menu:hover { filter: brightness(0.94); }

/* narrow: cohesive single card — food-cropped image band + matching text block below */
@container (max-width: 680px) {
  .brand-banner-art { background: var(--bbg, #161311); }
  .brand-banner-art .brand-banner-img { height: 150px; object-fit: cover; object-position: 78% 42%; }
  .bba-content { position: static; transform: none; width: auto; top: auto; left: auto; padding: 18px 18px 20px; gap: 10px; background: var(--bbg, #161311); }
  .bba-kicker { font-size: 11px; }
  .bba-title { font-size: 40px; }
  .bba-desc { font-size: 15px; max-width: none; }
  .bba-btn { font-size: 12px; padding: 12px 18px; gap: 8px; }
  .bba-actions { flex-direction: column; align-items: stretch; gap: 10px; }
  .bba-btn { justify-content: center; width: 100%; }
  .bba-dot { width: 6px; height: 6px; }
}

.flood-grid, .split-grid, .spot-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 0; align-items: stretch; }
.flood-grid { gap: clamp(20px,3vw,48px); padding: clamp(24px,3vw,44px); }
.spot-grid { gap: clamp(20px,3vw,44px); }

/* picker: grid — logo chips on dark, accent ring when active */
.picker-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: 12px; }
.brand-chip {
  display: flex; flex-direction: column; gap: 16px; align-items: stretch; justify-content: space-between;
  min-height: 132px; padding: 22px 20px; border-radius: 12px; text-align: left;
  background: linear-gradient(180deg, rgba(247,245,240,0.04), rgba(0,0,0,0.12));
  box-shadow: inset 0 0 0 1.5px var(--line);
  transition: transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s;
}
.brand-chip:hover { transform: translateY(-3px); box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--c) 55%, transparent); }
.brand-chip.on { box-shadow: inset 0 0 0 2px var(--c); background: color-mix(in srgb, var(--c) 12%, rgba(0,0,0,0.2)); }
.brand-chip-logo { display: flex; align-items: center; flex: 1; }
.brand-chip-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.brand-chip-arrow { font-family: var(--fz-mono); font-weight: 700; opacity: 0; transform: translateX(-4px); transition: .2s; }
.brand-chip:hover .brand-chip-arrow, .brand-chip.on .brand-chip-arrow { opacity: 1; transform: none; }

/* picker: accordion (phone) — detail opens directly under the tapped brand */
.picker-accordion { display: grid; gap: 12px; }
.acc-item { display: grid; }
.acc-item .brand-chip { width: 100%; }
.acc-detail { margin: 12px 0 4px; }

/* picker: carousel */
.picker-carousel { display: flex; gap: 14px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 8px; }
.brand-card {
  scroll-snap-align: start; flex: 0 0 clamp(200px, 32vw, 260px); height: 200px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 8px; text-align: left;
  padding: 20px; border-radius: 10px; transition: transform .2s, opacity .25s;
}
.brand-card:hover { transform: translateY(-3px); }

/* picker: tiles (accordion) */
.picker-tiles { display: flex; gap: 8px; height: clamp(180px, 26vw, 240px); }
.tile {
  position: relative; overflow: hidden; border-radius: 8px;
  display: flex; align-items: flex-end; padding: 18px;
  transition: flex .5s cubic-bezier(.16,1,.3,1), filter .3s;
  filter: saturate(.9) brightness(.92);
}
.tile.on { filter: none; }
.tile:not(.on) { filter: saturate(.7) brightness(.78); }
.tile-label { font-size: clamp(20px, 2.4vw, 34px); writing-mode: vertical-rl; transform: rotate(180deg); white-space: nowrap; }
.tile.on .tile-label { writing-mode: horizontal-tb; transform: none; }
.tile-kind { position: absolute; top: 16px; left: 16px; opacity: .8; font-size: 11px; }

@media (max-width: 860px) {
  .flood-grid, .split-grid, .spot-grid { grid-template-columns: 1fr; }
  .flood-grid .brand-detail, .split-grid { }
  .split-grid > div:first-child { order: 2; }
  .picker-grid { grid-template-columns: 1fr 1fr; }
  .picker-tiles { flex-direction: column; height: auto; }
  .tile { min-height: 64px; }
  .tile.on { min-height: 130px; }
  .tile-label { writing-mode: horizontal-tb; transform: none; }
  .brand-chip { padding: 16px; min-height: 104px; }
  .brand-chip-logo .brand-logo { height: 32px; }
}

/* ---- bestsellers (energetic "Rahva lemmikud") ---- */
.bs-section { position: relative; background: #0c0b09; overflow: hidden; padding: clamp(56px, 8vw, 104px) 0; }
.bs-noise {
  position: absolute; inset: 0; pointer-events: none; opacity: 0.5;
  background:
    radial-gradient(60% 50% at 100% 0%, rgba(255,212,0,0.06), transparent 60%),
    radial-gradient(50% 60% at 0% 100%, rgba(226,35,26,0.06), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.018) 0 2px, transparent 2px 9px);
}
.bs-inner { position: relative; z-index: 1; }
.bs-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; }
.bs-kicker {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--fz-mono); font-size: 13px; letter-spacing: .28em; text-transform: uppercase; font-weight: 700;
  color: #FFD400;
}
.bs-title {
  font-size: clamp(38px, 6vw, 82px); margin: 12px 0 0; line-height: 0.9; color: #fff; max-width: 720px; text-wrap: balance;
  text-shadow: 0 3px 0 rgba(0,0,0,0.25); letter-spacing: 0.005em;
}
.bs-brush { display: block; width: clamp(180px, 26vw, 300px); height: auto; margin: 6px 0 0 2px; }
.bs-viewall {
  flex: none; display: inline-flex; align-items: center; gap: 10px; margin-top: 8px;
  font-family: var(--fz-mono); font-weight: 700; font-size: 13px; letter-spacing: .14em; text-transform: uppercase;
  color: #fff; padding: 13px 22px; position: relative;
  clip-path: polygon(0 0, 100% 0, 100% 64%, calc(100% - 16px) 100%, 0 100%);
  box-shadow: inset 0 0 0 1.5px rgba(255,212,0,0.55); transition: background .2s, color .2s, transform .18s;
}
.bs-viewall:hover { background: #FFD400; color: #161410; transform: translateY(-2px); }
.bs-viewall span { color: #FFD400; font-size: 16px; }
.bs-viewall:hover span { color: #161410; }

/* chevrons */
.bs-chevs { display: inline-flex; align-items: center; gap: 3px; }
.kchevs { display: inline-flex; align-items: center; gap: 3px; margin-left: 11px; vertical-align: middle; }
.kchevs span { display: block; border-radius: 1px; transform: skewX(-22deg); }
.bs-chevs span { display: block; border-radius: 1px; transform: skewX(-22deg); }

/* controls row */
.bs-controls { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin: clamp(22px, 3vw, 38px) 0 clamp(20px, 2.5vw, 30px); }
.bs-controls-arrows-only { justify-content: flex-end; }
.bs-filters { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 2px; }
.bs-pill {
  flex: none; display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--fz-mono); font-weight: 700; font-size: 12.5px; letter-spacing: .08em; text-transform: uppercase;
  color: #fff; padding: 11px 18px; border-radius: 999px;
  background: rgba(255,255,255,0.04); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.12);
  transition: background .2s, box-shadow .2s, color .2s, transform .15s; white-space: nowrap;
}
.bs-pill:hover { transform: translateY(-1px); box-shadow: inset 0 0 0 1.5px var(--pill, rgba(255,255,255,0.4)); }
.bs-pill.on { background: #FFD400; color: #161410; box-shadow: none; }
.bs-pill.on .bs-pill-ic { color: #161410; }
.bs-pill-ic { width: 17px; height: 17px; flex: none; color: #FFD400; }
.bs-pill.on .bs-pill-ic { color: inherit; }

.bs-arrows { display: flex; gap: 10px; flex: none; }
.bs-arrow {
  width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 24px; line-height: 1; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.18);
  transition: background .2s, color .2s, transform .15s, box-shadow .2s;
}
.bs-arrow:hover { transform: translateY(-2px); }
.bs-arrow.on { box-shadow: inset 0 0 0 1.5px #FFD400; color: #FFD400; }
.bs-arrow.on:hover { background: #FFD400; color: #161410; }

/* card row */
.bs-row { display: flex; gap: 16px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 16px 2px 30px; }
.bs-card {
  flex: 0 0 clamp(250px, 25vw, 300px); scroll-snap-align: start;
  position: relative; display: flex; flex-direction: column; border-radius: 16px; overflow: hidden;
  background: linear-gradient(168deg, color-mix(in srgb, var(--ac) 26%, #14110d) 0%, #0b0a08 64%);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--ac) 35%, transparent), 0 20px 50px -28px rgba(0,0,0,0.8);
  transition: transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s;
}
.bs-card:hover { transform: translateY(-6px); box-shadow: inset 0 0 0 1.5px var(--ac), 0 16px 44px -12px color-mix(in srgb, var(--ac) 42%, transparent); }
.bs-card-tab {
  position: absolute; top: 14px; left: 14px; z-index: 3;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fz-mono); font-weight: 700; font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase;
  padding: 6px 11px; clip-path: polygon(0 0, 100% 0, 100% 100%, 8px 100%, 0 70%);
}
.bs-card-photo { position: relative; aspect-ratio: 3 / 3.2; overflow: hidden; }
.bs-card-glow { position: absolute; inset: 0; z-index: 1; }
.bs-card-photo .ph { position: absolute; inset: 0; z-index: 2; background: transparent !important; border-radius: 0; }
.bs-card-photo .ph::after { display: none; }
.bs-card-photo::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 58%; z-index: 3; pointer-events: none;
  background: linear-gradient(to top, #0b0a08 8%, color-mix(in srgb, #0b0a08 70%, transparent) 42%, transparent 100%);
}
.bs-card-foot { padding: 0 18px 18px; display: flex; flex-direction: column; gap: 8px; margin-top: -30px; position: relative; z-index: 4; background: #0b0a08; }
.bs-card-name { font-size: clamp(20px, 2vw, 26px); color: #fff; line-height: 0.95; text-shadow: 0 2px 8px rgba(0,0,0,0.7); }
.bs-card-foot-row { display: flex; align-items: center; justify-content: space-between; }
.bs-card-price { font-family: var(--fz-mono); font-weight: 800; font-size: 18px; }
.bs-card-pricenote { font-family: var(--fz-mono); font-size: 10.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); margin-top: 2px; display: block; }

@media (max-width: 760px) {
  .bs-head { flex-direction: column; gap: 14px; }
  .bs-viewall { align-self: flex-start; }
}

/* ---- campaign carousel ---- */
.campaign-carousel { position: relative; }

/* seasonal promo banner */
.promo-banner {
  position: relative; overflow: hidden; border-radius: 16px;
  background: linear-gradient(105deg, #1a0726 0%, #3a0f56 42%, #5a1b86 72%, #7d2bb0 100%);
  display: grid; grid-template-columns: 0.85fr 1.15fr auto; align-items: center;
  gap: clamp(16px, 3vw, 40px); padding: 0 clamp(20px, 3vw, 40px) 0 0;
  margin-bottom: clamp(22px, 3vw, 36px); min-height: 200px;
  box-shadow: 0 30px 70px -34px rgba(90,27,134,0.7);
}
.promo-photo { position: relative; align-self: stretch; min-height: 200px; }
.promo-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.promo-photo-fade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(26,7,38,0.25) 0%, rgba(26,7,38,0.4) 55%, #2b0c41 100%); }
.promo-body { position: relative; z-index: 2; padding: clamp(22px, 3vw, 36px) 0; }
.promo-kick { color: #e879f9; letter-spacing: .26em; }
.promo-title { color: #fff; font-size: clamp(28px, 4.2vw, 54px); line-height: 1.0; margin: 12px 0 0; max-width: 16ch; }
.promo-sub { color: rgba(255,255,255,0.8); font-size: clamp(14px, 1.7vw, 18px); margin: clamp(16px,1.8vw,22px) 0 0; max-width: 42ch; line-height: 1.45; }
.promo-cta { margin-top: 20px; background: #fff; color: #5a1b86; }
.promo-cta:hover { background: #f3e8ff; }
.promo-badge {
  position: relative; z-index: 2; flex: none; justify-self: end;
  width: clamp(96px, 12vw, 132px); height: clamp(96px, 12vw, 132px); border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
  background: radial-gradient(circle at 35% 30%, #c026d3, #7d2bb0);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.12), 0 14px 34px -10px rgba(192,38,211,0.7);
  color: #fff; transform: rotate(-8deg);
}
.promo-badge-pre { font-family: var(--fz-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; opacity: .9; }
.promo-badge-num { font-family: var(--fz-display); font-size: clamp(26px, 3.2vw, 40px); line-height: 0.9; }
/* football pitch motif */
.promo-pitch { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; opacity: .5; }
.pitch-mid { position: absolute; top: 8%; bottom: 8%; left: 50%; width: 2px; background: rgba(255,255,255,0.16); }
.pitch-circle { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: clamp(120px,16vw,190px); height: clamp(120px,16vw,190px); border-radius: 50%; border: 2px solid rgba(255,255,255,0.16); }
.pitch-spot { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,0.3); }

/* confetti */
.promo-confetti { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.promo-confetti span {
  position: absolute; width: 9px; height: 14px; border-radius: 2px;
  top: calc((var(--i) * 37% ) - 20%); left: calc((var(--i) * 53%) - 30%);
  background: hsl(calc(var(--i) * 47), 85%, 62%);
  transform: rotate(calc(var(--i) * 40deg)); opacity: .8;
  animation: ns-confetti 6s ease-in-out infinite; animation-delay: calc(var(--i) * -0.31s);
}
@keyframes ns-confetti { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(14px) rotate(180deg); } }
@media (prefers-reduced-motion: reduce) { .promo-confetti span { animation: none; } }

.campaign-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; border-radius: 12px; overflow: hidden; box-shadow: 0 30px 70px -34px rgba(0,0,0,0.6); animation: ns-campfade .5s ease; }
@keyframes ns-campfade { from { opacity: .35; } to { opacity: 1; } }
.campaign-panel { position: relative; padding: clamp(26px,3.6vw,48px); display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.campaign-photo { position: relative; background: var(--ink-soft); overflow: hidden; min-height: 300px; }
.camp-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 4;
  width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: rgba(14,13,11,0.6); color: var(--paper); font-size: 28px; line-height: 1;
  backdrop-filter: blur(6px); box-shadow: 0 6px 18px -6px rgba(0,0,0,0.6); transition: background .2s, transform .2s;
}
.camp-arrow:hover { background: rgba(14,13,11,0.85); }
.camp-prev { left: 14px; } .camp-prev:hover { transform: translateY(-50%) translateX(-2px); }
.camp-next { right: 14px; } .camp-next:hover { transform: translateY(-50%) translateX(2px); }
.camp-dots { display: flex; gap: 9px; justify-content: center; margin-top: 22px; }
.camp-dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(247,245,240,0.25); transition: background .25s, width .25s; padding: 0; }
.camp-dot.on { background: var(--c, var(--paper)); width: 28px; border-radius: 999px; }
.camp-dot:hover { background: rgba(247,245,240,0.55); }

@media (max-width: 860px) {
  .promo-banner { grid-template-columns: 1fr; padding: 0; }
  .promo-photo { min-height: 130px; }
  .promo-body { padding: 22px clamp(18px,5vw,28px) 0; }
  .promo-badge { position: absolute; top: 14px; right: 14px; width: 78px; height: 78px; }
  .promo-banner { padding-bottom: 24px; }
  .campaign-grid { grid-template-columns: 1fr; }
  .campaign-photo { order: -1; min-height: 210px; }
  .camp-arrow { width: 40px; height: 40px; font-size: 24px; }
}

/* ---- locations ---- */
#locations.section { padding-top: clamp(44px, 6vw, 84px); padding-bottom: clamp(44px, 6vw, 84px); }
.loc-haze { position: relative; overflow: hidden; }
.loc-haze > .bs-noise { z-index: 0; }
.loc-haze::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 170px; z-index: 0; pointer-events: none;
  background: linear-gradient(to bottom, transparent, var(--ink));
}
.loc-haze > .wrap { position: relative; z-index: 1; }

/* distinct section textures */
.haze-grid { position: relative; overflow: hidden; z-index: 0; }
.haze-grid::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(circle, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 26px 26px,
    radial-gradient(45% 40% at 100% 0%, rgba(255,255,255,0.035), transparent 60%);
  opacity: 0.7;
}
.haze-join { position: relative; overflow: hidden; z-index: 0; }
.haze-join::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(50% 70% at 0% 0%, rgba(226,35,26,0.10), transparent 62%),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.022) 0 2px, transparent 2px 13px);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0, #000 120px);
  mask-image: linear-gradient(to bottom, transparent 0, #000 120px);
}
.loc-grid { display: grid; grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr); gap: 16px; align-items: stretch; }
.loc-map { position: relative; border-radius: 12px; overflow: hidden; min-height: 340px; border: 1px solid var(--line); background: #0b0d10; isolation: isolate; z-index: 0; }
.loc-map-canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.loc-map-label {
  position: absolute; left: 14px; bottom: 14px; z-index: 500;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fz-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  background: rgba(14,13,11,0.78); color: var(--paper); padding: 7px 12px; border-radius: 999px;
  backdrop-filter: blur(6px); border: 1px solid var(--line);
}
/* leaflet dark popup / controls */
.loc-map .leaflet-control-zoom a { background: rgba(14,13,11,0.85); color: var(--paper); border-color: var(--line); }
.loc-map .leaflet-control-zoom a:hover { background: rgba(40,36,30,0.95); }

/* custom map pin (leaflet divIcon) */
.ns-pin {
  position: absolute; transform: translate(-12.5px, -50%); transform-origin: 12.5px 50%; display: inline-flex; align-items: center; gap: 7px;
  background: rgba(10,11,14,0.9); border: 1px solid rgba(247,245,240,0.18); border-radius: 999px;
  padding: 4px 11px 4px 7px; white-space: nowrap;
  font-family: var(--fz-mono); font-size: 12px; font-weight: 700; letter-spacing: .04em; color: var(--paper);
  box-shadow: 0 6px 18px -6px rgba(0,0,0,0.7); transition: transform .2s, background .2s, border-color .2s;
}
.ns-pin i { width: 11px; height: 11px; border-radius: 50%; background: var(--c); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c) 28%, transparent); flex: none; }
.ns-pin.on { transform: translate(-12.5px, -50%) scale(1.12); background: var(--c); border-color: #fff; color: #fff; }
.ns-pin.on i { background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,0.3); }

/* venue cards — photo on top, row of three */
.loc-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
/* karusselli nooled (nähtavad ainult telefonis) */
.loc-arrows { display: none; gap: 10px; justify-content: flex-end; margin-bottom: 12px; }
.loc-arrow {
  width: 46px; height: 46px; border-radius: 50%; font-size: 24px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  background: transparent; color: var(--paper); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.18);
  transition: background .2s, color .2s, transform .18s, box-shadow .2s;
}
.loc-arrow:hover { transform: translateY(-2px); }
.loc-arrow:last-child { box-shadow: inset 0 0 0 1.5px #E8852A; color: #E8852A; }
.loc-arrow:last-child:hover { background: #E8852A; color: #1a1208; }
.venue {
  position: relative; padding: 0; border-radius: 14px; display: flex; flex-direction: column; overflow: hidden;
  background: linear-gradient(180deg, rgba(247,245,240,0.03), rgba(0,0,0,0.1));
  border: 1.5px solid color-mix(in srgb, var(--c) 40%, transparent);
  transition: border-color .25s, background .25s, transform .2s; flex: 1;
}
.venue.on { border-color: var(--c); background: color-mix(in srgb, var(--c) 9%, transparent); transform: translateY(-3px); }
.venue-photo {
  display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover;
  background:
    repeating-linear-gradient(135deg, transparent 0 15px, color-mix(in srgb, var(--c) 16%, transparent) 15px 17px),
    color-mix(in srgb, var(--c) 12%, #15120f);
}
img.venue-photo { border-radius: 0; }
.venue-body { display: flex; flex-direction: column; padding: 14px 16px 16px; flex: 1; }
.venue-head { display: flex; align-items: center; gap: 9px; }
.venue-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--c); flex: none; box-shadow: 0 0 0 4px color-mix(in srgb, var(--c) 22%, transparent); }
.venue-name { font-size: 26px; line-height: 1; }
.venue-zip { font-family: var(--fz-mono); font-size: 11px; color: var(--muted); letter-spacing: .03em; text-transform: uppercase; margin: 9px 0 13px; }
.venue-hours { list-style: none; margin: 0 0 16px; padding: 0; display: grid; gap: 3px; }
.venue-hours li { display: flex; gap: 12px; font-size: 13.5px; color: rgba(247,245,240,0.78); }
.vh-d { display: inline-block; width: 58px; color: var(--paper); font-weight: 600; white-space: nowrap; }
.venue-menu {
  align-self: stretch; margin-top: auto; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--fz-mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  padding: 11px 15px; border-radius: 999px; box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--c) 55%, transparent);
  color: var(--paper); transition: background .2s, box-shadow .2s, transform .18s;
}
.venue-menu:hover { background: var(--c); box-shadow: inset 0 0 0 1.5px var(--c); transform: translateY(-2px); }
.venue-actions { margin-top: auto; display: grid; gap: 8px; }
.venue-dir {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  font-family: var(--fz-mono); font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  padding: 10px 14px; border-radius: 999px; text-decoration: none;
  color: rgba(247,245,240,0.78); box-shadow: inset 0 0 0 1.5px var(--line);
  transition: color .2s, box-shadow .2s, transform .18s;
}
.venue-dir svg { width: 14px; height: 14px; }
.venue-dir:hover { color: var(--paper); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.4); transform: translateY(-1px); }

/* ---- footer ---- */
.foot-link { display: inline-flex; align-items: center; gap: 9px; font-size: 14px; color: rgba(247,245,240,0.72); transition: color .18s; }
.foot-link:hover { color: var(--paper); }
.footer { background: var(--ink); border-top: 1px solid var(--line); padding: clamp(36px,5vw,56px) 0 calc(96px + env(safe-area-inset-bottom)); }
.footer-main {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr auto; gap: clamp(24px,4vw,56px);
  align-items: start; padding-bottom: 36px;
}
.footer-brand { display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.footer-tartu { font-family: var(--fz-mono); font-size: 11px; letter-spacing: .34em; text-transform: uppercase; color: var(--muted); }
.footer-tagline { font-family: var(--fz-display); font-size: 22px; text-transform: uppercase; color: var(--paper); margin-top: 6px; letter-spacing: .01em; }
.footer-block { display: flex; flex-direction: column; gap: 14px; }
.footer-social { display: flex; flex-direction: column; gap: 9px; }
.footer-soc { display: inline-flex; align-items: center; gap: 10px; color: rgba(247,245,240,0.72); font-size: 14px; transition: color .18s; }
.footer-soc svg { opacity: .8; transition: opacity .18s; }
.footer-soc:hover { color: var(--paper); }
.footer-soc:hover svg { opacity: 1; }
.footer-contact { display: flex; flex-direction: column; gap: 9px; }
.footer-order { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.footer-order-label { color: var(--muted); }
.footer-order-logos { display: flex; align-items: center; gap: 22px; }
.footer-wolt-link { display: inline-flex; transition: transform .18s, filter .18s; }
.footer-wolt-link:hover { transform: translateY(-2px); filter: brightness(1.1); }
.footer-bolt-link { display: inline-flex; transition: transform .18s, filter .18s; }
.footer-bolt-link:hover { transform: translateY(-2px); filter: brightness(1.1); }
.footer-bolt-logo { height: 30px; width: auto; display: block; }
.footer-brands {
  display: flex; align-items: center; gap: clamp(18px, 3vw, 40px); flex-wrap: wrap;
  margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--line);
}
.footer-brands-label { color: var(--muted); flex: none; }
.footer-brands-row { display: flex; align-items: center; gap: clamp(22px, 4vw, 52px); flex-wrap: wrap; flex: 1; }
.footer-brand-logo { opacity: 0.82; transition: opacity .2s, transform .2s; }
.footer-brand-logo:hover { opacity: 1; transform: translateY(-2px); }
.btn-wolt { background: #00B8D4; color: #04222a; box-shadow: 0 10px 26px -12px rgba(0,184,212,0.7); }
.btn-wolt .wolt-dot { background: #04222a; }
.btn-wolt:hover { background: #00cdec; }
.wolt-wordmark { font-family: var(--fz-display); font-size: 30px; letter-spacing: .01em; color: #00B8D4; line-height: 1; }
.footer-bar {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
  padding-top: 22px; border-top: 1px solid var(--line);
  font-family: var(--fz-mono); font-size: 11px; color: var(--muted); letter-spacing: .06em;
}
.footer-bar-links { display: flex; gap: 22px; }
.footer-bar-links .foot-link { font-size: 11px; }

@media (max-width: 860px) {
  .footer-main { grid-template-columns: 1fr 1fr; gap: 28px; }
  .footer-order { grid-column: 1 / -1; }
  .footer-bar { justify-content: flex-start; }
  .footer-brands { height: auto !important; flex-direction: column; align-items: flex-start; gap: 16px !important; padding-top: 24px !important; }
  .footer-brands-row { gap: 22px 26px; }
}
@media (max-width: 520px) {
  .footer-main { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  .loc-grid { grid-template-columns: 1fr; }
  .loc-map { min-height: 300px; }
  .loc-cards { grid-template-columns: 1fr 1fr; }
  .foot-cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .foot-cols { grid-template-columns: 1fr; }
  .loc-cards { grid-template-columns: 1fr; }
}

/* ---- Jalka MM offers carousel ---- */
.mm-section { position: relative; }
.mm-section::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 200px; pointer-events: none; z-index: 0;
  background: linear-gradient(to bottom, #0c0b09, transparent);
}
.mm-section::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 200px; pointer-events: none; z-index: 0;
  background: linear-gradient(to bottom, transparent, var(--ink-soft));
}
.mm-section > .wrap { position: relative; z-index: 1; }
.mm-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; margin: clamp(34px, 5vw, 56px) 0 20px; flex-wrap: wrap; }
.mm-title { font-size: clamp(30px, 4.4vw, 54px); margin: 12px 0 6px; line-height: 1; }
.mm-sub { font-size: clamp(14px, 1.7vw, 17px); color: var(--muted); margin: 0; max-width: 46ch; }
.mm-arrows { display: flex; gap: 10px; margin-left: auto; }
.mm-arrow {
  width: 46px; height: 46px; border-radius: 50%; font-size: 24px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  background: transparent; color: var(--paper); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,0.18);
  transition: background .2s, color .2s, transform .18s, box-shadow .2s;
}
.mm-arrow:hover { transform: translateY(-2px); }
.mm-arrow.on, .mm-arrow:last-child { box-shadow: inset 0 0 0 1.5px #FFD400; color: #FFD400; }
.mm-arrow:last-child:hover { background: #FFD400; color: #161410; }
.mm-rail { display: flex; gap: 16px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 16px 2px 30px; }
.mm-card {
  flex: 0 0 clamp(260px, 30vw, 320px); scroll-snap-align: start;
  display: flex; flex-direction: column; border-radius: 14px; overflow: hidden;
  background: var(--card, #1b1813);
  box-shadow: inset 0 0 0 1px var(--line), 0 0 0 0 transparent;
  transition: transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .2s;
}
.mm-card:hover { transform: translateY(-4px); box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--c) 50%, transparent), 0 16px 44px -12px color-mix(in srgb, var(--c) 42%, transparent); }
.mm-photo { position: relative; aspect-ratio: 4 / 3; background: #0f0d0a; }
.mm-badge {
  position: absolute; top: 12px; left: 12px; z-index: 3;
  font-family: var(--fz-mono); font-weight: 700; font-size: 14px; padding: 5px 11px; border-radius: 9px;
  background: var(--c); color: #fff; box-shadow: 0 6px 16px -6px rgba(0,0,0,0.5);
}
.mm-brandtag {
  position: absolute; bottom: 12px; left: 12px; z-index: 3;
  font-family: var(--fz-mono); font-weight: 700; font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
  padding: 6px 10px; border-radius: 999px;
}
.mm-body { display: flex; flex-direction: column; gap: 10px; padding: 16px 16px 18px; flex: 1; }
.mm-cta {
  align-self: flex-start; margin-top: auto; display: inline-flex; align-items: center; gap: 10px; white-space: nowrap;
  font-family: var(--fz-mono); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; font-size: 13px;
  padding: 12px 18px; border-radius: 999px; transition: transform .18s, box-shadow .18s;
  background: #161311; color: #fff; box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--c) 55%, transparent);
}
.mm-cta:hover { transform: translateY(-2px); box-shadow: inset 0 0 0 1.5px var(--c); }
.mm-cta-dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.mm-name { font-size: 17px; font-weight: 800; line-height: 1.2; margin: 0; }
.mm-price { display: flex; align-items: baseline; gap: 9px; }
.mm-price b { font-family: var(--fz-display); font-size: 26px; font-weight: 400; color: var(--paper); }
.mm-price s { font-family: var(--fz-mono); font-size: 13px; color: var(--muted); }

/* ---- join club ---- */
.join-sec { padding-top: clamp(24px, 5vw, 64px); }
.join-card {
  position: relative; overflow: hidden; border-radius: 16px;
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 56px);
  padding: clamp(28px, 4vw, 56px);
  background: linear-gradient(135deg, #E2231A 0%, #9c1109 100%);
  color: #fff; box-shadow: 0 30px 70px -34px rgba(226,35,26,0.6);
}
.join-card::before {
  content: ""; position: absolute; top: -60px; right: -40px; width: 280px; height: 280px;
  border-radius: 50%; background: rgba(255,255,255,0.07); pointer-events: none;
}
.join-left { position: relative; z-index: 1; display: flex; flex-direction: column; justify-content: center; }
.join-title { font-size: clamp(36px, 5vw, 64px); margin: 12px 0 22px; line-height: 0.95; }
.join-perks { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
.join-perks li { display: flex; align-items: center; gap: 12px; font-size: clamp(14px,1.7vw,17px); font-weight: 600; }
.join-pk { width: 30px; height: 30px; border-radius: 9px; flex: none; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.16); color: #fff; }
.join-form { position: relative; z-index: 1; display: flex; flex-direction: column; justify-content: center; gap: 12px; }
.join-field {
  width: 100%; background: rgba(0,0,0,0.22); border: 1.5px solid rgba(255,255,255,0.25); border-radius: 11px;
  padding: 15px 16px; color: #fff; font-family: var(--fz-body); font-size: 15px;
}
.join-field:focus { outline: none; border-color: #fff; background: rgba(0,0,0,0.34); }
.join-field::placeholder { color: rgba(255,255,255,0.7); }
.join-phone { display: flex; gap: 10px; }
.join-phone .code { flex: 0 0 92px; }
.join-phone .join-field { min-width: 0; }
.join-dob { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.join-dob > span { font-family: var(--fz-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,0.78); padding-left: 2px; }
/* iOS Safari: natiivne date-väli ei austa width:100% ilma appearance:none + min-width:0 */
.join-dob input[type="date"] {
  color-scheme: dark; -webkit-appearance: none; appearance: none;
  display: flex; align-items: center;
  width: 100%; min-width: 0; max-width: 100%;
  /* iOS: tühi date-väli kukub appearance:none puhul kokku — fikseeri sama kõrgus mis teistel väljadel */
  height: 52px; padding-top: 0; padding-bottom: 0;
}
.join-submit {
  width: 100%; background: #fff; color: #E2231A; font-weight: 800; font-size: 16px;
  padding: 16px; border-radius: 11px; transition: transform .18s, filter .18s; margin-top: 4px;
}
.join-submit:hover { transform: translateY(-2px); filter: brightness(0.98); }
.join-submit.done { background: #0E0D0B; color: #fff; }
.join-fine { font-size: 11.5px; color: rgba(255,255,255,0.78); line-height: 1.45; margin: 4px 0 0; }
.join-names { display: flex; gap: 10px; }
.join-names .join-field { flex: 1 1 0; min-width: 0; }
.join-field:disabled { opacity: 0.7; cursor: default; }
.join-feedback { font-size: 13.5px; font-weight: 700; line-height: 1.4; margin: 2px 0 0; }
.join-feedback.ok { color: #fff; }
.join-feedback.bad { color: #ffd9d5; }

@media (max-width: 760px) {
  .join-card { grid-template-columns: 1fr; }
  .join-names { flex-direction: column; gap: 12px; }
}

/* ---- menu lightbox (shared) ---- */
.menu-overlay {
  position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center;
  background: rgba(8,7,6,0.86); backdrop-filter: blur(8px); padding: clamp(10px, 3vw, 40px);
  animation: menu-fade .25s ease;
}
@keyframes menu-fade { from { opacity: 0; } to { opacity: 1; } }
.menu-sheet {
  width: min(1000px, 100%); max-height: 92vh; display: flex; flex-direction: column;
  background: #16140f; border-radius: 14px; overflow: hidden; box-shadow: 0 40px 100px -30px rgba(0,0,0,0.8);
  animation: menu-rise .3s cubic-bezier(.16,1,.3,1);
}
@keyframes menu-rise { from { transform: translateY(16px) scale(.99); opacity: 0; } to { transform: none; opacity: 1; } }
.menu-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 14px 16px; border-bottom: 2px solid #0E0D0B; flex: none; background: rgba(0,0,0,0.25);
}
.menu-bar-title { display: inline-flex; align-items: center; gap: 11px; min-width: 0; }
.menu-order {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--fz-mono); font-weight: 700;
  font-size: 12px; text-transform: uppercase; letter-spacing: .06em; padding: 9px 14px; border-radius: 999px;
  transition: transform .18s, filter .18s; white-space: nowrap;
}
.menu-order:hover { transform: translateY(-2px); filter: brightness(1.05); }
.menu-close {
  width: 38px; height: 38px; border-radius: 50%; font-size: 17px; flex: none;
  background: rgba(247,245,240,0.08); color: var(--paper); transition: background .18s;
}
.menu-close:hover { background: rgba(247,245,240,0.18); }
.menu-scroll { overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 16px; }
.menu-page { width: 100%; height: auto; border-radius: 8px; display: block; box-shadow: 0 10px 30px -14px rgba(0,0,0,0.6); }
.menu-empty { padding: 60px 20px; text-align: center; font-family: var(--fz-mono); color: var(--muted); letter-spacing: .08em; text-transform: uppercase; font-size: 13px; }

/* =======================================================
   PHONE LAYER — tighter spacing, safe wrapping, no overflow
   ======================================================= */
@media (max-width: 600px) {
  html, body { overflow-x: hidden; }
  /* tame oversized / inline section paddings on phones */
  .section { padding-top: 48px !important; padding-bottom: 48px !important; }
  #top { padding-top: 92px !important; }

  /* hero: let the headline wrap instead of forcing one line + overflowing */
  .hero-h1 { white-space: normal !important; font-size: clamp(40px, 13vw, 60px) !important; }
  .hero-eyebrow, .hero-content .kicker { white-space: normal !important; }
  .hero-actions { gap: 26px; flex-direction: column; align-items: stretch; }
  .cta-badge-join { display: inline-flex; }
  /* telefonis asendab klubi-nupp "Vali oma maitse" nuppu */
  .hero-actions .cta-badge-alt { display: none; }
  .hero-actions .cta-badge, .hero-actions .cta-ghost { width: 100%; justify-content: space-between; }

  /* section titles scale down a touch */
  .sec-title, .mm-title { font-size: clamp(30px, 9vw, 44px) !important; }

  /* brand selector: single column reads better on a narrow screen */
  .picker-grid { grid-template-columns: 1fr !important; }
  .brand-chip { min-height: 92px; }

  /* MM + bestseller cards: roomier peek so they're easy to swipe */
  .mm-card { flex-basis: 80vw !important; }
  .bs-card { flex-basis: 76vw !important; }

  /* telefonis: peida kaart, näita karusselli nooli */
  .loc-map { display: none !important; }
  .loc-arrows { display: flex; }

  /* locations cards: horisontaalne karussell telefonis (nagu lemmikud/combo'd) */
  .loc-cards {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 12px;
    padding-bottom: 6px;
    align-items: stretch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .loc-cards::-webkit-scrollbar { display: none; }
  .loc-cards .venue { flex: 0 0 80vw; scroll-snap-align: start; }

  /* comfortable tap targets */
  .lang button, .nav-toggle { min-height: 44px; }
  .venue-menu, .venue-dir, .promo-cta, .mm-card .btn { min-height: 44px; }

  /* menu lightbox uses full screen on phone */
  .menu-sheet { max-height: 96vh; border-radius: 10px; }
}

/* very small phones */
@media (max-width: 380px) {
  .picker-grid { gap: 10px; }
  .hero-h1 { font-size: clamp(34px, 12vw, 48px) !important; }
}
