/* ============================================================
   SEVEN BOWLS — Marken-Theme (v2) über base.css
   Tokens exakt nach work/shared/DESIGN-LANGUAGE.md (Spalte 7bowls).
   Die helle Schwester im Trio: luftig auf Creme, weiße Karten
   mit weicher Schatten-Elevation, Grün als einzige Würze.
   ============================================================ */

/* ---------- Fonts (lokal, woff2) ---------- */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/montserrat-regular.woff2") format("woff2")}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/montserrat-semibold.woff2") format("woff2")}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700 900;font-display:swap;
  src:url("../fonts/montserrat-bold.woff2") format("woff2")}

/* ---------- Marken-Tokens ---------- */
:root{
  --bg:#e7e2dc;
  --bg-2:#efebe5;
  --panel:#ffffff;
  --ink:#1d1d1e;
  --muted:#6d6a64;
  --accent:#616a32;
  --accent-2:#95a55d;
  --grad:linear-gradient(135deg,#95a55d,#616a32);
  --accent-ink:#fff;
  --font-display:'Montserrat';
  --marquee-dur:26s;
  /* Heller Modus: dunkleres Muted für längere Texte (AA) + weiche Schatten */
  --muted-strong:#5d5a54;
  --shadow-1:0 10px 30px -14px rgba(29,29,30,.16);
  --shadow-2:0 26px 56px -20px rgba(29,29,30,.24);
}
.lead,.menu-desc,.check,.sig-ing,.story-copy p,.map-box p,.builder-note,
.contact-side .lead,.gallery-note{color:var(--muted-strong)}

/* Karten: weiß mit Elevation statt dunkler Panel-Optik */
.card{box-shadow:var(--shadow-1)}
.card:hover{box-shadow:var(--shadow-2)}

/* ---------- Nav ---------- */
.nav-logo{display:inline-flex;align-items:center;gap:11px}
.nav-logo img{height:34px;width:auto}
.nav-logo span{font-weight:700;font-size:.88rem;letter-spacing:.2em;color:var(--ink)}
.nav-logo em{font-style:normal;color:var(--accent)}
.nav-links a.btn{padding:11px 20px;font-size:.7rem;opacity:1}
.nav-links a.btn::after{display:none}
.btn-sm{padding:11px 20px;font-size:.72rem}

/* ============================================================
   HERO — Bowl rechts, Text auf der Creme-Freifläche links
   ============================================================ */
.hero{min-height:min(100svh,940px);display:flex;align-items:center;
  padding-block:calc(var(--nav-h) + 42px) clamp(96px,14vh,150px);overflow:clip}
.hero.seam-bottom{padding-bottom:clamp(110px,16vh,170px)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:68% 42%;
  animation:hero-zoom 5s var(--ease) both}
@keyframes hero-zoom{from{transform:scale(1.06)}to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,#e7e2dc 6%,rgba(231,226,220,.82) 30%,rgba(231,226,220,.12) 58%,rgba(231,226,220,0) 74%),
  linear-gradient(180deg,rgba(231,226,220,.4),transparent 26%,transparent 70%,#e7e2dc 100%)}
.hero canvas.fx{z-index:1}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-inner{max-width:600px;display:grid;justify-items:start;gap:18px}
.hero-logo{width:min(215px,46vw);height:auto}
.hero-title{font-size:clamp(2.5rem,6vw,4.3rem)}
.hero-sub{max-width:44ch}
.hero .status-chip{background:color-mix(in srgb,#fff 62%,transparent);
  backdrop-filter:blur(8px);box-shadow:0 8px 22px -10px rgba(29,29,30,.28)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.hero-note{font-size:.78rem;letter-spacing:.06em;color:var(--muted-strong)}
.hero .scroll-cue{bottom:clamp(44px,7vh,72px)}
@media(max-width:760px){
  .hero-bg img{object-position:74% 40%}
  .hero-bg::after{background:
    linear-gradient(90deg,rgba(231,226,220,.95) 0%,rgba(231,226,220,.8) 55%,rgba(231,226,220,.5) 100%),
    linear-gradient(180deg,rgba(231,226,220,.55),transparent 30%,transparent 66%,#e7e2dc 100%)}
}

/* ============================================================
   BOWL-BUILDER — das Herzstück
   ============================================================ */
.builder{background:var(--bg-2)}
.builder-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);
  gap:clamp(28px,4.5vw,60px);margin-top:44px;align-items:start}

.bstep{padding-block:20px;border-top:1px dashed color-mix(in srgb,var(--ink) 16%,transparent)}
.bstep:first-child{border-top:0;padding-top:0}
.bstep-head{display:flex;align-items:baseline;gap:13px;margin-bottom:15px;flex-wrap:wrap}
.step-n{width:30px;height:30px;flex:none;display:grid;place-items:center;align-self:center;
  font-weight:700;font-size:.8rem;color:var(--ink);background:var(--panel);
  box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--ink) 22%,transparent);
  clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px);
  transition:background .3s,color .3s}
.bstep.done .step-n{background:var(--accent);color:#fff;box-shadow:none}
.bstep-head h3{font-size:1.02rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.bstep-hint{font-size:.72rem;font-weight:600;letter-spacing:.1em;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chipbtn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:99px;
  border:1.5px solid color-mix(in srgb,var(--ink) 18%,transparent);background:var(--panel);
  color:var(--ink);font:inherit;font-size:.86rem;font-weight:600;cursor:pointer;
  box-shadow:0 3px 12px -6px rgba(29,29,30,.14);
  transition:transform .3s var(--ease),background .3s,border-color .3s,color .3s,box-shadow .3s,opacity .3s}
.chipbtn small{font-size:.7rem;font-weight:700;color:var(--accent);letter-spacing:.02em}
.chipbtn:hover{border-color:var(--accent);transform:translateY(-2px)}
.chipbtn[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff;
  box-shadow:0 10px 22px -8px rgba(97,106,50,.5)}
.chipbtn[aria-pressed="true"] small{color:#e3e9c8}
.chipbtn[aria-pressed="true"]::before{content:"✓";font-size:.72em;font-weight:700}
.chipbtn.locked{opacity:.38;cursor:not-allowed}
.chipbtn.locked:hover{border-color:color-mix(in srgb,var(--ink) 18%,transparent);transform:none}
.chipbtn.deny{animation:deny .3s var(--ease)}
@keyframes deny{25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

.builder-visual{position:sticky;top:calc(var(--nav-h) + 20px)}
.bowl-stage{position:relative;background:var(--panel);border-radius:var(--radius);
  padding:clamp(20px,2.6vw,30px);box-shadow:var(--shadow-1);
  border:1px solid color-mix(in srgb,var(--ink) 6%,transparent);
  transition:box-shadow .5s var(--ease)}
.bowl-stage.complete{box-shadow:var(--shadow-2),0 0 0 3px color-mix(in srgb,var(--accent-2) 55%,transparent)}
.bowl-stage svg{width:100%;height:auto;display:block}
.bowl-stage.pulse svg{animation:bowlpop .45s var(--ease)}
@keyframes bowlpop{35%{transform:scale(1.02)}}
#bowl-svg .layer{opacity:0;transform:translateY(10px) scale(.86);
  transform-box:fill-box;transform-origin:center;
  transition:opacity .4s var(--ease),transform .5s var(--ease)}
#bowl-svg .layer.on{opacity:1;transform:none}
.builder-total{display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  flex-wrap:wrap;margin-top:16px}
.total-label{display:block;font-size:.66rem;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--muted)}
.total-price{font-weight:800;font-size:clamp(1.9rem,3vw,2.5rem);line-height:1.1;
  font-variant-numeric:tabular-nums;background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.total-hint{font-size:.72rem;color:var(--muted)}
.builder-summary{min-height:2.8em;margin-top:8px;font-size:.86rem;line-height:1.5;
  color:var(--muted-strong);border-top:1px dashed color-mix(in srgb,var(--ink) 14%,transparent);
  padding-top:10px}
.builder-cta{width:100%;justify-content:center;margin-top:12px}
.builder-note{font-size:.74rem;margin-top:10px;text-align:center}

/* Konfetti (grüne Kreise + Blättchen) */
.cfetti{position:absolute;left:50%;top:42%;width:var(--s,9px);height:var(--s,9px);
  border-radius:50%;background:var(--c,#95a55d);pointer-events:none;z-index:5;
  animation:cfetti .95s cubic-bezier(.15,.6,.35,1) forwards}
.cfetti.leaf{border-radius:0 62% 0 62%}
@keyframes cfetti{
  0%{transform:translate(0,0) rotate(0deg) scale(.2);opacity:1}
  18%{transform:translate(calc(var(--dx) * .3),calc(var(--dy) * .45)) rotate(calc(var(--rot) * .3)) scale(1.05);opacity:1}
  100%{transform:translate(var(--dx),calc(var(--dy) + 70px)) rotate(var(--rot)) scale(.85);opacity:0}
}

/* Sticky Preis-Pill (mobil) */
.builder-pill{display:none}
@media(max-width:900px){
  .builder-grid{grid-template-columns:1fr}
  .builder-visual{position:static;order:-1;max-width:460px;margin-inline:auto;width:100%}
  .builder-pill{position:sticky;bottom:16px;z-index:40;display:flex;align-items:center;gap:12px;
    width:fit-content;margin:22px auto 0;padding:12px 24px;border-radius:99px;
    background:var(--grad);color:#fff;font-weight:700;font-size:.95rem;
    box-shadow:0 16px 34px -10px rgba(97,106,50,.55)}
  .builder-pill [data-total]{font-variant-numeric:tabular-nums}
  .pill-label{font-size:.66rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;opacity:.85}
}

/* ============================================================
   SIGNATURE BOWLS + KARTE
   ============================================================ */
.bowls{background:var(--bg)}
.sig-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));
  gap:clamp(18px,2.6vw,30px);margin-top:44px}
.sig-card{padding:0;overflow:hidden}
.sig-card .tilt-inner{display:flex;flex-direction:column;height:100%}
.sig-card figure{position:relative;margin:0;aspect-ratio:4/3;overflow:hidden}
.sig-card figure img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.sig-card:hover figure img{transform:scale(1.07)}
.price-badge{position:absolute;top:14px;right:14px;background:var(--grad);color:#fff;
  font-weight:700;font-size:.85rem;padding:8px 14px;font-variant-numeric:tabular-nums;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.sig-body{padding:20px 22px 24px}
.sig-body h3{font-weight:700;font-size:1.1rem;letter-spacing:.01em}
.sig-ing{font-size:.85rem;margin-top:6px;line-height:1.55}
.menu-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,270px),1fr));
  gap:clamp(22px,3.4vw,42px);margin-top:clamp(40px,6vh,60px)}
.menu-row{flex-wrap:wrap}
.menu-block h3{display:flex;align-items:center;gap:12px;font-size:.76rem;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.menu-block h3::after{content:"";flex:1;height:2px;
  background:color-mix(in srgb,var(--accent) 28%,transparent);transform:skewX(var(--skew))}
.bowls-cta{margin-top:clamp(36px,5vh,52px);display:flex;gap:14px;flex-wrap:wrap}

/* ============================================================
   GALERIE
   ============================================================ */
.gallery{background:var(--bg-2)}
.gallery-strip{margin-top:38px}
.gallery-strip figure{box-shadow:var(--shadow-1)}
.gallery-note{font-size:.72rem;letter-spacing:.08em;margin-top:14px}

/* ============================================================
   STORY
   ============================================================ */
.story{background:var(--bg)}
.story-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);
  gap:clamp(34px,5vw,68px);align-items:center}
.story-media{margin:0;position:relative}
.story-media::before{content:"";position:absolute;inset:-10% -8%;z-index:0;
  background:radial-gradient(50% 50% at 50% 55%,rgba(149,165,93,.28),transparent 70%)}
.story-media .tilt-inner{position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-2)}
.story-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.4}
.story-media figcaption{position:absolute;inset-inline:0;bottom:0;padding:52px 20px 16px;
  font-size:.7rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff;
  background:linear-gradient(transparent,rgba(29,29,30,.72))}
.story-stats{display:flex;gap:clamp(22px,3.6vw,52px);flex-wrap:wrap;margin-top:32px}
.stat{display:grid;gap:4px;justify-items:start}
.stat-num{font-weight:800;font-size:clamp(1.9rem,3.4vw,2.6rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums}
.stat-label{font-size:.66rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   ÖFFNUNGSZEITEN
   ============================================================ */
.hours{background:var(--bg-2)}
.hours-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.hours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,148px),1fr));
  gap:14px;margin-top:40px}
@media(min-width:1080px){.hours-grid{grid-template-columns:repeat(7,1fr)}}
.day-card{position:relative;background:var(--panel);border-radius:14px;padding:18px 16px 16px;
  display:grid;gap:7px;align-content:start;
  border:1px solid color-mix(in srgb,var(--ink) 7%,transparent);
  box-shadow:0 8px 22px -14px rgba(29,29,30,.16)}
.day-name{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.day-time{font-weight:600;font-size:.88rem;line-height:1.6;font-variant-numeric:tabular-nums}
.day-card.closed .day-time{color:var(--muted)}
.day-card.today{border-color:var(--accent);
  box-shadow:0 16px 34px -14px rgba(97,106,50,.4)}
.day-card.today .day-name{color:var(--accent)}
.day-card.today::after{content:"Heute";position:absolute;top:-10px;right:12px;
  background:var(--grad);color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;padding:4px 10px;border-radius:99px}

/* ============================================================
   STANDORT
   ============================================================ */
.location{background:var(--bg)}
.location-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);
  gap:clamp(34px,5vw,64px);align-items:center}
.location address{font-style:normal;font-weight:800;
  font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.35;margin-block:16px 12px}
.location address .acc{color:var(--accent)}
.loc-house{display:inline-flex;align-items:center;gap:10px;margin-block:6px 24px;padding:10px 18px;
  border-radius:99px;background:color-mix(in srgb,var(--accent) 10%,transparent);
  font-size:.8rem;font-weight:600}
.loc-house a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.loc-actions{display:flex;gap:14px;flex-wrap:wrap}
.map-box{position:relative;min-height:380px;border-radius:var(--radius);overflow:hidden;
  display:grid;place-content:center;justify-items:center;gap:18px;text-align:center;
  padding:36px;background:var(--panel);box-shadow:var(--shadow-1);
  border:1px dashed color-mix(in srgb,var(--ink) 22%,transparent)}
.map-box p{font-size:.85rem;max-width:44ch}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact{background:var(--bg-2)}
.contact-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(34px,5vw,64px);align-items:start}
.phone-label{margin-top:26px;font-size:.66rem;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--muted)}
.phone-big{display:inline-block;margin-top:6px;font-weight:800;
  font-size:clamp(1.5rem,2.8vw,2rem);line-height:1.2;transition:color .3s}
.phone-big:hover{color:var(--accent)}
.contact-form{background:var(--panel);border-radius:var(--radius);
  box-shadow:var(--shadow-1);border:1px solid color-mix(in srgb,var(--ink) 6%,transparent);
  padding:clamp(26px,3.6vw,42px)}
.contact-form .field input:focus+label,
.contact-form .field input:not(:placeholder-shown)+label,
.contact-form .field textarea:focus+label,
.contact-form .field textarea:not(:placeholder-shown)+label{background:var(--panel)}
.contact-form .check{margin-block:6px 16px}
.form-note{min-height:1.4em;margin-bottom:14px;font-size:.85rem;font-weight:600;color:var(--accent)}

/* ============================================================
   FOOTER — Watermark + Family-Strip + Fußzeile
   ============================================================ */
.footer{background:var(--bg);padding-top:clamp(44px,8vh,84px)}
.watermark-clip{overflow:hidden}
.family-logos img{height:30px}
.family-logos a:first-child img{height:44px}
.footer-line{border-top:1px solid color-mix(in srgb,var(--ink) 9%,transparent)}
.footer-line .wrap{display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;padding-block:22px;font-size:.78rem;color:var(--muted-strong)}
.footer-line nav{display:flex;gap:20px}
.footer-line a{transition:color .3s}
.footer-line a:hover{color:var(--accent)}

/* ============================================================
   Rechtsseiten (Impressum / Datenschutz)
   ============================================================ */
.legal-main{max-width:860px;margin-inline:auto;padding-inline:var(--pad);
  padding-block:calc(var(--nav-h) + clamp(42px,8vh,84px)) clamp(60px,9vh,100px)}
.legal-main h1{font-weight:800;font-size:clamp(1.9rem,4.2vw,2.9rem);letter-spacing:-.01em;
  margin-bottom:8px}
.legal-main h1::after{content:"";display:block;width:56px;height:3px;margin-top:18px;
  background:var(--grad);transform:skewX(var(--skew))}
.legal-main h2{font-size:1rem;font-weight:700;letter-spacing:.05em;color:var(--accent);
  margin:34px 0 10px}
.legal-main p,.legal-main li{color:var(--muted-strong);font-size:.95rem}
.legal-main strong{color:var(--ink)}
.legal-main ul{padding-left:22px;margin-block:10px}
.legal-main a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;
  transition:color .3s}
.legal-main a:hover{color:var(--accent)}
.placeholder{color:var(--accent);border-bottom:1px dashed var(--accent)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:900px){
  .story-grid,.location-grid,.contact-grid{grid-template-columns:1fr}
  .story-media{max-width:480px;margin-inline:auto;width:100%}
  .map-box{min-height:320px}
}
