/* =========================================================================
   ICE CUP — premium icy DTC landing
   Type: Archivo (display) / Manrope (body) / Space Mono (technical)
   Color: icy whites -> saturated cold blue -> deep-freeze navy
   ========================================================================= */

:root{
  /* fonts (overridable via Tweaks) */
  --font-display: "Archivo", system-ui, sans-serif;
  --font-body: "Manrope", system-ui, sans-serif;
  --font-mono: "Space Mono", ui-monospace, monospace;

  /* cold palette */
  --ice-white:  oklch(0.995 0.004 230);
  --frost:      oklch(0.972 0.012 232);
  --frost-2:    oklch(0.945 0.022 235);
  --ice-line:   oklch(0.90 0.03 235);
  --ice-200:    oklch(0.86 0.06 232);

  /* accent (overridable via Tweaks) */
  --accent:     oklch(0.60 0.19 245);
  --accent-2:   oklch(0.74 0.14 222);
  --accent-deep:oklch(0.46 0.17 252);

  /* deep freeze */
  --navy:       oklch(0.22 0.055 252);
  --navy-2:     oklch(0.17 0.05 254);

  /* ink */
  --ink:        oklch(0.23 0.035 250);
  --ink-soft:   oklch(0.45 0.03 248);
  --ink-faint:  oklch(0.60 0.025 246);

  --radius:   28px;
  --radius-sm:18px;
  --radius-lg:40px;

  --shadow-sm: 0 2px 8px oklch(0.5 0.08 250 / 0.06), 0 8px 24px oklch(0.5 0.08 250 / 0.06);
  --shadow-md: 0 8px 24px oklch(0.5 0.1 250 / 0.10), 0 24px 60px oklch(0.45 0.1 250 / 0.12);
  --shadow-lg: 0 24px 70px oklch(0.45 0.12 252 / 0.20), 0 60px 140px oklch(0.4 0.12 252 / 0.18);
  --glass-stroke: 1px solid oklch(1 0 0 / 0.55);

  --maxw: 1240px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--ice-white);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--accent); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.74rem; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--accent); font-weight:700;
}
.section-title{
  font-family:var(--font-display);
  font-weight:800; letter-spacing:-0.02em; line-height:0.98;
  text-transform:uppercase;
  font-size:clamp(2.2rem, 5.2vw, 4.4rem);
  color:var(--ink);
}
.lead{ font-size:clamp(1rem,1.3vw,1.2rem); color:var(--ink-soft); max-width:60ch; }

/* ---------- background frost field ---------- */
.aurora{
  position:fixed; inset:0; z-index:-2; pointer-events:none; overflow:hidden;
  background:
    radial-gradient(60% 50% at 80% -5%, oklch(0.85 0.09 222 / 0.55), transparent 60%),
    radial-gradient(55% 45% at 8% 8%, oklch(0.8 0.1 250 / 0.4), transparent 60%),
    var(--ice-white);
}
.aurora b{
  position:absolute; border-radius:50%; filter:blur(70px); opacity:0.5;
  background:radial-gradient(circle at 30% 30%, var(--accent-2), transparent 70%);
  animation:drift 26s ease-in-out infinite;
}
.aurora b:nth-child(1){ width:520px; height:520px; left:-6%; top:30%; }
.aurora b:nth-child(2){ width:460px; height:460px; right:-4%; top:55%;
  background:radial-gradient(circle at 30% 30%, var(--accent), transparent 70%); animation-delay:-9s; }
.aurora b:nth-child(3){ width:380px; height:380px; left:40%; top:120%;
  background:radial-gradient(circle at 30% 30%, oklch(0.82 0.1 200), transparent 70%); animation-delay:-15s; }
@keyframes drift{
  0%,100%{ transform:translate(0,0) scale(1); }
  33%{ transform:translate(40px,-30px) scale(1.08); }
  66%{ transform:translate(-30px,25px) scale(0.96); }
}

/* floating ice cubes layer (global, behind content) */
.ice-field{ position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; }
.cube-float{
  position:absolute; border-radius:9px;
  background:linear-gradient(140deg, oklch(0.97 0.02 230 / 0.85), oklch(0.82 0.08 232 / 0.55));
  border:1px solid oklch(1 0 0 / 0.6);
  box-shadow: inset 0 6px 14px oklch(1 0 0 / 0.7), inset 0 -10px 18px oklch(0.6 0.1 250 / 0.15), 0 10px 30px oklch(0.5 0.1 250 / 0.08);
  animation:bob var(--dur,16s) ease-in-out infinite;
  opacity:0.55;
}
.cube-float::after{
  content:""; position:absolute; left:16%; top:12%; width:34%; height:20%;
  background:oklch(1 0 0 / 0.85); border-radius:50%; filter:blur(1px);
}
@keyframes bob{
  0%,100%{ transform:translateY(0) rotate(var(--r,0deg)); }
  50%{ transform:translateY(-34px) rotate(calc(var(--r,0deg) + 12deg)); }
}
body[data-anim="off"] .cube-float,
body[data-anim="off"] .aurora b{ animation:none; }
body[data-anim="off"] .ice-field{ opacity:0.5; }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }

/* ============================ NAV ============================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:center;
  transition:padding .35s ease;
  padding:18px 0;
}
.nav-inner{
  width:min(calc(100% - 36px), var(--maxw));
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px 12px 22px; border-radius:999px;
  background:oklch(1 0 0 / 0.55);
  border:var(--glass-stroke);
  backdrop-filter:blur(18px) saturate(140%);
  box-shadow:var(--shadow-sm);
  transition:box-shadow .35s ease, background .35s ease;
}
.nav.scrolled .nav-inner{ background:oklch(1 0 0 / 0.78); box-shadow:var(--shadow-md); }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; letter-spacing:-0.02em; font-size:1.18rem; text-transform:uppercase; }
.brand .mark{ width:30px; height:30px; }
.brand-logo{ height:34px; width:auto; display:block; }
.foot-brand .brand-logo{ height:64px; }
.nav-links{ display:flex; gap:30px; align-items:center; font-weight:600; font-size:0.93rem; }
.nav-links a{ color:var(--ink-soft); transition:color .2s; position:relative; white-space:nowrap; }
.nav-links a:hover{ color:var(--ink); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.cart-btn{ position:relative; display:flex; align-items:center; gap:8px; padding:11px 18px; border-radius:999px; background:var(--ink); color:#fff; font-weight:700; font-size:0.9rem; transition:transform .2s, background .25s; white-space:nowrap; }
.cart-btn:hover{ transform:translateY(-2px); }
.cart-icon-btn{ position:relative; display:flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:999px; background:oklch(1 0 0 / 0.6); border:var(--glass-stroke); color:var(--ink); transition:transform .2s, background .25s; }
.cart-icon-btn:hover{ transform:translateY(-2px); background:#fff; }
.cart-badge{ position:absolute; top:-6px; right:-6px; min-width:21px; height:21px; padding:0 5px; border-radius:999px; background:var(--accent); color:#fff; font-size:0.72rem; font-weight:800; display:flex; align-items:center; justify-content:center; box-shadow:0 0 0 2px #fff; transform:scale(0); transition:transform .3s cubic-bezier(.3,1.5,.5,1); }
.cart-badge.show{ transform:scale(1); }
.nav-burger{ display:none; position:relative; width:44px; height:44px; flex:none; border-radius:50%; background:var(--ink); align-items:center; justify-content:center; flex-direction:column; gap:5px; transition:background .25s; }
.nav-burger span{ display:block; width:18px; height:2px; border-radius:2px; background:#fff; transition:transform .3s cubic-bezier(.2,.7,.2,1), opacity .2s; }
.nav-burger.on span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-burger.on span:nth-child(2){ opacity:0; }
.nav-burger.on span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile slide-down menu */
.mobile-scrim{ position:fixed; inset:0; top:0; z-index:55; background:oklch(0.2 0.05 250 / 0.4); backdrop-filter:blur(3px); opacity:0; pointer-events:none; transition:opacity .35s; }
.mobile-scrim.show{ opacity:1; pointer-events:auto; }
.mobile-menu{ position:fixed; z-index:58; top:84px; left:18px; right:18px; padding:14px; border-radius:24px; background:oklch(1 0 0 / 0.86); border:var(--glass-stroke); backdrop-filter:blur(20px) saturate(150%); box-shadow:var(--shadow-lg); transform:translateY(-16px) scale(0.97); transform-origin:top center; opacity:0; pointer-events:none; transition:opacity .3s ease, transform .3s cubic-bezier(.2,.7,.2,1); display:none; }
.mobile-menu.open{ opacity:1; transform:none; pointer-events:auto; }
.mobile-menu-links{ display:flex; flex-direction:column; }
.mobile-menu-links a{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:16px 16px; border-radius:14px; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.12rem; color:var(--ink); transition:background .2s, color .2s; }
.mobile-menu.open .mobile-menu-links a{ opacity:1; transform:none; transition:opacity .4s ease, transform .4s cubic-bezier(.2,.7,.2,1), background .2s; }
.mobile-menu-links a:active{ background:var(--frost-2); }
.mobile-menu-links a + a{ border-top:1px solid var(--ice-line); }
.mobile-menu-links a svg{ color:var(--accent); }
.mobile-menu-cta{ display:flex; align-items:center; justify-content:center; gap:10px; width:100%; margin-top:10px; padding:17px; border-radius:14px; background:var(--accent); color:#fff; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1rem; box-shadow:0 10px 26px oklch(0.6 0.19 245 / 0.35); transition:transform .2s, background .25s; }
.mobile-menu-cta:active{ transform:scale(0.98); }

.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; font-weight:700; border-radius:999px; transition:transform .2s, box-shadow .3s, background .3s; white-space:nowrap; }
.btn-lg{ padding:17px 30px; font-size:1.02rem; }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 10px 30px oklch(0.6 0.19 245 / 0.4); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 18px 44px oklch(0.6 0.19 245 / 0.5); }
.btn-ghost{ background:oklch(1 0 0 / 0.5); color:var(--ink); border:var(--glass-stroke); backdrop-filter:blur(10px); }
.btn-ghost:hover{ transform:translateY(-3px); background:oklch(1 0 0 / 0.8); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ transform:translateY(-3px); }

/* ============================ HERO ============================ */
.hero{ position:relative; padding:170px 0 90px; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:40px; align-items:center; }
.hero-badge{ display:inline-flex; align-items:center; gap:9px; padding:8px 16px; border-radius:999px; background:oklch(1 0 0 / 0.6); border:var(--glass-stroke); backdrop-filter:blur(10px); font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent-deep); font-weight:700; box-shadow:var(--shadow-sm); }
.hero-badge .dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px oklch(0.6 0.19 245 / 0.2); animation:pulse 2s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 4px oklch(0.6 0.19 245 / 0.18);} 50%{ box-shadow:0 0 0 8px oklch(0.6 0.19 245 / 0);} }

.hero h1{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  letter-spacing:-0.03em; line-height:0.86;
  font-size:clamp(3.4rem, 9vw, 8.2rem);
  margin:22px 0 0;
}
.hero h1 .stroke{ color:transparent; -webkit-text-stroke:2px var(--ink); }
.hero h1 .grad{ background:linear-gradient(135deg, var(--accent-2), var(--accent) 55%, var(--accent-deep)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-sub{ font-size:clamp(1.05rem,1.5vw,1.32rem); color:var(--ink-soft); max-width:46ch; margin:26px 0 0; }
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:34px; margin-top:46px; }
.hero-stats .s b{ font-family:var(--font-display); font-weight:800; font-size:1.8rem; display:block; letter-spacing:-0.02em; }
.hero-stats .s span{ font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); }

/* hero product stage */
.hero-stage{ position:relative; height:560px; display:flex; align-items:center; justify-content:center; }
.stage-glow{ position:absolute; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle, var(--accent-2), transparent 65%); filter:blur(20px); opacity:0.5; animation:breathe 7s ease-in-out infinite; }
@keyframes breathe{ 0%,100%{ transform:scale(1); opacity:.45;} 50%{ transform:scale(1.12); opacity:.62;} }
.hero-ring{ position:absolute; border-radius:50%; border:1px dashed oklch(0.6 0.12 245 / 0.35); }
.hero-ring.r1{ width:430px; height:430px; animation:spin 40s linear infinite; }
.hero-ring.r2{ width:560px; height:560px; animation:spin 60s linear infinite reverse; border-color:oklch(0.6 0.12 245 / 0.2); }
@keyframes spin{ to{ transform:rotate(360deg);} }

/* ----- CSS ICE CUP ----- */
.cup{ position:relative; width:262px; height:360px; filter:drop-shadow(0 40px 50px oklch(0.45 0.12 250 / 0.3)); animation:cupfloat 6s ease-in-out infinite; z-index:2; }
@keyframes cupfloat{ 0%,100%{ transform:translateY(0) rotate(-1deg);} 50%{ transform:translateY(-18px) rotate(1deg);} }
body[data-anim="off"] .cup, body[data-anim="off"] .stage-glow, body[data-anim="off"] .hero-ring{ animation:none; }
.cup-body{
  position:absolute; inset:0;
  clip-path:polygon(8% 0, 92% 0, 84% 100%, 16% 100%);
  background:linear-gradient(120deg, oklch(0.99 0.01 230 / 0.62), oklch(0.86 0.07 235 / 0.42));
  border:1.5px solid oklch(1 0 0 / 0.7);
  border-top:none;
  overflow:hidden;
  backdrop-filter:blur(3px);
}
.cup-body::before{ /* vertical sheen */
  content:""; position:absolute; left:24%; top:0; width:10%; height:100%;
  background:linear-gradient(oklch(1 0 0 / 0.75), oklch(1 0 0 / 0.1)); filter:blur(2px);
}
.cup-rim{
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  width:248px; height:46px; border-radius:50%;
  background:linear-gradient(oklch(0.92 0.04 232), oklch(0.78 0.08 238));
  border:2px solid oklch(1 0 0 / 0.85);
  box-shadow:inset 0 6px 10px oklch(1 0 0 / 0.6), inset 0 -8px 14px oklch(0.55 0.1 250 / 0.25);
  z-index:3;
}
.cup-rim::after{ content:""; position:absolute; inset:9px 16px; border-radius:50%; background:linear-gradient(160deg, oklch(0.8 0.08 235 / 0.6), oklch(0.62 0.12 245 / 0.45)); }
.cup-liquid{ position:absolute; left:0; right:0; bottom:0; height:46%;
  background:linear-gradient(oklch(0.7 0.14 240 / 0.35), oklch(0.6 0.17 245 / 0.5)); }
.ice{ position:absolute; border-radius:7px;
  background:linear-gradient(140deg, oklch(0.98 0.015 230 / 0.92), oklch(0.83 0.07 234 / 0.66));
  border:1px solid oklch(1 0 0 / 0.7);
  box-shadow:inset 0 4px 8px oklch(1 0 0 / 0.6), inset 0 -6px 10px oklch(0.55 0.1 250 / 0.22);
}
.ice::after{ content:""; position:absolute; left:16%; top:12%; width:34%; height:22%; background:oklch(1 0 0 / 0.7); border-radius:50%; filter:blur(1px); }
.cup-shadow{ position:absolute; bottom:-26px; left:50%; transform:translateX(-50%); width:230px; height:34px; border-radius:50%; background:oklch(0.45 0.1 250 / 0.28); filter:blur(16px); }

/* condensation droplets */
.drop{ position:absolute; border-radius:50% 50% 50% 50%/ 60% 60% 40% 40%; background:oklch(0.9 0.05 232 / 0.7); box-shadow:inset 0 1px 2px oklch(1 0 0 / 0.8); }

/* HERO TREATMENT: poster (big type, cup behind) */
.hero[data-hero="poster"] .hero-grid{ grid-template-columns:1fr; text-align:center; justify-items:center; }
.hero[data-hero="poster"] .hero-stage{ position:absolute; inset:0; height:100%; opacity:0.9; z-index:0; }
.hero[data-hero="poster"] .hero-copy{ position:relative; z-index:2; }
.hero[data-hero="poster"] h1{ font-size:clamp(3.6rem,13vw,11rem); }
.hero[data-hero="poster"] .hero-sub{ margin-left:auto; margin-right:auto; }
.hero[data-hero="poster"] .hero-cta{ justify-content:center; }
.hero[data-hero="poster"] .hero-stats{ justify-content:center; }
.hero[data-hero="poster"] .cup{ width:300px; height:412px; }

/* HERO TREATMENT: dark deep-freeze */
.hero[data-hero="dark"]{ background:linear-gradient(165deg, var(--navy), var(--navy-2)); margin:0 0 0; color:#fff; border-radius:0 0 48px 48px; }
.hero[data-hero="dark"] .hero-sub{ color:oklch(0.82 0.03 240); }
.hero[data-hero="dark"] h1 .stroke{ -webkit-text-stroke-color:#fff; }
.hero[data-hero="dark"] .hero-badge{ background:oklch(1 0 0 / 0.08); color:#fff; border-color:oklch(1 0 0 / 0.2); }
.hero[data-hero="dark"] .hero-stats .s span{ color:oklch(0.75 0.03 240); }
.hero[data-hero="dark"] .btn-ghost{ background:oklch(1 0 0 / 0.1); color:#fff; border-color:oklch(1 0 0 / 0.22); }

/* marquee strip */
.marquee{ overflow:hidden; padding:22px 0; border-top:1px solid var(--ice-line); border-bottom:1px solid var(--ice-line); background:oklch(1 0 0 / 0.4); backdrop-filter:blur(6px); }
.marquee-track{ display:flex; gap:48px; width:max-content; animation:scroll 26s linear infinite; }
body[data-anim="off"] .marquee-track{ animation:none; }
.marquee-track span{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.5rem; color:var(--ink); display:flex; align-items:center; gap:48px; }
.marquee-track span::after{ content:"❄"; color:var(--accent); font-size:1rem; }
@keyframes scroll{ to{ transform:translateX(-50%);} }

/* ============================ FEATURES ============================ */
.section{ padding:110px 0; position:relative; }
.sec-head{ display:flex; flex-direction:column; gap:16px; align-items:flex-start; margin-bottom:54px; max-width:720px; }
.sec-head.center{ align-items:center; text-align:center; margin-left:auto; margin-right:auto; }
.feat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.feat-card{ position:relative; padding:30px 26px 34px; border-radius:var(--radius); background:oklch(1 0 0 / 0.55); border:var(--glass-stroke); backdrop-filter:blur(16px) saturate(140%); box-shadow:var(--shadow-sm); transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s; overflow:hidden; }
.feat-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.feat-card::before{ content:""; position:absolute; inset:0; background:linear-gradient(160deg, oklch(0.85 0.08 222 / 0.25), transparent 55%); opacity:0; transition:opacity .4s; }
.feat-card:hover::before{ opacity:1; }
.feat-ic{ width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:linear-gradient(150deg, var(--accent-2), var(--accent)); box-shadow:0 10px 24px oklch(0.6 0.19 245 / 0.35); margin-bottom:22px; position:relative; }
.feat-card h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.22rem; position:relative; }
.feat-card p{ color:var(--ink-soft); font-size:0.96rem; margin-top:10px; position:relative; }
.feat-num{ position:absolute; top:20px; right:22px; font-family:var(--font-mono); font-size:0.74rem; color:var(--ink-faint); }

/* ============================ PRODUCTS ============================ */
.prod-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:20px; }
.prod-card{ flex:1 1 240px; max-width:282px; position:relative; display:flex; flex-direction:column; border-radius:var(--radius); background:#fff; box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s; border:1px solid var(--ice-line); }
.prod-card:hover{ transform:translateY(-10px); box-shadow:var(--shadow-lg); }
.prod-media{ position:relative; aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; background:
   linear-gradient(135deg, var(--frost), var(--frost-2));
   overflow:hidden; }
.prod-media .ph-stripes{ position:absolute; inset:0; background:repeating-linear-gradient(45deg, oklch(0.9 0.03 232 / 0.5) 0 12px, transparent 12px 24px); opacity:0.5; }
.prod-img{ position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.prod-card:hover .prod-img{ transform:scale(1.05); }
.prod-tag{ position:absolute; top:14px; left:14px; z-index:3; font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.1em; text-transform:uppercase; font-weight:700; padding:6px 11px; border-radius:999px; background:var(--ink); color:#fff; }
.prod-tag.alt{ background:var(--accent); }
.ph-label{ position:relative; z-index:2; font-family:var(--font-mono); font-size:0.74rem; color:var(--ink-faint); text-align:center; padding:8px 12px; border:1px dashed var(--ice-200); border-radius:10px; background:oklch(1 0 0 / 0.5); }
.prod-info{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:6px; flex:1; }
.prod-info h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:1.18rem; letter-spacing:-0.01em; }
.prod-info p{ color:var(--ink-soft); font-size:0.9rem; min-height:40px; }

/* straws */.straw-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:760px; margin:0 auto; }
.straw-img{ position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.prod-card:hover .straw-img{ transform:scale(1.05); }
.straw-pack{ margin-top:8px; align-self:flex-start; font-family:var(--font-mono); font-size:0.72rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--accent-deep); background:var(--frost-2); padding:6px 12px; border-radius:999px; }
.eco-note{ display:flex; align-items:center; gap:16px; max-width:760px; margin:26px auto 0; padding:18px 24px; border-radius:var(--radius-sm); background:linear-gradient(140deg, oklch(0.95 0.05 165 / 0.6), oklch(0.96 0.03 200 / 0.5)); border:1px solid oklch(0.84 0.07 165 / 0.5); }
.eco-ic{ flex:none; width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:#fff; color:oklch(0.55 0.13 160); box-shadow:var(--shadow-sm); }
.eco-note p{ color:var(--ink-soft); font-size:0.94rem; }
.eco-note p b{ color:oklch(0.42 0.11 160); }
.prod-foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px; padding-top:14px; }
.prod-price{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; letter-spacing:-0.02em; }
.prod-price small{ font-family:var(--font-mono); font-weight:400; font-size:0.7rem; color:var(--ink-faint); display:block; letter-spacing:0.04em; }
.add-btn{ display:flex; align-items:center; gap:8px; padding:12px 18px; border-radius:999px; background:var(--ink); color:#fff; font-weight:700; font-size:0.9rem; transition:transform .2s, background .25s; }
.add-btn:hover{ background:var(--accent); transform:translateY(-2px); }
.add-btn.added{ background:var(--accent-2); }

/* mini ice cup illustration inside product media */
.mini-cup{ position:relative; width:120px; height:158px; z-index:2; filter:drop-shadow(0 18px 22px oklch(0.5 0.1 250 / 0.25)); transition:transform .5s; }
.prod-card:hover .mini-cup{ transform:translateY(-6px) scale(1.04); }
.mini-cup .mc-body{ position:absolute; inset:0; clip-path:polygon(10% 0,90% 0,82% 100%,18% 100%); background:linear-gradient(120deg, oklch(0.99 0.01 230 / 0.7), oklch(0.85 0.07 235 / 0.5)); border:1.4px solid oklch(1 0 0 / 0.75); border-top:none; overflow:hidden; backdrop-filter:blur(2px); }
.mini-cup .mc-rim{ position:absolute; top:-6px; left:50%; transform:translateX(-50%); width:112px; height:22px; border-radius:50%; background:linear-gradient(oklch(0.92 0.04 232), oklch(0.8 0.08 238)); border:1.6px solid oklch(1 0 0 / 0.85); }
.mini-cup .mc-ice{ position:absolute; border-radius:4px; background:linear-gradient(140deg, oklch(0.98 0.015 230 / 0.92), oklch(0.84 0.07 234 / 0.7)); border:1px solid oklch(1 0 0 / 0.7); }

/* ============================ ABOUT ============================ */
.about{ position:relative; }
.about-card{ position:relative; border-radius:var(--radius-lg); overflow:hidden; background:linear-gradient(160deg, var(--navy), var(--navy-2)); color:#fff; padding:clamp(40px,6vw,86px); box-shadow:var(--shadow-lg); }
.about-card .glow{ position:absolute; width:520px; height:520px; border-radius:50%; right:-120px; top:-160px; background:radial-gradient(circle, var(--accent), transparent 65%); opacity:0.45; filter:blur(10px); }
.about-grid{ position:relative; display:grid; grid-template-columns:1fr 0.85fr; gap:48px; align-items:center; }
.about-grid > *{ min-width:0; }
.about-grid h2{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.02em; line-height:0.95; font-size:clamp(2.2rem,4.4vw,3.8rem); }
.about-grid p{ color:oklch(0.85 0.025 240); font-size:1.08rem; margin-top:22px; max-width:48ch; }
.about-stats{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.about-stat b{ overflow-wrap:break-word; }
.about-stat{ padding:24px; border-radius:var(--radius-sm); background:oklch(1 0 0 / 0.07); border:1px solid oklch(1 0 0 / 0.12); backdrop-filter:blur(8px); }
.about-stat b{ font-family:"Space Grotesk", var(--font-display); font-weight:600; font-size:2.4rem; display:block; letter-spacing:-0.02em; background:linear-gradient(120deg,#fff,var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.about-stat span{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:oklch(0.78 0.03 240); }

/* ============================ FAQ ============================ */
.faq{ max-width:860px; margin:0 auto; }
.faq-item{ border:1px solid var(--ice-line); border-radius:var(--radius-sm); background:oklch(1 0 0 / 0.55); backdrop-filter:blur(10px); margin-bottom:14px; overflow:hidden; transition:box-shadow .3s, border-color .3s; }
.faq-item.open{ box-shadow:var(--shadow-md); border-color:oklch(0.78 0.08 240); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:24px 26px; text-align:left; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.06rem; }
.faq-ic{ flex:none; width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--frost-2); transition:transform .4s cubic-bezier(.2,.7,.2,1), background .3s; }
.faq-item.open .faq-ic{ background:var(--accent); transform:rotate(45deg); }
.faq-item.open .faq-ic svg{ stroke:#fff; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s cubic-bezier(.2,.7,.2,1); }
.faq-a-inner{ padding:0 26px 26px; color:var(--ink-soft); font-size:1rem; }

/* ============================ CONTACT ============================ */
.contact-card{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:0; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--ice-line); }
.contact-card > *{ min-width:0; }
.contact-aside{ position:relative; padding:clamp(36px,4vw,56px); background:linear-gradient(160deg, var(--accent-deep), var(--accent)); color:#fff; display:flex; flex-direction:column; justify-content:space-between; overflow:hidden; }
.contact-aside .c-glow{ position:absolute; width:360px; height:360px; border-radius:50%; background:oklch(1 0 0 / 0.16); filter:blur(20px); right:-120px; bottom:-120px; }
.contact-aside h2{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.02em; line-height:0.95; font-size:clamp(2rem,3vw,2.8rem); position:relative; }
.contact-aside p{ position:relative; margin-top:18px; color:oklch(0.95 0.02 235); font-size:1.02rem; max-width:34ch; }
.contact-meta{ position:relative; display:flex; flex-direction:column; gap:14px; margin-top:30px; font-family:var(--font-mono); font-size:0.86rem; }
.contact-meta div{ display:flex; align-items:center; gap:12px; }
.contact-form{ padding:clamp(36px,4vw,56px); background:#fff; display:flex; flex-direction:column; gap:18px; min-width:0; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-row > *{ min-width:0; }
.field-row.plz-ort{ grid-template-columns:0.5fr 1fr; }
@media (max-width:480px){ .field-row{ grid-template-columns:1fr; } .field-row.plz-ort{ grid-template-columns:0.6fr 1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.field label{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-soft); font-weight:700; }
.field label .opt{ color:var(--ink-faint); font-weight:400; text-transform:none; letter-spacing:0; }
.field input, .field textarea{ font-family:var(--font-body); font-size:1rem; padding:15px 18px; border-radius:14px; border:1.5px solid var(--ice-line); background:var(--frost); color:var(--ink); transition:border-color .25s, background .25s, box-shadow .25s; resize:vertical; width:100%; min-width:0; box-sizing:border-box; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--accent); background:#fff; box-shadow:0 0 0 4px oklch(0.6 0.19 245 / 0.12); }
.field.err input, .field.err textarea{ border-color:oklch(0.6 0.2 25); background:oklch(0.97 0.03 25); }
.field .msg{ font-size:0.78rem; color:oklch(0.55 0.2 25); font-weight:600; min-height:0; }
.form-ok{ padding:16px 18px; border-radius:14px; background:oklch(0.95 0.06 160); color:oklch(0.4 0.12 160); font-weight:700; display:flex; align-items:center; gap:10px; font-size:0.95rem; }
.form-err{ padding:16px 18px; border-radius:14px; background:oklch(0.95 0.08 25); color:oklch(0.45 0.2 25); font-weight:600; font-size:0.95rem; }

/* ============================ FOOTER ============================ */
.footer{ position:relative; margin-top:40px; background:linear-gradient(180deg, transparent, oklch(0.95 0.02 235)); padding-top:80px; }
.foot-cta{ text-align:center; max-width:760px; margin:0 auto 70px; }
.foot-cta h2{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.025em; line-height:0.9; font-size:clamp(2.6rem,7vw,6rem); }
.foot-cta h2 .grad{ background:linear-gradient(120deg,var(--accent-2),var(--accent),var(--accent-deep)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.foot-main{ border-top:1px solid var(--ice-line); padding:50px 0 30px; display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; }
.foot-brand .brand{ font-size:1.4rem; }
.foot-brand p{ color:var(--ink-soft); margin-top:14px; font-size:0.92rem; max-width:30ch; }
.foot-col h4{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:16px; }
.foot-col a{ display:block; color:var(--ink-soft); font-size:0.94rem; padding:6px 0; transition:color .2s, transform .2s; }
.foot-col a:hover{ color:var(--accent); transform:translateX(3px); }
.socials{ display:flex; gap:12px; margin-top:20px; }
.socials a{ width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid var(--ice-line); box-shadow:var(--shadow-sm); transition:transform .25s, background .25s, color .25s; }
.socials a:hover{ transform:translateY(-3px); background:var(--accent); color:#fff; }
.foot-bottom{ border-top:1px solid var(--ice-line); padding:24px 0 40px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:0.85rem; color:var(--ink-faint); }
.foot-bottom .legal{ display:flex; gap:24px; }
.foot-bottom a:hover{ color:var(--ink); }

/* ============================ CART DRAWER ============================ */
.scrim{ position:fixed; inset:0; z-index:90; background:oklch(0.2 0.05 250 / 0.4); backdrop-filter:blur(4px); opacity:0; pointer-events:none; transition:opacity .35s; }
.scrim.show{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; bottom:0; z-index:95; width:min(420px,92vw); background:var(--ice-white); box-shadow:-30px 0 80px oklch(0.3 0.1 250 / 0.25); transform:translateX(100%); transition:transform .42s cubic-bezier(.2,.8,.2,1); display:flex; flex-direction:column; }
.drawer.open{ transform:none; }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; padding:26px 26px 18px; border-bottom:1px solid var(--ice-line); }
.drawer-head h3{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:1.3rem; letter-spacing:-0.01em; }
.drawer-close{ width:38px; height:38px; border-radius:50%; background:var(--frost-2); display:flex; align-items:center; justify-content:center; transition:background .2s, transform .2s; }
.drawer-close:hover{ background:var(--ice-line); transform:rotate(90deg); }
.drawer-body{ flex:1; overflow-y:auto; padding:18px 26px; display:flex; flex-direction:column; gap:14px; }
.cart-line{ display:flex; gap:14px; align-items:center; padding:14px; border-radius:18px; background:#fff; border:1px solid var(--ice-line); }
.cart-thumb{ width:62px; height:62px; border-radius:12px; flex:none; background:linear-gradient(135deg,var(--frost),var(--frost-2)); display:flex; align-items:center; justify-content:center; }
.cart-line .cl-info{ flex:1; min-width:0; }
.cart-line .cl-info b{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:0.92rem; display:block; }
.cart-line .cl-info span{ font-family:var(--font-mono); font-size:0.78rem; color:var(--ink-faint); }
.qty{ display:flex; align-items:center; gap:10px; margin-top:8px; }
.qty button{ width:26px; height:26px; border-radius:8px; background:var(--frost-2); font-weight:800; display:flex; align-items:center; justify-content:center; transition:background .2s; color:var(--ink); }
.qty button:hover{ background:var(--accent); color:#fff; }
.qty span{ font-weight:700; min-width:18px; text-align:center; }
.cl-remove{ color:var(--ink-faint); font-size:0.74rem; font-family:var(--font-mono); transition:color .2s; align-self:flex-start; }
.cl-remove:hover{ color:oklch(0.55 0.2 25); }
.cart-empty{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; text-align:center; color:var(--ink-faint); padding:40px; }
.drawer-foot{ padding:22px 26px 26px; border-top:1px solid var(--ice-line); background:#fff; }
.drawer-total{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:16px; }
.drawer-total b{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; letter-spacing:-0.02em; }
.drawer-total span{ font-family:var(--font-mono); font-size:0.74rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-faint); }

/* ============================ FREEZERS ============================ */.freezer-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.freezer-card{ display:flex; flex-direction:column; border-radius:var(--radius); background:#fff; border:1px solid var(--ice-line); box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s; }
.freezer-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.freezer-media{ aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; background:linear-gradient(165deg, oklch(0.94 0.035 232), oklch(0.86 0.07 233)); overflow:hidden; }
.freezer-media img{ width:100%; height:100%; object-fit:contain; }
.freezer-info{ padding:22px 24px 26px; display:flex; flex-direction:column; gap:6px; }
.freezer-info h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.18rem; }
.freezer-dim{ font-family:var(--font-mono); font-size:0.82rem; font-weight:700; color:var(--accent-deep); }
.freezer-info p{ color:var(--ink-soft); font-size:0.92rem; margin-top:4px; }

.freezer-rent{ position:relative; margin-top:24px; display:grid; grid-template-columns:1.1fr 0.9fr; gap:40px; align-items:center; overflow:hidden; padding:clamp(30px,4vw,52px); border-radius:var(--radius-lg); background:linear-gradient(160deg, var(--navy), var(--navy-2)); color:#fff; box-shadow:var(--shadow-lg); }
.rent-glow{ position:absolute; width:440px; height:440px; border-radius:50%; right:-130px; top:-160px; background:radial-gradient(circle, var(--accent), transparent 65%); opacity:0.4; filter:blur(8px); }
.rent-text{ position:relative; }
.rent-eyebrow{ font-family:var(--font-mono); font-size:0.74rem; letter-spacing:0.18em; text-transform:uppercase; font-weight:700; color:var(--accent-2); }
.rent-text h3{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.02em; line-height:0.98; font-size:clamp(1.7rem,2.8vw,2.5rem); margin-top:14px; }
.rent-text p{ color:oklch(0.85 0.025 240); font-size:1.02rem; margin-top:16px; max-width:46ch; }
.rent-text p b{ color:#fff; }
.rent-points{ position:relative; display:flex; flex-direction:column; gap:12px; }
.rent-point{ padding:16px 20px; border-radius:var(--radius-sm); background:oklch(1 0 0 / 0.07); border:1px solid oklch(1 0 0 / 0.12); backdrop-filter:blur(8px); }
.rent-point b{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.02rem; display:block; }
.rent-point span{ font-family:var(--font-mono); font-size:0.74rem; letter-spacing:0.04em; color:oklch(0.78 0.03 240); }
.rent-cta{ margin-top:4px; align-self:flex-start; }

/* ============================ ICE SPEC / 3D CUBE ============================ */
.icespec-grid{ display:grid; grid-template-columns:1fr 0.92fr; gap:40px; align-items:center; }
.cube-stage{ position:relative; height:460px; display:flex; align-items:center; justify-content:center; perspective:1200px; }
.cube-floor{ position:absolute; bottom:54px; left:50%; transform:translateX(-50%); width:290px; height:46px; border-radius:50%; background:radial-gradient(ellipse, oklch(0.5 0.1 250 / 0.28), transparent 70%); filter:blur(8px); animation:floorpulse 5s ease-in-out infinite; }
@keyframes floorpulse{ 0%,100%{ transform:translateX(-50%) scale(1); opacity:0.9; } 50%{ transform:translateX(-50%) scale(0.86); opacity:0.6; } }

.ice3d{ position:relative; width:260px; height:260px; transform-style:preserve-3d; animation:cubefloat3d 5s ease-in-out infinite; }
@keyframes cubefloat3d{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-22px); } }
.ice3d-cube{ position:absolute; inset:0; transform-style:preserve-3d; animation:cubespin 16s linear infinite; }
@keyframes cubespin{ from{ transform:rotateX(-22deg) rotateY(0deg); } to{ transform:rotateX(-22deg) rotateY(360deg); } }
body[data-anim="off"] .ice3d, body[data-anim="off"] .ice3d-cube, body[data-anim="off"] .cube-floor{ animation:none; }
body[data-anim="off"] .ice3d-cube{ transform:rotateX(-22deg) rotateY(-32deg); }

.ice-face{ position:absolute; width:260px; height:260px; border-radius:18px;
  background:linear-gradient(135deg, oklch(0.97 0.02 230 / 0.62), oklch(0.78 0.09 235 / 0.42));
  border:1.5px solid oklch(1 0 0 / 0.6);
  box-shadow:inset 0 8px 22px oklch(1 0 0 / 0.55), inset 0 -16px 30px oklch(0.55 0.1 250 / 0.25);
  backdrop-filter:blur(2px);
}
.ice-face::before{ content:""; position:absolute; left:18%; top:10%; width:24%; height:40%; background:linear-gradient(oklch(1 0 0 / 0.7), transparent); border-radius:40%; filter:blur(3px); }
.ice-face.fz{ transform:translateZ(130px); }
.ice-face.bk{ transform:rotateY(180deg) translateZ(130px); }
.ice-face.rt{ transform:rotateY(90deg) translateZ(130px); background:linear-gradient(135deg, oklch(0.9 0.05 232 / 0.55), oklch(0.66 0.13 245 / 0.45)); }
.ice-face.lf{ transform:rotateY(-90deg) translateZ(130px); background:linear-gradient(135deg, oklch(0.9 0.05 232 / 0.55), oklch(0.66 0.13 245 / 0.45)); }
.ice-face.tp{ transform:rotateX(90deg) translateZ(130px); background:linear-gradient(135deg, oklch(0.99 0.01 230 / 0.78), oklch(0.85 0.06 232 / 0.55)); }
.ice-face.bm{ transform:rotateX(-90deg) translateZ(130px); background:linear-gradient(135deg, oklch(0.72 0.1 245 / 0.5), oklch(0.6 0.15 248 / 0.5)); }
.bub{ position:absolute; border-radius:50%; background:oklch(1 0 0 / 0.65); box-shadow:inset 0 0 3px oklch(0.6 0.1 245 / 0.4); }
.bub.b1{ width:18px; height:18px; left:28%; top:34%; }
.bub.b2{ width:11px; height:11px; left:58%; top:52%; }
.bub.b3{ width:8px; height:8px; left:44%; top:24%; }

/* dimension callouts */
.dim{ position:absolute; z-index:4; font-family:var(--font-mono); }
.dim-label{ position:absolute; font-size:0.78rem; font-weight:700; letter-spacing:0.04em; color:var(--accent-deep); background:oklch(1 0 0 / 0.82); backdrop-filter:blur(4px); padding:3px 9px; border-radius:999px; box-shadow:var(--shadow-sm); white-space:nowrap; }
.dim-line{ position:absolute; background:var(--accent); opacity:0.55; }
.dim-cap{ position:absolute; background:var(--accent); opacity:0.55; }
/* height (left) */
.dim-h{ left:calc(50% - 205px); top:calc(50% - 125px); width:2px; height:250px; }
.dim-h .dim-line{ left:0; top:0; width:2px; height:100%; }
.dim-h .dim-cap{ width:16px; height:2px; left:-7px; }
.dim-h .dim-cap-top{ top:0; }
.dim-h .dim-cap-bot{ bottom:0; }
.dim-h .dim-label{ right:14px; top:50%; transform:translateY(-50%); }
/* width (bottom) */
.dim-w{ left:calc(50% - 125px); bottom:42px; width:250px; height:2px; }
.dim-w .dim-line{ left:0; top:0; width:100%; height:2px; }
.dim-w .dim-cap{ height:16px; width:2px; top:-7px; }
.dim-w .dim-cap-l{ left:0; }
.dim-w .dim-cap-r{ right:0; }
.dim-w .dim-label{ left:50%; top:10px; transform:translateX(-50%); }
/* depth (top-right diagonal) */
.dim-d{ right:calc(50% - 150px); top:calc(50% - 120px); width:74px; height:2px; transform:rotate(-34deg); }
.dim-d .dim-line{ left:0; top:0; width:100%; height:2px; }
.dim-d .dim-label{ left:50%; top:-26px; transform:translateX(-50%) rotate(34deg); }

.weight-chip{ position:absolute; right:calc(50% - 196px); bottom:128px; z-index:5; display:flex; flex-direction:column; align-items:center; gap:2px; padding:14px 20px; border-radius:18px; background:var(--accent); color:#fff; box-shadow:0 14px 34px oklch(0.6 0.19 245 / 0.4); animation:chipfloat 5s ease-in-out infinite; }
@keyframes chipfloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
body[data-anim="off"] .weight-chip{ animation:none; }
.weight-chip b{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; line-height:1; letter-spacing:-0.02em; }
.weight-chip span{ font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; opacity:0.85; }

.spec-list{ display:flex; flex-direction:column; gap:14px; }
.spec-card{ display:flex; align-items:center; gap:22px; padding:22px 24px; border-radius:var(--radius-sm); background:oklch(1 0 0 / 0.55); border:var(--glass-stroke); backdrop-filter:blur(14px); box-shadow:var(--shadow-sm); transition:transform .35s, box-shadow .35s; }
.spec-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.spec-val{ flex:none; width:160px; display:flex; align-items:baseline; gap:5px; }
.spec-val b{ font-family:var(--font-display); font-weight:800; font-size:2.3rem; letter-spacing:-0.03em; line-height:1; color:var(--ink); }
.spec-val span{ font-family:var(--font-mono); font-size:0.86rem; font-weight:700; color:var(--accent); text-transform:uppercase; }
.spec-meta h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.04rem; }
.spec-meta p{ color:var(--ink-soft); font-size:0.9rem; margin-top:3px; }
.spec-note{ display:flex; gap:14px; align-items:flex-start; padding:20px 24px; border-radius:var(--radius-sm); background:linear-gradient(150deg, var(--navy), var(--navy-2)); color:#fff; }
.spec-note .snow{ font-size:1.5rem; color:var(--accent-2); line-height:1; }
.spec-note p{ color:oklch(0.85 0.025 240); font-size:0.92rem; }

/* ============================ PARTNERS / MAP ============================ */
.partners{ overflow-x:clip; }
.partners-grid{ display:grid; grid-template-columns:1.25fr 0.85fr; gap:22px; align-items:stretch; min-height:480px; }
.partners-grid > *{ min-width:0; }
.map-card{ position:relative; max-width:100%; border-radius:var(--radius); background:linear-gradient(160deg, var(--frost), var(--frost-2)); border:var(--glass-stroke); box-shadow:var(--shadow-sm); padding:18px; overflow:hidden; }
.map-stage{ position:relative; width:100%; max-width:100%; height:100%; min-height:440px; overflow:hidden; }
.leaflet-map{ position:absolute; inset:0; width:100%; height:100%; border-radius:calc(var(--radius) - 14px); overflow:hidden; z-index:1; background:linear-gradient(160deg, oklch(0.97 0.012 232), oklch(0.93 0.03 230)); }
.leaflet-container{ font-family:var(--font-body); background:transparent; }
.leaflet-control-zoom{ border:none !important; box-shadow:var(--shadow-sm) !important; border-radius:12px !important; overflow:hidden; margin:14px !important; }
.leaflet-control-zoom a{ background:#fff !important; color:var(--ink) !important; border:none !important; border-bottom:1px solid var(--ice-line) !important; width:34px !important; height:34px !important; line-height:34px !important; font-size:18px !important; font-weight:700; transition:background .2s, color .2s; }
.leaflet-control-zoom a:hover{ background:var(--accent) !important; color:#fff !important; }
.leaflet-bar a:last-child{ border-bottom:none !important; }
.ic-marker{ cursor:pointer; filter:drop-shadow(0 3px 5px oklch(0.4 0.1 250 / 0.3)); }
.leaflet-tooltip.ic-tip{ background:var(--ink); color:#fff; border:none; border-radius:8px; font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.02em; padding:5px 9px; box-shadow:var(--shadow-sm); }
.leaflet-tooltip.ic-tip::before{ border-top-color:var(--ink); border-bottom-color:var(--ink); }
.leaflet-tooltip.ic-tip.ct{ background:var(--accent-deep); font-family:var(--font-display); text-transform:uppercase; font-weight:700; }
.partner-list{ display:flex; flex-direction:column; gap:14px; min-width:0; min-height:0; }
.partner-feature{ border-radius:var(--radius-sm); padding:24px 26px; background:linear-gradient(155deg, var(--accent-deep), var(--accent)); color:#fff; box-shadow:0 14px 34px oklch(0.6 0.19 245 / 0.3); display:flex; flex-direction:column; gap:4px; }
.pf-city{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.16em; text-transform:uppercase; opacity:0.85; }
.pf-name{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-0.01em; font-size:1.35rem; line-height:1.05; }
.pf-type{ font-size:0.9rem; opacity:0.9; }

.partner-controls{ display:flex; gap:10px; }
.search-field{ position:relative; flex:1; display:flex; align-items:center; gap:9px; padding:0 12px 0 14px; border-radius:13px; background:#fff; border:1.5px solid var(--ice-line); transition:border-color .2s, box-shadow .2s; }
.search-field:focus-within{ border-color:var(--accent); box-shadow:0 0 0 4px oklch(0.6 0.19 245 / 0.12); }
.search-field svg{ color:var(--ink-faint); flex:none; }
.search-field input{ flex:1; border:none; background:none; outline:none; font-family:var(--font-body); font-size:0.92rem; padding:12px 0; color:var(--ink); min-width:0; }
.search-clear{ flex:none; width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--ink-faint); background:var(--frost-2); transition:background .2s, color .2s; }
.search-clear:hover{ background:var(--accent); color:#fff; }
.kanton-select{ flex:none; font-family:var(--font-body); font-weight:600; font-size:0.9rem; padding:0 14px; border-radius:13px; border:1.5px solid var(--ice-line); background:#fff; color:var(--ink); cursor:pointer; transition:border-color .2s; }
.kanton-select:focus{ outline:none; border-color:var(--accent); }
.partner-empty{ padding:34px 16px; text-align:center; color:var(--ink-faint); font-size:0.92rem; }

.partner-scroll{ flex:1; display:flex; flex-direction:column; gap:8px; max-height:360px; overflow-y:auto; padding-right:4px; scrollbar-width:thin; }
.partner-row{ display:flex; align-items:center; gap:13px; text-align:left; padding:13px 15px; border-radius:14px; background:#fff; border:1px solid var(--ice-line); transition:border-color .2s, transform .2s, box-shadow .2s; }
.partner-row:hover{ transform:translateX(3px); box-shadow:var(--shadow-sm); }
.partner-row.on{ border-color:var(--accent); box-shadow:0 0 0 3px oklch(0.6 0.19 245 / 0.12); }
.pr-pin{ flex:none; width:11px; height:11px; border-radius:50%; background:#fff; border:3px solid var(--ice-200); transition:border-color .2s; }
.partner-row.on .pr-pin{ border-color:var(--accent); }
.pr-text{ flex:1; min-width:0; display:flex; flex-direction:column; }
.pr-text b{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:0.92rem; letter-spacing:-0.01em; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pr-text span{ font-size:0.8rem; color:var(--ink-faint); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.partner-row svg{ color:var(--ink-faint); flex:none; transition:color .2s, transform .2s; }
.partner-row.on svg, .partner-row:hover svg{ color:var(--accent); transform:translateX(2px); }

.partner-more{ margin-top:4px; display:flex; align-items:center; justify-content:center; gap:10px; width:100%; padding:15px; border-radius:14px; background:var(--ink); color:#fff; font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:0.01em; font-size:0.92rem; transition:background .25s, transform .2s; }
.partner-more:hover{ background:var(--accent); transform:translateY(-2px); }
.partner-more small{ font-family:var(--font-mono); font-weight:400; font-size:0.74rem; letter-spacing:0.04em; opacity:0.85; text-transform:none; }

@media (max-width:860px){
  .partners-grid{ grid-template-columns:1fr; min-height:0; }
  .partner-scroll{ max-height:none; }
  .map-card{ padding:12px; }
  .map-stage{ min-height:380px; }
}
@media (max-width:560px){
  .partner-controls{ flex-wrap:wrap; }
  .search-field{ flex:1 1 100%; }
  .kanton-select{ flex:1 1 100%; padding:13px 14px; }
  .map-stage{ min-height:320px; }
  .partner-feature{ padding:20px 20px; }
}

/* ============================ RESPONSIVE ============================ */
@media (max-width:1080px){
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .prod-grid{ grid-template-columns:repeat(3,1fr); }
  .foot-main{ grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
  .nav-links{ display:none; }
  .nav-cta .cart-btn{ display:none; }
  .nav-burger{ display:flex; }
  .mobile-menu{ display:block; }
  .freezer-grid{ grid-template-columns:1fr; max-width:480px; margin:0 auto; }
  .freezer-rent{ grid-template-columns:1fr; gap:26px; }
  .hero-grid{ grid-template-columns:1fr; gap:10px; }
  .hero-stage{ height:420px; order:-1; }
  .about-grid{ grid-template-columns:1fr; gap:32px; }
  .about-card{ padding:40px 28px; }
  .contact-card{ grid-template-columns:1fr; }
  .icespec-grid{ grid-template-columns:1fr; gap:20px; }
  .cube-stage{ height:400px; }
}
@media (max-width:560px){
  .wrap{ padding:0 18px; }
  .feat-grid{ grid-template-columns:1fr; }
  .prod-grid{ grid-template-columns:repeat(2,1fr); }
  .straw-grid{ grid-template-columns:1fr; max-width:420px; }
  .hero-stats{ gap:22px; flex-wrap:wrap; }
  .about-card{ padding:32px 22px; }
  .about-grid{ gap:26px; }
  .about-stats{ gap:12px; }
  .about-stat{ padding:18px 16px; }
  .about-stat b{ font-size:2rem; }
  .foot-main{ grid-template-columns:1fr; }
  .foot-bottom{ flex-direction:column; align-items:flex-start; }

  /* reCAPTCHA badge ausblenden (Hinweis im Formular sichtbar) */
.grecaptcha-badge{ display:none !important; }
.recaptcha-notice{ font-size:0.72rem; color:var(--ink-soft); margin-top:10px; line-height:1.5; }
.recaptcha-notice a{ color:var(--ink-soft); text-decoration:underline; }

/* ice-cube spec: shrink cube + dimension callouts so nothing overflows */
  .cube-stage{ height:340px; }
  .ice3d{ width:182px; height:182px; }
  .ice-face{ width:182px; height:182px; }
  .ice-face.fz{ transform:translateZ(91px); }
  .ice-face.bk{ transform:rotateY(180deg) translateZ(91px); }
  .ice-face.rt{ transform:rotateY(90deg) translateZ(91px); }
  .ice-face.lf{ transform:rotateY(-90deg) translateZ(91px); }
  .ice-face.tp{ transform:rotateX(90deg) translateZ(91px); }
  .ice-face.bm{ transform:rotateX(-90deg) translateZ(91px); }
  .cube-floor{ width:200px; bottom:64px; }
  .dim-h{ left:calc(50% - 118px); top:calc(50% - 91px); height:182px; }
  .dim-h .dim-label{ right:auto; left:14px; font-size:0.72rem; padding:3px 7px; }
  .dim-w{ left:calc(50% - 91px); width:182px; bottom:58px; }
  .dim-w .dim-label{ font-size:0.72rem; padding:3px 7px; }
  .dim-d{ right:calc(50% - 108px); top:calc(50% - 84px); width:54px; }
  .dim-d .dim-label{ font-size:0.72rem; padding:3px 7px; }
  .weight-chip{ right:calc(50% - 118px); bottom:92px; padding:11px 15px; }
  .weight-chip b{ font-size:1.25rem; }
}
