/* NENNA — Haupt-Stylesheet (asynchron geladen). SION: Handwerk, A11y, Performance. */

/* Header verdichtet sich beim Scrollen */
.site-header.is-scrolled .header-inner{box-shadow:0 6px 24px rgba(33,30,24,.12)}
.intro-line{display:flex;align-items:center;gap:.8rem;color:var(--ink-2);font-weight:500}
.intro-line::before{content:"";flex:none;width:2rem;height:2px;background:var(--rose)}

/* ---------- Layout-Sektionen ---------- */
.section{padding:clamp(3rem,7vw,5.5rem) 0}
.section-tight{padding:clamp(2rem,5vw,3.5rem) 0}
.section-paper{background:var(--paper)}
.section-sand{background:var(--sand-2)}
.section-blue{background:var(--indigo);color:var(--paper)}
.section-head{margin-bottom:clamp(1.8rem,4vw,3rem);max-width:60ch}
.section-head.is-center{margin-inline:auto;text-align:center}
.section-head .display{font-size:clamp(1.9rem,4vw,2.9rem)}
.section-intro{font-size:1.08rem;line-height:1.55;color:var(--ink-2);margin-top:1rem}

/* Konsistente Display-Heading-Skala (statt Inline-font-sizes) */
.h2{font-family:var(--font-display);font-weight:400;font-size:clamp(1.7rem,3.4vw,2.4rem);line-height:1.1;letter-spacing:.01em}
.h-card{font-size:1.45rem;margin-bottom:.4rem}
.h1-legal{font-size:clamp(2rem,4.5vw,2.8rem);margin-bottom:1.4rem}
.section-blue .eyebrow{color:var(--rose-soft)}
.section-blue .section-intro{color:rgba(253,250,243,.85)}
.lead-narrow{max-width:46ch}

/* ---------- Breadcrumb ---------- */
.breadcrumb{padding:1.4rem 0 .2rem}
.breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.92rem;color:var(--ink-2)}
.breadcrumb li{display:inline-flex;align-items:center;gap:.4rem}
.breadcrumb a:hover{color:var(--indigo);text-decoration:underline}
.breadcrumb [aria-current=page]{color:var(--ink);font-weight:600}
.crumb-sep{width:1rem;height:1rem;opacity:.5;transform:rotate(-90deg)}

/* ---------- Info-Karten (Standort/Zeiten etc.) ---------- */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}
.info-card{background:var(--indigo-050);border:1px solid var(--indigo-100);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.2rem)}
.info-card .info-ic{width:48px;height:48px;border-radius:14px;background:var(--rose-100);color:var(--rose);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.info-card .info-ic svg{width:24px;height:24px}
.info-card h3{font-size:1.3rem;margin-bottom:.6rem}
.info-card p{color:var(--ink-2)}
.info-card .addr{margin-top:1rem;font-weight:600;color:var(--ink)}
.hours-table{margin-top:.8rem;width:100%;border-collapse:collapse}
.hours-table th,.hours-table td{text-align:left;padding:.45rem 0;border-bottom:1px solid var(--line);font-weight:500}
.hours-table td:last-child{text-align:right;color:var(--ink-2)}
.hours-table tr.is-today th,.hours-table tr.is-today td{color:var(--indigo);font-weight:700}
.hours-note{font-style:italic;color:var(--ink-2);margin-bottom:.4rem}

/* ---------- Feature-Karten ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.feature-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2rem)}
.feature-ic{width:46px;height:46px;border-radius:13px;background:var(--indigo-050);color:var(--indigo);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.feature-ic svg{width:24px;height:24px}
.feature-num{font-family:var(--font-display);font-size:1.6rem;color:var(--rose);display:block;margin-bottom:.5rem}
.feature-card h3{font-size:1.2rem;margin-bottom:.5rem}
.feature-card p{color:var(--ink-2)}
.section-blue .feature-card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:var(--paper)}
.section-blue .feature-card p{color:rgba(253,250,243,.82)}
.section-blue .feature-ic{background:rgba(255,255,255,.12);color:#fff}

/* ---------- Checklisten ---------- */
.checklist{display:grid;gap:.8rem;margin-top:1.4rem}
.checklist li{display:flex;align-items:flex-start;gap:.7rem;font-weight:500}
.checklist .check-ic{flex:none;width:24px;height:24px;border-radius:50%;background:var(--indigo-050);color:var(--indigo);display:flex;align-items:center;justify-content:center}
.checklist .check-ic svg{width:15px;height:15px}

/* two-column text+media block */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split.is-reverse .split-media{order:-1}
.split-media .media-frame{aspect-ratio:5/4}
@media(max-width:820px){.split{grid-template-columns:1fr}.split-media .media-frame{aspect-ratio:16/10}.split.is-reverse .split-media{order:0}}

/* ---------- Events ---------- */
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem}
.event-card{display:flex;gap:1.1rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem}
.event-date{flex:none;width:64px;height:64px;border-radius:14px;background:var(--indigo);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center}
.event-day{font-family:var(--font-display);font-size:1.5rem;line-height:1}
.event-mon{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.9}
.event-cat{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--rose);margin-bottom:.3rem}
.event-card--tentative{opacity:.85}
.event-badge-tentative{display:inline-block;font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:#EFF6FF;color:#3B82F6;border:1px solid #BFDBFE;border-radius:4px;padding:1px 6px;vertical-align:middle;margin-left:.3rem}
.event-notice{font-size:.82rem;color:#6B7280;border-left:3px solid #BFDBFE;padding:.5rem .8rem;margin:.6rem 0 1rem;background:#F0F7FF;border-radius:0 6px 6px 0}
.event-title{font-size:1.25rem;margin-bottom:.4rem}
.event-meta{font-size:.9rem;color:var(--ink-2);margin-bottom:.5rem}
.event-meta svg{width:1rem;height:1rem;display:inline;vertical-align:-2px}
.event-teaser{color:var(--ink-2);margin-bottom:.7rem}
.link-more{display:inline-flex;align-items:center;gap:.35rem;background:none;border:0;padding:0;color:var(--indigo);font-weight:600}
.link-more:hover{text-decoration:underline}
.ic-sm{width:1rem;height:1rem}

/* Event-Dialog */
.event-dialog{width:min(560px,92vw);border:0;border-radius:var(--radius-lg);padding:0;background:var(--paper);box-shadow:0 24px 70px rgba(20,16,40,.4);overflow:hidden;color:var(--ink)}
.event-dialog::backdrop{background:rgba(28,22,52,.55);backdrop-filter:blur(2px)}
.event-dialog-media{aspect-ratio:16/8;position:relative;background:var(--indigo-050)}
.event-dialog-media img{width:100%;height:100%;object-fit:cover;display:block}
.event-dialog-body{padding:clamp(1.4rem,4vw,2rem)}
/* Ohne Bild: oben Platz lassen, damit der Schließen-Button nicht über dem Text liegt */
.event-dialog--no-media .event-dialog-body{padding-top:3rem}
.event-dialog-body .event-title{font-size:1.7rem;margin-bottom:.7rem}
.event-text{margin:1rem 0 1.4rem;color:var(--ink-2)}
.event-dialog-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.dialog-x{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.dialog-x svg{width:18px;height:18px}

/* ---------- Speisekarte ---------- */
.menu-cols{columns:2;column-gap:clamp(2rem,5vw,4rem)}
.menu-group{break-inside:avoid;margin-bottom:2.2rem}
.menu-group-title{font-size:1.35rem;padding-bottom:.6rem;border-bottom:2px solid var(--indigo);margin-bottom:.9rem}
.menu-note{font-size:.92rem;color:var(--ink-2);font-style:italic;margin-bottom:.8rem}
.menu-item{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dotted var(--line-2)}
.menu-name{font-weight:600;display:block}
.menu-desc{display:block;font-size:.9rem;color:var(--ink-2)}
.menu-price{font-weight:700;white-space:nowrap}
@media(max-width:680px){.menu-cols{columns:1}}

/* Google-Bewertung */
.star{width:1.1em;height:1.1em;fill:#F5A623;display:inline-block;vertical-align:middle}
.g-stars{display:inline-flex;gap:2px;line-height:0}
.google-pill{display:inline-flex;align-items:center;gap:.6rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.55rem 1.05rem;font-weight:600;box-shadow:var(--shadow);font-size:1rem}
.google-pill:hover{border-color:var(--line-2)}
.google-pill strong{color:var(--indigo)}
.google-card{max-width:620px;margin-inline:auto;text-align:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.6rem,4vw,2.4rem)}
.google-card .g-stars{font-size:1.7rem;margin-bottom:.5rem}
.g-rating{font-size:1.15rem;color:var(--ink-2)}
.g-rating strong{font-family:var(--font-display);color:var(--indigo);font-size:1.5rem;margin-right:.2rem}
.g-text{color:var(--ink-2);margin:.7rem auto 1.5rem;max-width:42ch}

/* Angebots-Band */
.deal-band{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:var(--indigo-050);border:1px solid var(--indigo-100);border-radius:var(--radius);padding:1rem 1.3rem;margin-bottom:2rem}
.deal-tag{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--rose);border-radius:var(--radius-pill);padding:.3rem .8rem}
.deal-main{flex:1;min-width:200px}
.deal-main strong{font-size:1.1rem}
.deal-main span{color:var(--ink-2)}
.deal-price{font-family:var(--font-display);font-size:1.4rem;color:var(--indigo)}

/* breakfast cards */
.bf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem}
.bf-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column}
.bf-top{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.5rem}
.bf-name{font-size:1.2rem;font-weight:700}
.bf-price{font-family:var(--font-display);font-size:1.3rem;color:var(--indigo);white-space:nowrap}
.bf-card p{color:var(--ink-2)}
.veg-tag{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;align-self:flex-start;font-size:.82rem;font-weight:600;color:#2f7d4f;background:#e7f4ec;border-radius:var(--radius-pill);padding:.3rem .75rem}
.veg-tag svg{width:1rem;height:1rem}

/* ---------- Store / Schaufenster ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.filter-btn{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.6rem 1.1rem;font-weight:600;color:var(--ink-2);transition:.15s}
.filter-btn:hover{border-color:var(--ink)}
.filter-btn[aria-pressed=true]{background:var(--indigo);color:#fff;border-color:var(--indigo)}
.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.2rem}
.store-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}
.store-img{aspect-ratio:1;position:relative;background:var(--indigo-050)}
.store-info{padding:1.1rem;display:flex;flex-direction:column;gap:.3rem;flex:1}
.store-cat{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--rose)}
.store-name{font-weight:700;font-size:1.05rem}
.store-note{font-size:.9rem;color:var(--ink-2);flex:1}
.store-price{font-family:var(--font-display);font-size:1.2rem;color:var(--indigo);margin-top:.3rem}
.store-card.is-hidden{display:none}

/* ---------- Heute im NENNA ---------- */
.today-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.today-item{background:var(--paper);padding:1.3rem}
.today-item .t-ic{color:var(--rose);margin-bottom:.6rem}
.today-item .t-ic svg{width:22px;height:22px}
.today-k{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2)}
.today-v{font-size:1.2rem;font-weight:700;margin:.2rem 0}
.today-s{font-size:.9rem;color:var(--ink-2)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin-inline:auto;display:grid;gap:.7rem}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.1rem 1.3rem;font-weight:600;font-size:1.08rem;cursor:pointer;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ic{width:1.3rem;height:1.3rem;flex:none;color:var(--indigo);transition:transform .2s}
.faq-item[open] .faq-ic{transform:rotate(180deg)}
.faq-a{padding:0 1.3rem 1.2rem;color:var(--ink-2)}

/* ---------- Formulare ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,2.5rem)}
.lead-form{display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-weight:600;font-size:.95rem}
.req{color:var(--rose)}
.field input,.field textarea{font:inherit;width:100%;padding:.8rem 1rem;border:2px solid var(--line-2);border-radius:12px;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus{border-color:var(--indigo);outline:none}
.field-check .check{display:flex;gap:.6rem;align-items:flex-start;font-weight:500;font-size:.95rem;color:var(--ink-2)}
.field-check input{width:22px;height:22px;flex:none;accent-color:var(--indigo)}
.field-check a{color:var(--indigo);text-decoration:underline}
.form-hint{font-size:.88rem;color:var(--ink-2)}
.form-success{background:#e7f4ec;border:1px solid #b9dcc6;color:#1d5234;border-radius:var(--radius);padding:1.2rem 1.4rem;font-size:1.08rem}
.form-error{background:var(--rose-100);border:1px solid var(--rose-soft);color:#9a2b57;border-radius:var(--radius);padding:.9rem 1.1rem}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}

/* contact split */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.contact-meta{display:grid;gap:1.3rem}
.contact-line{display:flex;gap:.9rem;align-items:flex-start}
.contact-line .c-ic{flex:none;width:44px;height:44px;border-radius:12px;background:var(--indigo-050);color:var(--indigo);display:flex;align-items:center;justify-content:center}
.contact-line .c-ic svg{width:22px;height:22px}
.contact-line h3{font-size:1.05rem;margin-bottom:.2rem}
.contact-line p,.contact-line address{color:var(--ink-2);font-style:normal}
.map-embed{margin-top:1.4rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);position:relative;aspect-ratio:16/9;background:var(--indigo-050)}
.map-embed .media-ph{position:absolute;inset:0}
.map-embed .map-cta{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;text-align:center;padding:1rem;background:rgba(241,240,250,.6)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ---------- CTA-Band ---------- */
.cta-band{background:var(--indigo);color:#fff;border-radius:var(--radius-lg);margin:clamp(2rem,5vw,4rem) auto;max-width:var(--maxw)}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding:clamp(1.8rem,4vw,2.8rem)}
.cta-band .display{font-size:clamp(1.8rem,4vw,2.6rem)}
.cta-band p{color:rgba(255,255,255,.85);margin-top:.4rem;max-width:48ch}

/* ---------- Footer ---------- */
.site-footer{background:var(--indigo);color:var(--paper);margin-top:clamp(3rem,6vw,5rem);padding:clamp(2.5rem,5vw,4rem) 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
.footer-claim{color:rgba(253,250,243,.8);margin:1rem 0 1.2rem;max-width:32ch}
.footer-ig{display:inline-flex;align-items:center;gap:.5rem;color:var(--rose-soft);font-weight:600}
.footer-ig svg{width:1.2rem;height:1.2rem}
.footer-h{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--rose-soft);margin-bottom:1rem}
.footer-col ul{display:grid;gap:.6rem}
.footer-col a{color:rgba(253,250,243,.85)}
.footer-col a:hover{color:#fff;text-decoration:underline}
.footer-address{font-style:normal;color:rgba(253,250,243,.85);line-height:1.7}
.footer-hours{margin-top:1rem;color:rgba(253,250,243,.85)}
.footer-contact{display:grid;gap:.7rem;margin-bottom:1.3rem}
.footer-contact a{display:inline-flex;align-items:center;gap:.5rem;color:rgba(253,250,243,.9)}
.footer-contact svg{width:1.1rem;height:1.1rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.15);font-size:.9rem;color:rgba(253,250,243,.7)}
.footer-legal{display:flex;gap:1.2rem;flex-wrap:wrap}
.footer-legal a:hover{color:#fff;text-decoration:underline}
.footer-credit a{color:var(--rose-soft);font-weight:600}
.footer-credit a:hover{color:#fff;text-decoration:underline}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Legal / Prosa ---------- */
.prose{max-width:740px}
.prose h2{font-size:1.5rem;margin:2rem 0 .8rem}
.prose h3{font-size:1.15rem;margin:1.4rem 0 .5rem}
.prose p,.prose li{color:var(--ink-2);margin-bottom:.8rem}
.prose ul{list-style:disc;padding-left:1.3rem;display:grid;gap:.4rem}
.prose a{color:var(--indigo);text-decoration:underline}

/* 404 */
.error-page{text-align:center;padding:clamp(3rem,9vw,7rem) 0}
.error-page .big{font-family:var(--font-display);font-size:clamp(4rem,16vw,9rem);color:var(--indigo);line-height:1}
