/* ============================================================
   PIZZERIA VITA MIA — Marken-Theme (v2) über base.css
   Tokens exakt nach work/shared/DESIGN-LANGUAGE.md (Spalte vitamia)
   Dunkle Steinofen-Romantik: Glut, Feuer, Passione.
   ============================================================ */

/* ---------- Fonts (lokal, woff2) ---------- */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/montserrat-400.woff2") format("woff2")}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/montserrat-600.woff2") format("woff2")}
/* kein 800er Schnitt instanziert → 700 deckt 700–800 ab (kein Faux-Bold) */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700 800;font-display:swap;
  src:url("../fonts/montserrat-700.woff2") format("woff2")}
@font-face{font-family:'Yellowtail';font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/yellowtail-400.woff2") format("woff2")}

/* ---------- Marken-Tokens ---------- */
:root{
  --bg:#0f0f0f;
  --bg-2:#181818;
  --panel:#1c1c1c;
  --ink:#f5efe8;
  --muted:#b5aca2;
  --accent:#f17021;
  --accent-2:#fca048;
  --grad:linear-gradient(135deg,#fca048,#d94f0a);
  --accent-ink:#fff;
  --font-display:'Montserrat';
  --font-accent:'Yellowtail';
  --marquee-dur:24s;
}

/* Akzentschrift — NUR als Würze (Eyebrow-Alternative, Zitat, Unterzeile) */
.script{font-family:var(--font-accent),cursive;font-weight:400;text-transform:none;
  letter-spacing:.02em;color:var(--accent-2)}

/* ---------- Nav: Icon + Wortmarke ---------- */
.nav-logo{display:inline-flex;align-items:center;gap:12px}
.nav-logo img{height:32px}
.nav-logo span{font-weight:800;font-size:.92rem;letter-spacing:.2em}
.nav-logo em{font-style:normal;color:var(--accent)}
.nav-cta{padding:11px 20px;font-size:.7rem}
@media(max-width:860px){.nav-cta{padding:15px 30px;font-size:.82rem}}

/* ============================================================
   HERO — der Ofen rechts, Text links, Glut überall
   ============================================================ */
.hero{min-height:min(100svh,1080px);display:flex;align-items:center;
  padding-block:calc(var(--nav-h) + 40px) 110px;overflow:clip}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:66% 44%;
  animation:hero-zoom 6s var(--ease) both}
@keyframes hero-zoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(15,15,15,.9) 8%,rgba(15,15,15,.45) 46%,rgba(15,15,15,0) 72%),
  linear-gradient(180deg,rgba(15,15,15,.6),rgba(15,15,15,0) 26%,rgba(15,15,15,0) 62%,#0f0f0f 99%)}
.hero canvas.fx{z-index:1}
.hero .wrap{position:relative;z-index:2;display:grid;justify-items:start;gap:18px;width:100%}
.hero .status-chip{backdrop-filter:blur(6px);
  background:color-mix(in srgb,var(--accent) 15%,rgba(15,15,15,.55))}
.hero-logo{width:min(320px,58vw);height:auto;
  filter:drop-shadow(0 16px 46px rgba(0,0,0,.7))}
.hero-title{font-size:clamp(2.5rem,6.4vw,4.7rem);line-height:1.04;text-wrap:balance;
  max-width:12ch;margin-top:2px}
.hero-title .acc{text-shadow:0 0 44px rgba(241,112,33,.55)}
.hero-script{font-size:clamp(1.45rem,3vw,2.15rem);line-height:1.3;min-height:1.45em;
  text-shadow:0 2px 22px rgba(0,0,0,.6)}
.tw-caret{display:inline-block;width:2px;height:.92em;margin-left:5px;vertical-align:-.1em;
  background:var(--accent-2);animation:caret-blink 1.05s steps(1,end) infinite}
@keyframes caret-blink{50%{opacity:0}}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}

/* ============================================================
   GIMMICK „OFEN-GLOW" — Restwärme, die mit der Scroll-Tiefe atmet
   (site.js koppelt --glow an den Scroll-Fortschritt)
   ============================================================ */
.oven-glow{position:fixed;left:50%;bottom:-14vh;translate:-50%;z-index:40;
  width:min(130vw,1200px);height:36vh;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(50% 100% at 50% 100%,
    rgba(252,160,72,.5),rgba(217,79,10,.22) 46%,transparent 74%);
  opacity:var(--glow,0);transition:opacity .8s var(--ease);
  animation:glow-breathe 4.6s ease-in-out infinite}
@keyframes glow-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.12,1.22)}}
@media(prefers-reduced-motion:reduce){.oven-glow{animation:none;opacity:.22}}

/* ============================================================
   SPEISEKARTE — Tabs mit gleitendem Indikator + Menü-Zeilen
   ============================================================ */
.menu-section{background:var(--bg-2)}
.section-head{display:grid;gap:6px;justify-items:start;margin-bottom:clamp(28px,4vw,44px)}
.section-head.center{justify-items:center;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head .script{font-size:clamp(1.5rem,2.6vw,2rem)}
.section-head .lead{margin-top:8px}
.menu-tabs{position:relative;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
  margin-bottom:clamp(28px,4vw,42px);padding-bottom:6px}
.menu-tab{background:transparent;border:1px solid color-mix(in srgb,var(--ink) 16%,transparent);
  color:var(--muted);font:inherit;font-size:.72rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;padding:10px 18px;border-radius:99px;cursor:pointer;
  transition:color .3s,border-color .3s,background .3s}
.menu-tab:hover{color:var(--ink);border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
.menu-tab.active{color:var(--accent-ink);background:color-mix(in srgb,var(--accent) 22%,transparent);
  border-color:var(--accent)}
.tab-ind{position:absolute;left:0;top:0;width:1px;height:3px;border-radius:3px;
  background:var(--grad);transform-origin:0 0;opacity:0;
  transition:transform .5s var(--ease),opacity .3s}
.tab-ind.on{opacity:1}
.menu-panel{max-width:840px;margin-inline:auto}
.menu-panel[hidden]{display:none}
.menu-row{flex-wrap:wrap}
.menu-note{margin-top:34px;text-align:center;color:var(--muted);font-size:.9rem}
.menu-note a{color:var(--accent);font-weight:600;white-space:nowrap;
  border-bottom:1px solid color-mix(in srgb,var(--accent) 45%,transparent);
  transition:border-color .3s,color .3s}
.menu-note a:hover{color:var(--accent-2);border-color:var(--accent-2)}

/* ============================================================
   GALERIE — Einblicke
   ============================================================ */
.gallery-section{background:var(--bg)}
.gallery-hint{margin-top:16px;text-align:center;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted)}

/* ============================================================
   STORY — Familienbetrieb, Teig & Feuer
   ============================================================ */
.story{background:var(--bg-2)}
.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:-14% -10%;z-index:0;
  background:radial-gradient(50% 50% at 50% 60%,rgba(241,112,33,.18),transparent 70%)}
.story-media .tilt-inner{position:relative;border-radius:var(--radius);overflow:hidden;
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);
  box-shadow:0 36px 90px -26px rgba(0,0,0,.85)}
.story-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.5}
.story-media figcaption{position:absolute;inset-inline:0;bottom:0;padding:54px 20px 16px;
  font-size:.7rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.8))}
.story-copy p{margin-bottom:14px}
.story-quote{margin:26px 0 4px;font-size:clamp(1.35rem,2.4vw,1.8rem);line-height:1.45}
.story-stats{display:flex;gap:clamp(22px,3.8vw,52px);flex-wrap:wrap;margin-top:30px}
.stat{display:grid;gap:4px;justify-items:start}
.stat-num{font-weight:800;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums}
.stat-label{font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted)}

/* ============================================================
   ÖFFNUNGSZEITEN — Karten-Grid, heutiger Tag glüht
   ============================================================ */
.hours{background:var(--bg)}
.hours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr));
  gap:16px;margin-top:8px}
.hours-card{padding:24px 22px;text-align:center;display:grid;gap:10px;align-content:start}
.hours-day{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-2)}
.hours-time{display:grid;gap:4px;font-weight:600;font-size:1.02rem;
  font-variant-numeric:tabular-nums}
.hours-card.closed-day .hours-day{color:var(--muted)}
.hours-card.closed-day .hours-time{color:var(--muted);font-weight:400;font-style:italic}
.hours-card.today{border-color:var(--accent);
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 13%,var(--panel)),var(--panel));
  box-shadow:0 18px 50px -18px rgba(241,112,33,.45)}
.hours-card.today::after{content:"Heute";position:absolute;top:-11px;left:50%;translate:-50%;
  padding:4px 14px;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-ink);background:var(--grad);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.hours-status{display:grid;justify-items:center;margin-top:34px;gap:14px}
.hours-note{text-align:center;color:var(--muted);font-size:.85rem}

/* ============================================================
   STANDORT — Click-to-Load-Karte
   ============================================================ */
.location{background:var(--bg-2)}
.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.45rem,2.6vw,2.05rem);line-height:1.3;margin-block:18px 14px}
.location address .acc{color:var(--accent)}
.location .lead{margin-bottom:26px}
.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:color-mix(in srgb,var(--panel) 80%,transparent);
  border:1px dashed color-mix(in srgb,var(--ink) 22%,transparent)}
.map-box p{color:var(--muted);font-size:.86rem;max-width:44ch}

/* ============================================================
   RESERVIERUNG
   ============================================================ */
.reserve{background:var(--bg)}
.reserve-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(34px,5vw,64px);align-items:start}
.reserve-side .script{display:block;font-size:clamp(1.5rem,2.6vw,2rem);margin-bottom:6px}
.reserve-side p{margin-bottom:14px}
.phone-label{margin-top:24px;font-size:.68rem;font-weight:600;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,2.1rem);line-height:1.2;transition:color .3s}
.phone-big:hover{color:var(--accent)}
.phone-hint{display:block;margin-top:10px;color:var(--muted);font-size:.82rem}
.reserve-form{background:var(--panel);border-radius:var(--radius);
  border:1px solid color-mix(in srgb,var(--ink) 8%,transparent);
  padding:clamp(26px,3.6vw,42px)}
.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0 16px}
.reserve-form .field input:focus+label,
.reserve-form .field input:not(:placeholder-shown)+label,
.reserve-form .field textarea:focus+label,
.reserve-form .field textarea:not(:placeholder-shown)+label{background:var(--panel)}
/* Datum/Uhrzeit/Select: Label dauerhaft oben (kein :placeholder-shown möglich) */
.field.static label{top:-9px;left:12px;font-size:.68rem;letter-spacing:.08em;
  color:var(--accent);background:var(--panel);padding-inline:6px}
.field select{appearance:none;background-image:
  linear-gradient(45deg,transparent 49%,var(--muted) 50%,transparent 60%),
  linear-gradient(-45deg,transparent 49%,var(--muted) 50%,transparent 60%);
  background-position:calc(100% - 22px) 55%,calc(100% - 16px) 55%;
  background-size:7px 7px;background-repeat:no-repeat;cursor:pointer}
.field input[type=date],.field input[type=time]{color-scheme:dark}
.reserve-form .check{margin-block:6px 16px}
.form-note{min-height:1.4em;margin-bottom:14px;font-size:.85rem;color:var(--accent-2)}

/* ============================================================
   FOOTER — Watermark + Family-Strip + Fußzeile
   ============================================================ */
.footer{background:var(--bg-2);padding-top:clamp(46px,8vh,86px)}
.watermark-clip{overflow:hidden}
.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)}
.footer-line nav{display:flex;gap:20px;flex-wrap:wrap}
.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);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,.reserve-grid{grid-template-columns:1fr}
  .story-media{max-width:480px;margin-inline:auto}
  .map-box{min-height:320px}
  .form-row{grid-template-columns:1fr 1fr}
  .form-row .field:first-child{grid-column:1/-1}
}
@media(max-width:560px){
  .hero{padding-bottom:96px}
  .hero-bg img{object-position:70% 42%}
  .menu-tabs{gap:8px}
  .menu-tab{font-size:.66rem;padding:9px 14px;letter-spacing:.09em}
  .form-row{grid-template-columns:1fr}
}
