/* =====================================================================
   Mixomat — Design-System (§4)
   hell · gelb · offen · energetisch.  Weiß als Grundfläche, Life-Gelb als
   Energie, Schwarz nur als Akzent. Runde Fenster, Diagonal-Schraffur,
   Stempel-Badges, Pill-Buttons, weiche große Rundungen.
   ===================================================================== */

/* ── Selbst gehostete Hausschrift (Poppins) ───────────────────────────
   Lege die woff2-Dateien unter /assets/fonts/ ab (siehe fonts/README.md).
   Fehlen sie, greift der System-Fallback aus --font-family. Über die
   CSS-Variable ist eine lizenzierte Hausschrift später 1:1 tauschbar. */
@font-face{ font-family:"Poppins"; font-style:normal; font-weight:400;
  src:url("/assets/fonts/Poppins-Regular.woff2") format("woff2"); font-display:swap; }
@font-face{ font-family:"Poppins"; font-style:normal; font-weight:500;
  src:url("/assets/fonts/Poppins-Medium.woff2") format("woff2"); font-display:swap; }
@font-face{ font-family:"Poppins"; font-style:normal; font-weight:600;
  src:url("/assets/fonts/Poppins-SemiBold.woff2") format("woff2"); font-display:swap; }
@font-face{ font-family:"Poppins"; font-style:normal; font-weight:700;
  src:url("/assets/fonts/Poppins-Bold.woff2") format("woff2"); font-display:swap; }
@font-face{ font-family:"Poppins"; font-style:normal; font-weight:800;
  src:url("/assets/fonts/Poppins-ExtraBold.woff2") format("woff2"); font-display:swap; }

:root{
  /* Farb-Tokens (§4.1) */
  --life-yellow:      #FFED00;
  --life-yellow-deep: #F2DC00;
  --ink:              #15171C;
  --white:            #FFFFFF;
  --paper:            #FAFAF7;
  --fresh-blue:       #A6CDEA;
  --fresh-blue-deep:  #5B9BD5;
  --mint:             #BFE3C9;
  --drink-color:      #5B9BD5;          /* dynamisch pro Rezept gesetzt */

  --font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --radius:    28px;
  --radius-lg: 40px;
  --shadow:    0 18px 44px rgba(21,23,28,.12);
  --shadow-sm: 0 8px 20px rgba(21,23,28,.10);

  --spring: cubic-bezier(.34,1.56,.64,1);
  --ease:   cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html,body{ margin:0; padding:0; }
body{
  font-family:var(--font-family);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.45;
  overflow-x:hidden;
}

/* ── Bühne + dekorative Shapes ───────────────────────────────────────── */
.stage{
  position:relative;
  min-height:100%;
  display:flex;
  flex-direction:column;
  padding:14px clamp(14px,4vw,28px) 0;
  isolation:isolate;
  overflow:hidden;
}
/* großes gelbes Organic-Shape oben + Diagonal-Schraffur-Akzent */
.stage::before{
  content:""; position:absolute; z-index:-2;
  inset:-30% -20% auto -20%; height:62%;
  background:
    radial-gradient(120% 100% at 70% 0%, var(--life-yellow) 0%, var(--life-yellow) 55%, transparent 72%);
  filter:saturate(1.05);
}
.stage::after{
  content:""; position:absolute; z-index:-1; pointer-events:none;
  right:-40px; bottom:-40px; width:240px; height:240px; opacity:.5;
  background:repeating-linear-gradient(45deg, var(--life-yellow-deep) 0 6px, transparent 6px 18px);
  -webkit-mask:radial-gradient(circle at 100% 100%, #000 60%, transparent 62%);
          mask:radial-gradient(circle at 100% 100%, #000 60%, transparent 62%);
}

/* ── Topbar / Brand ──────────────────────────────────────────────────── */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:4px 2px 8px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand__logo{
  width:42px; height:42px; border-radius:50%;
  background:var(--ink); display:grid; place-items:center; flex:0 0 auto;
}
.brand__dot{ width:16px; height:16px; border-radius:50%; background:var(--life-yellow); }
.brand__text{ display:flex; flex-direction:column; line-height:1.05; }
.brand__text strong{ font-weight:800; font-size:1.15rem; letter-spacing:-.01em; }
.brand__text em{ font-style:normal; font-size:.72rem; opacity:.72; font-weight:600; }

.icon-btn{
  border:0; background:var(--white); width:42px; height:42px; border-radius:50%;
  box-shadow:var(--shadow-sm); cursor:pointer; font-size:1.1rem; line-height:1;
  display:grid; place-items:center;
}
.icon-btn .sfx-on{ display:none; }
.icon-btn[aria-pressed="true"] .sfx-on{ display:block; }
.icon-btn[aria-pressed="true"] .sfx-off{ display:none; }

/* ── Main / Screens ──────────────────────────────────────────────────── */
.main{ flex:1 0 auto; display:flex; flex-direction:column; padding:8px 0 20px; }
.screen{ display:none; animation:screenIn .4s var(--spring) both; }
.screen.is-active{ display:block; }
@keyframes screenIn{ from{ opacity:0; transform:translateY(14px) scale(.99); } to{ opacity:1; transform:none; } }

.step-head{ display:flex; align-items:center; gap:10px; margin:6px 0 4px; }
.step-title{ font-size:clamp(1.4rem,5vw,1.9rem); font-weight:800; margin:0; letter-spacing:-.01em; }
.step-sub{ margin:0 0 14px; opacity:.72; }

/* ── Buttons (§4.3) ──────────────────────────────────────────────────── */
.btn{
  font-family:inherit; font-weight:600; font-size:1rem; cursor:pointer;
  border:0; border-radius:999px; padding:14px 24px; line-height:1.1;
  transition:transform .18s var(--spring), box-shadow .2s var(--ease), background .2s;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.btn:active{ transform:scale(.96); }
.btn--lg{ padding:18px 30px; font-size:1.1rem; }
.btn--block{ display:flex; width:100%; }
.btn--primary{ background:var(--life-yellow); color:var(--ink); font-weight:700;
  box-shadow:0 12px 26px rgba(242,220,0,.45); }
.btn--primary:hover{ box-shadow:0 16px 32px rgba(242,220,0,.55); transform:translateY(-2px); }
.btn--yellow{ background:var(--life-yellow); color:var(--ink); font-weight:700; }
.btn--outline{ background:var(--white); color:var(--ink); border:2px solid var(--ink); }
.btn--ghost{ background:transparent; color:var(--ink); padding:8px 12px; font-size:1.3rem; }
.btn--back{ width:44px; height:44px; border-radius:50%; background:var(--white); box-shadow:var(--shadow-sm); }

/* ── Stempel-Badge (§4.3) ────────────────────────────────────────────── */
.badge-stamp{
  display:inline-block; background:var(--ink); color:var(--life-yellow);
  font-weight:800; text-transform:uppercase; letter-spacing:.02em;
  font-size:.8rem; padding:10px 16px; border-radius:999px;
  transform:rotate(-4deg);
}

/* ── HERO ────────────────────────────────────────────────────────────── */
.hero{ text-align:center; padding:18px 4px 30px; max-width:560px; margin:0 auto; }
.hero__stamp{ margin-bottom:18px; }
.hero__title{ font-size:clamp(2rem,9vw,3.2rem); font-weight:800; line-height:1.05;
  letter-spacing:-.02em; margin:.2em 0 .4em; }
.hero__title .hl{ background:var(--ink); color:var(--life-yellow); padding:0 .18em;
  border-radius:.14em; display:inline-block; transform:rotate(-1.5deg); }
.hero__sub{ font-size:1.08rem; opacity:.8; margin:0 auto 28px; max-width:30ch; }
.hero__hint{ font-size:.85rem; opacity:.6; margin-top:16px; }

/* ── Mood-Tiles (§4.3) ───────────────────────────────────────────────── */
.tiles{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:12px; }
.tile{
  border:0; background:var(--white); border-radius:var(--radius); padding:22px 14px;
  text-align:center; cursor:pointer; box-shadow:var(--shadow-sm);
  transition:transform .2s var(--spring), box-shadow .2s var(--ease), background .2s;
  display:flex; flex-direction:column; align-items:center; gap:8px; min-height:118px; justify-content:center;
}
.tile:hover{ transform:translateY(-3px) scale(1.02); box-shadow:var(--shadow); }
.tile:active{ transform:scale(.97); }
.tile.is-selected{ background:var(--life-yellow); }
.tile__icon{ font-size:2.1rem; line-height:1; }
.tile__label{ font-weight:600; font-size:.98rem; }

/* ── Zutaten-Chips ───────────────────────────────────────────────────── */
.chips{ display:flex; flex-wrap:wrap; gap:10px; margin:6px 0 18px; }
.chip{
  border:2px solid var(--ink); background:var(--white); color:var(--ink);
  border-radius:999px; padding:9px 16px; font-weight:600; font-size:.95rem; cursor:pointer;
  transition:transform .16s var(--spring), background .18s, color .18s;
}
.chip:active{ transform:scale(.94); }
.chip.is-on{ background:var(--ink); color:var(--life-yellow); }
.chip__x{ opacity:.6; margin-left:6px; }

.freetext{ display:flex; gap:10px; margin-bottom:18px; }
.freetext__input{
  flex:1; border:2px solid #e4e2d8; border-radius:999px; padding:13px 18px;
  font:inherit; background:var(--white);
}
.freetext__input:focus{ outline:none; border-color:var(--ink); }

/* ── Toggles ─────────────────────────────────────────────────────────── */
.toggle{ display:flex; align-items:center; gap:14px; cursor:pointer; padding:14px 16px;
  background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-sm); margin-bottom:14px; }
.toggle input{ position:absolute; opacity:0; width:0; height:0; }
.toggle__track{ width:52px; height:30px; border-radius:999px; background:#dcdad0; position:relative;
  flex:0 0 auto; transition:background .2s var(--ease); }
.toggle__thumb{ position:absolute; top:3px; left:3px; width:24px; height:24px; border-radius:50%;
  background:var(--white); box-shadow:0 2px 6px rgba(0,0,0,.2); transition:transform .25s var(--spring); }
.toggle input:checked + .toggle__track{ background:var(--ink); }
.toggle input:checked + .toggle__track .toggle__thumb{ transform:translateX(22px); }
.toggle input:focus-visible + .toggle__track{ outline:3px solid var(--fresh-blue-deep); outline-offset:2px; }
.toggle__label{ font-weight:600; line-height:1.2; }
.toggle__label em{ display:block; font-style:normal; font-weight:500; font-size:.8rem; opacity:.62; }

/* ── Optionen / Slider ───────────────────────────────────────────────── */
.options{ background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-sm);
  margin-bottom:18px; overflow:hidden; }
.options__summary{ cursor:pointer; padding:15px 18px; font-weight:700; list-style:none; }
.options__summary::-webkit-details-marker{ display:none; }
.options__summary::after{ content:"⌄"; float:right; transition:transform .2s; }
.options[open] .options__summary::after{ transform:rotate(180deg); }
.options__body{ padding:4px 18px 18px; }
.option-row{ display:flex; align-items:center; gap:14px; margin:6px 0 18px; }
.option-label{ font-weight:600; flex:0 0 auto; }
.option-out{ font-weight:700; min-width:54px; text-align:right; color:var(--fresh-blue-deep); }
.slider{ -webkit-appearance:none; appearance:none; flex:1; height:8px; border-radius:999px;
  background:linear-gradient(90deg,var(--fresh-blue),var(--fresh-blue-deep)); }
.slider::-webkit-slider-thumb{ -webkit-appearance:none; width:26px; height:26px; border-radius:50%;
  background:var(--ink); cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.3); }
.slider::-moz-range-thumb{ width:26px; height:26px; border:0; border-radius:50%; background:var(--ink); cursor:pointer; }

/* ── Mixer / Shaker / Meter (§5) ─────────────────────────────────────── */
.mixer{ text-align:center; max-width:460px; margin:0 auto; padding:14px 0 30px; }
.mixer__hint{ display:flex; flex-direction:column; align-items:center; gap:6px; margin-bottom:14px; min-height:96px; }
.mixer__hint p{ margin:0; }
.mixer__hint .muted{ opacity:.6; font-size:.9rem; }
.phone-shake{ font-size:2.6rem; display:inline-block; animation:phoneWiggle 1.1s var(--ease) infinite; }
@keyframes phoneWiggle{ 0%,100%{ transform:rotate(-12deg); } 50%{ transform:rotate(12deg); } }

.shaker{ height:190px; display:grid; place-items:center; margin:4px 0 10px; }
.shaker__svg{ width:120px; height:180px; transform-origin:50% 90%; }
.shaker__cap{ fill:var(--ink); }
.shaker__body{ fill:var(--fresh-blue-deep); }
.shaker__sheen{ fill:rgba(255,255,255,.35); }
.shaker.is-shaking .shaker__svg{ animation:shakeIt .28s linear infinite; }
@keyframes shakeIt{
  0%{ transform:translate(0,0) rotate(0); } 25%{ transform:translate(-7px,2px) rotate(-9deg); }
  50%{ transform:translate(0,-3px) rotate(0); } 75%{ transform:translate(7px,2px) rotate(9deg); }
  100%{ transform:translate(0,0) rotate(0); }
}

.meter{ position:relative; height:54px; background:var(--white); border-radius:999px;
  box-shadow:inset 0 0 0 3px var(--ink); overflow:hidden; margin:10px 0 22px; }
.meter__fill{ position:absolute; inset:0 100% 0 0;
  background:linear-gradient(90deg,var(--life-yellow),var(--life-yellow-deep));
  transition:right .12s var(--ease); }
.meter__label{ position:relative; z-index:1; line-height:54px; font-weight:800; letter-spacing:.02em;
  text-transform:uppercase; font-size:.95rem; }

/* Stempel-Button „MIX!" (runder Ink-Kreis, gelber Text) */
.stamp-btn{
  width:170px; height:170px; border-radius:50%; border:0; cursor:pointer;
  background:var(--ink); color:var(--life-yellow); font-weight:800; font-size:1.8rem;
  letter-spacing:.04em; text-transform:uppercase; margin:6px auto 0; display:block;
  box-shadow:0 14px 30px rgba(21,23,28,.4);
  transition:transform .12s var(--spring), box-shadow .2s;
  position:relative;
}
.stamp-btn::after{ content:""; position:absolute; inset:10px; border-radius:50%;
  border:3px dashed rgba(255,237,0,.5); }
.stamp-btn:active{ transform:scale(.9); box-shadow:0 6px 16px rgba(21,23,28,.4); }
.stamp-btn.pulse{ animation:stampPulse .9s var(--ease) infinite; }
@keyframes stampPulse{ 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.05); } }

/* ── Result-Card ─────────────────────────────────────────────────────── */
.card{ background:var(--white); border-radius:var(--radius-lg); box-shadow:var(--shadow);
  padding:26px clamp(18px,5vw,30px) 30px; max-width:560px; margin:0 auto; }
.result__stamp{ position:relative; top:-6px; }
.result__visual{ display:grid; place-items:center; margin:6px 0 14px; }
.window{ width:200px; height:200px; border-radius:50%; background:var(--fresh-blue);
  display:grid; place-items:center; position:relative; overflow:visible;
  box-shadow:inset 0 0 0 6px rgba(255,255,255,.4); }

/* Optionales KI-Cocktailbild im runden Fenster */
.window__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  border-radius:50%; box-shadow:inset 0 0 0 6px rgba(255,255,255,.4); }

/* Glas-SVG + Liquid-Fill */
.glass{ width:150px; height:200px; overflow:visible; }
.glass__outline{ fill:none; stroke:var(--ink); stroke-width:6; stroke-linejoin:round; }
.glass__liquid{ fill:var(--drink-color);
  transform:translateY(calc((1 - var(--fill,0)) * 205px));
  transition:transform 1.1s var(--spring); }
.glass__wave{ fill:var(--drink-color); opacity:.8;
  transform:translateY(calc((1 - var(--fill,0)) * 205px));
  transition:transform 1.1s var(--spring); }
.glass__straw{ stroke:var(--ink); stroke-width:7; stroke-linecap:round; }
.glass__garnish{ fill:var(--life-yellow-deep); stroke:var(--ink); stroke-width:4; opacity:.95; }

.result__name{ text-align:center; font-size:clamp(1.6rem,6vw,2.2rem); font-weight:800;
  letter-spacing:-.01em; margin:.1em 0; line-height:1.1; }
.result__tagline{ text-align:center; opacity:.75; margin:0 0 16px; font-size:1.05rem; }

.result__meta{ list-style:none; display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
  padding:0; margin:0 0 20px; }
.result__meta li{ background:var(--paper); border:1.5px solid #e7e5da; border-radius:999px;
  padding:6px 13px; font-size:.85rem; font-weight:600; }
.result__meta li.is-alc{ background:var(--ink); color:var(--life-yellow); border-color:var(--ink); }

.result__cols{ display:grid; gap:18px; margin-bottom:14px; }
@media(min-width:480px){ .result__cols{ grid-template-columns:1fr 1fr; } }
.result__block h3{ font-size:1rem; margin:0 0 8px; text-transform:uppercase; letter-spacing:.03em; opacity:.6; }
.ing-list,.step-list{ margin:0; padding-left:1.1em; }
.ing-list{ list-style:none; padding:0; }
.ing-list li{ display:flex; justify-content:space-between; gap:10px; padding:5px 0;
  border-bottom:1px dashed #e7e5da; font-size:.95rem; }
.ing-list li .amt{ opacity:.6; white-space:nowrap; }
.step-list li{ padding:4px 0; font-size:.95rem; }

.result__flavor{ font-style:italic; background:var(--paper); border-radius:18px; padding:12px 16px;
  margin:6px 0 16px; text-align:center; }

.listen{ display:flex; align-items:center; gap:14px; background:var(--life-yellow);
  border-radius:18px; padding:14px 16px; margin-bottom:14px; flex-wrap:wrap; }
.listen__icon{ font-size:1.6rem; }
.listen__text{ display:flex; flex-direction:column; line-height:1.25; flex:1; min-width:150px; }
.listen__text strong{ font-weight:700; }
.listen__text em{ font-style:normal; opacity:.75; font-size:.92rem; }
.listen__cta{ background:var(--ink); color:var(--life-yellow); padding:12px 20px;
  white-space:nowrap; box-shadow:none; }
.listen__cta:hover{ transform:translateY(-2px); box-shadow:0 10px 22px rgba(21,23,28,.3); }

.responsible{ font-size:.85rem; background:#fff4cc; border:1px solid #f0df8a; border-radius:14px;
  padding:10px 14px; margin:0 0 14px; text-align:center; }

.rate{ display:flex; align-items:center; gap:10px; justify-content:center; margin:6px 0 20px; flex-wrap:wrap; }
.rate__q{ font-weight:600; opacity:.8; }
.rate__btn{ border:0; background:var(--paper); width:52px; height:52px; border-radius:50%;
  font-size:1.4rem; cursor:pointer; box-shadow:var(--shadow-sm); transition:transform .16s var(--spring); }
.rate__btn:hover{ transform:scale(1.12); }
.rate__btn.is-picked{ background:var(--life-yellow); }
.rate__thanks{ font-weight:700; }

.result__actions{ display:grid; gap:10px; }

/* ── Modal ───────────────────────────────────────────────────────────── */
.modal{ position:fixed; inset:0; z-index:50; display:grid; place-items:center;
  background:rgba(21,23,28,.55); padding:20px; animation:fade .2s var(--ease) both; }
.modal[hidden]{ display:none; }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }
.modal__box{ background:var(--white); border-radius:var(--radius); padding:26px; max-width:420px; width:100%;
  box-shadow:var(--shadow); position:relative; animation:screenIn .3s var(--spring) both; text-align:center; }
.modal__box h3{ margin:0 0 10px; font-size:1.3rem; font-weight:800; }
.modal__box p{ margin:0 0 18px; opacity:.8; }
.modal__actions{ display:flex; gap:10px; justify-content:center; }
.modal__close{ position:absolute; top:12px; right:12px; border:0; background:var(--paper);
  width:36px; height:36px; border-radius:50%; cursor:pointer; font-size:1rem; }
.share-preview{ width:auto; max-width:240px; max-height:46vh; border-radius:20px; margin:6px auto 18px;
  display:block; box-shadow:var(--shadow-sm); background:var(--life-yellow); aspect-ratio:9/16; }
.share-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.share-grid .btn{ width:100%; }
.share-grid .btn--wide{ grid-column:1 / -1; }

/* ── Footer ──────────────────────────────────────────────────────────── */
.footer{ flex:0 0 auto; text-align:center; padding:16px 4px 22px; font-size:.78rem; opacity:.6; }
.footer a{ color:inherit; }

/* ── Konfetti-Overlay ────────────────────────────────────────────────── */
.confetti{ position:fixed; inset:0; width:100%; height:100%; pointer-events:none; z-index:40; }

/* ── Accessibility / Reduced Motion ──────────────────────────────────── */
:focus-visible{ outline:3px solid var(--fresh-blue-deep); outline-offset:2px; border-radius:6px; }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; }
  .screen{ animation:none; }
  .glass__liquid,.glass__wave{ transition:none; }
}
