:root{
  --brand:#990033;        /* Bordeaux – Hausfarbe (vom Original übernommen) */
  --brand-dark:#7a0028;
  --brand-tint:#faf0f3;   /* heller Bordeaux-Hauch für Flächen */
  --gold:#b08a2e;         /* dezenter Gold-Akzent */
  --cream:#fdfaf8;        /* warmes Weiß (Seitenhintergrund) */
  --cream-2:#f6efe9;      /* warmer Wechsel-Hintergrund */
  --ink:#2a2220;
  --muted:#7a6f69;
  --line:#ece2db;
  --radius:14px;
  --shadow:0 6px 24px rgba(80,10,30,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  /* nur systemeigene Schriften – keine externen Fonts (Datenschutz) */
  margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--cream);font-size:18px;line-height:1.65;
}
h1,h2,h3{font-family:Georgia,"Times New Roman","Iowan Old Style",serif;line-height:1.2;color:var(--brand)}
h1{font-size:clamp(2.2rem,6vw,4rem);margin:0}
h2{font-size:clamp(1.8rem,4vw,2.5rem);margin:0 0 .4em}
h3{font-size:1.35rem;margin:0 0 .5em}
a{color:var(--brand)}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.narrow{max-width:760px}
.center{text-align:center}
.big{font-size:1.15rem}
.muted{color:var(--muted)}
.small{font-size:.9rem}

/* ---- Buttons ---- */
.btn{display:inline-block;text-decoration:none;font-weight:700;border:0;cursor:pointer;
  padding:14px 28px;border-radius:var(--radius);font-size:1.05rem;transition:.15s;text-align:center}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--brand-dark)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.85)}
.btn-ghost:hover{background:#fff;color:var(--brand)}
.big-btn{width:100%;padding:16px;font-size:1.15rem;margin-top:8px}

/* ---- Header (Bordeaux-Leiste wie im Original) ---- */
.site-header{position:sticky;top:0;z-index:50;background:var(--brand);
  box-shadow:0 2px 12px rgba(80,10,30,.25)}
.nav{display:flex;align-items:center;gap:18px;padding-top:13px;padding-bottom:13px}
.brand{font-family:Georgia,serif;font-weight:700;font-size:1.3rem;color:#fff;
  text-decoration:none;margin-right:auto;display:inline-flex;align-items:center;gap:9px;letter-spacing:.02em}
.brand-ico{width:26px;height:26px;flex:none;fill:none;stroke:var(--gold);stroke-width:1.6}
.links{display:flex;gap:6px}
.links a{color:#fff;text-decoration:none;font-weight:600;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;padding:7px 12px;border-radius:7px;transition:.15s}
.links a:hover{background:rgba(255,255,255,.15)}
.nav-cta{background:#fff;color:var(--brand)!important;padding:9px 18px;border-radius:9px;font-size:.85rem;
  letter-spacing:.06em;text-transform:uppercase}
.nav-cta:hover{background:var(--gold);color:#fff!important}

/* Hamburger (mobil) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  background:transparent;border:0;cursor:pointer;padding:0}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:860px){
  .nav-toggle{display:flex;margin-left:auto}
  .nav-cta{display:none}            /* mobil im Menü + Hero vorhanden */
  .brand{font-size:1.12rem}
  .links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--brand-dark);box-shadow:0 12px 24px rgba(80,10,30,.3);
    max-height:0;overflow:hidden;transition:max-height .3s ease}
  .links.open{max-height:60vh}
  .links a{padding:15px 24px;border-radius:0;font-size:.95rem;letter-spacing:.06em;
    border-top:1px solid rgba(255,255,255,.1)}
}

/* ---- Hero ---- */
/* Optionales Foto: in der Zeile unten url(assets/hero.jpg) als --hero-photo setzen,
   sobald ein echtes Bild vorliegt – z. B. per Inline-Style am <section class="hero" style="--hero-photo:url(assets/hero.jpg)">. */
.hero{position:relative;min-height:74vh;display:flex;align-items:center;
  background-color:#5c0b22;
  background-image:linear-gradient(150deg,rgba(122,0,40,.94) 0%,rgba(153,0,51,.80) 50%,rgba(92,11,34,.95) 100%),
                   var(--hero-photo, none);
  background-size:cover;background-position:center;
  color:#fff;overflow:hidden;text-align:center}
.hero-overlay{position:absolute;inset:0;opacity:.16;pointer-events:none;
  background-image:radial-gradient(circle at 22% 28%,#fff6 0,transparent 42%),
                   radial-gradient(circle at 80% 75%,#0007 0,transparent 48%);}
.hero-content{position:relative;width:100%;padding:78px 22px;animation:fadeUp .9s ease both}
.hero-scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(255,255,255,.5);border-radius:50%;color:#fff;
  animation:bob 2s ease-in-out infinite;transition:background .15s}
.hero-scroll:hover{background:rgba(255,255,255,.15)}
.hero-scroll svg{width:22px;height:22px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.eyebrow{letter-spacing:.28em;text-transform:uppercase;font-weight:700;font-size:.85rem;
  color:var(--gold);margin:0 0 14px}
.hero h1{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero .rule{width:70px;height:3px;background:var(--gold);border:0;margin:18px auto 0}
.lead{font-size:1.3rem;margin:22px auto 32px;max-width:680px;color:#f7e9ee}
.hero-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---- Sections ---- */
.section{padding:72px 0}
.section.alt{background:var(--cream-2)}
.section-head{margin-bottom:8px}
.section-head .rule{width:60px;height:3px;background:var(--gold);border:0;margin:14px auto 28px}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.feature{background:#fff;border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow);
  text-align:center;border:1px solid var(--line)}
.feature .ico{width:46px;height:46px;fill:none;stroke:var(--brand);stroke-width:1.6;
  stroke-linecap:round;stroke-linejoin:round}
.feature h3{margin:.5em 0 .25em}
.feature p{margin:0;color:var(--muted)}
@media(max-width:760px){.features{grid-template-columns:1fr}.section{padding:52px 0}}

/* ---- Cards / Forms ---- */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;border:1px solid var(--line)}
.card.highlight{border-top:5px solid var(--brand)}
.lunch-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:30px;align-items:start}
@media(max-width:860px){.lunch-grid{grid-template-columns:1fr}}

label{display:block;font-weight:600;margin-bottom:14px;color:var(--ink)}
input[type=text],input[type=tel],input[type=email],input[type=number],input[type=date],input[type=time]{
  display:block;width:100%;margin-top:6px;padding:13px;font-size:1.05rem;font-family:inherit;
  border:1.5px solid #d9cdc6;border-radius:10px;background:#fffdfc}
input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(153,0,51,.13)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.grid-2{grid-template-columns:1fr}}

/* Mittagstisch-Tage */
.days{border:1.5px solid #d9cdc6;border-radius:10px;padding:14px 16px;margin-bottom:14px}
.days legend{font-weight:700;padding:0 6px;color:var(--brand)}
.day-row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--line);cursor:pointer}
.day-row:last-child{border-bottom:0}
.day-row input{width:24px;height:24px;flex:none;margin:0;accent-color:var(--brand)}
.day-row .d-name{font-weight:700;min-width:110px}
.day-row .d-dish{color:var(--muted);font-size:.95rem}

/* Menü-Tabelle */
.menu-table{width:100%;border-collapse:collapse}
.menu-table td{padding:12px 6px;border-bottom:1px solid var(--line);vertical-align:top}
.menu-table .d{font-weight:700;width:120px;color:var(--brand)}
.menu-table .p{text-align:right;color:var(--gold);font-weight:700;white-space:nowrap}

/* Verfügbarkeit */
.availability{margin:4px 0 16px;padding:14px 16px;border-radius:10px;font-weight:600}
.av-free{background:#e6f3e2;color:#256b25;border:1px solid #bcdcb4}
.av-full{background:var(--brand-tint);color:var(--brand-dark);border:1px solid #e7c3cf}
.av-closed{background:#f0ebe2;color:#7a6f4f;border:1px solid #ddd2b8}

.form-msg{margin:14px 0 0;font-weight:600;min-height:1.2em}
.form-msg.ok{color:#256b25}
.form-msg.err{color:var(--brand-dark)}

/* Kontakt */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.hours{width:100%;border-collapse:collapse;margin-bottom:10px}
.hours td{padding:10px 4px;border-bottom:1px solid var(--line)}
.hours tr.closed td{color:var(--muted)}
.hours td:last-child{text-align:right;font-weight:600}

/* Footer (Bordeaux-Band wie im Original) */
.site-footer{background:var(--brand);color:#f3dde4;padding:34px 0;text-align:center}
.site-footer a{color:#fff}
.site-footer p{margin:.4em 0}

/* ============ Feinschliff & Bildwelt ============ */

/* Sanfte Hover-Effekte */
.feature,.card{transition:transform .18s ease, box-shadow .18s ease}
.feature:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(80,10,30,.14)}
.btn{transition:background .15s ease, transform .12s ease, box-shadow .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}

/* Scroll-Einblendung */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}

/* ---- Angebote / Leistungen ---- */
.offers{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
@media(max-width:760px){.offers{grid-template-columns:1fr}}
.offer{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .18s ease, box-shadow .18s ease}
.offer:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(80,10,30,.14)}
.offer-ico{width:48px;height:48px;fill:none;stroke:var(--brand);stroke-width:1.5;
  stroke-linecap:round;stroke-linejoin:round;margin-bottom:6px}
.offer h3{margin:.3em 0 .35em;display:flex;align-items:center;gap:10px}
.offer .tag{display:inline-block;background:var(--brand-tint);color:var(--brand-dark);
  font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 10px;border-radius:20px;margin-bottom:12px;align-self:flex-start}
.offer p{margin:0 0 16px;color:var(--ink)}
.offer .offer-cta{margin-top:auto;font-weight:700;text-decoration:none;color:var(--brand);
  display:inline-flex;align-items:center;gap:6px}
.offer .offer-cta:hover{color:var(--brand-dark)}
.offer .offer-cta::after{content:"→";transition:transform .15s}
.offer .offer-cta:hover::after{transform:translateX(3px)}

/* Speisekarte-Kategorien als Chips */
.menu-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.menu-chips span{background:#fff;border:1px solid var(--line);color:var(--brand-dark);
  padding:8px 16px;border-radius:30px;font-weight:600;font-size:.95rem;box-shadow:0 2px 8px rgba(80,10,30,.05)}

/* ---- Galerie ---- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px}
.photo{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;min-height:200px;
  background-size:cover;background-position:center;box-shadow:var(--shadow);
  display:flex;align-items:flex-end}
.photo.wide{grid-column:span 2}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}.photo.wide{grid-column:span 2}}
@media(max-width:460px){.gallery{grid-template-columns:1fr}.photo.wide{grid-column:span 1}}
.photo figcaption{position:relative;z-index:2;color:#fff;font-weight:700;padding:16px 18px;width:100%;
  background:linear-gradient(transparent,rgba(60,5,22,.75));font-family:Georgia,serif;font-size:1.05rem}
/* on-brand Platzhalter-Verläufe (werden durch echte Fotos ersetzt) */
.photo::after{content:"";position:absolute;inset:0;z-index:1;opacity:.10;
  background-image:radial-gradient(circle at 30% 25%,#fff 0,transparent 45%);}
.ph-1{background-image:linear-gradient(145deg,#7a0028,#aa2a55)}
.ph-2{background-image:linear-gradient(145deg,#990033,#5c0b22)}
.ph-3{background-image:linear-gradient(145deg,#b08a2e,#7a0028)}
.ph-4{background-image:linear-gradient(145deg,#5c0b22,#990033)}
.ph-5{background-image:linear-gradient(145deg,#8a1f44,#7a0028)}
.ph-6{background-image:linear-gradient(145deg,#aa2a55,#5c0b22)}
.photo{transition:transform .3s ease}
.photo:hover{transform:scale(1.02)}
.gallery-hint{margin-top:18px}

/* ---- Footer-Layout ---- */
.footer-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap;
  padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid rgba(255,255,255,.18)}
.footer-brand{font-family:Georgia,serif;font-size:1.25rem;font-weight:700;color:#fff;
  display:flex;align-items:center;gap:9px;margin-bottom:8px}
.footer-grid .brand-ico{stroke:var(--gold)}
.footer-nav{display:flex;flex-wrap:wrap;gap:6px 18px}
.footer-nav a{color:#f3dde4;text-decoration:none;font-weight:600}
.footer-nav a:hover{color:#fff}
.footer-legal p{margin:.35em 0}
.site-footer{text-align:left}
@media(max-width:560px){.site-footer{text-align:center}.footer-grid{justify-content:center;text-align:center}.footer-brand{justify-content:center}}

/* Bewegung reduzieren */
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .hero-scroll,.hero-content{animation:none}
  .btn:hover,.feature:hover,.offer:hover,.photo:hover{transform:none}
}

/* Mittagstisch: zwei Wochen */
.menu-week{margin-bottom:18px}
.menu-week:last-of-type{margin-bottom:6px}
.menu-week-title{font-family:Georgia,serif;color:var(--brand);font-size:1.08rem;margin:0 0 6px;
  padding-bottom:6px;border-bottom:2px solid var(--brand-tint)}

/* ---- Reservierungs-Hinweis (Sperre) ---- */
.res-gate{max-width:620px;margin:0 auto;text-align:center;border-top:5px solid var(--gold)}
.res-gate .gate-icon{width:56px;height:56px;margin:0 auto 6px}
.res-gate .gate-icon svg{width:56px;height:56px;fill:none;stroke:var(--brand);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ack{display:flex;gap:12px;align-items:flex-start;text-align:left;background:var(--brand-tint);
  border:1px solid #e7c3cf;border-radius:12px;padding:16px;margin:18px 0;font-weight:600;cursor:pointer}
.ack input{width:26px;height:26px;flex:none;margin:0;accent-color:var(--brand);cursor:pointer}
#res-continue:disabled{opacity:.45;cursor:not-allowed;transform:none}
.reminder{background:var(--brand-tint);color:var(--brand-dark);border-radius:10px;
  padding:10px 14px;margin:0 0 18px;font-weight:600;font-size:.95rem}

/* ---- Mittagstisch-Assistent (Schritte) ---- */
.steps-indicator{display:flex;align-items:center;justify-content:center;gap:6px;margin:0 0 22px}
.steps-indicator .dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;background:#eadfd8;color:#a99;transition:.2s;flex:none}
.steps-indicator .dot.active{background:var(--brand);color:#fff;box-shadow:0 2px 8px rgba(153,0,51,.3)}
.steps-indicator .bar{width:34px;height:3px;background:#eadfd8;border-radius:2px}
.step-title{font-family:Georgia,serif;color:var(--brand);font-size:1.2rem;font-weight:700;margin:0 0 14px}
.step-nav{display:flex;justify-content:space-between;gap:12px;margin-top:18px}
.step-nav button{min-width:120px}
.step-nav button[data-prev]{background:#efe7df;color:var(--brand-dark);border:0;border-radius:var(--radius);
  padding:14px 22px;font-weight:700;cursor:pointer}
.step-nav button[data-prev]:hover{background:#e6dace}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---- Datumsfeld im deutschen Format (nativer Picker liegt transparent darüber) ---- */
.datefield{position:relative;display:block;margin-top:6px}
.datefield #res-date-de{margin-top:0;cursor:pointer;background:#fffdfc}
.datefield .date-native{position:absolute;inset:0;width:100%;height:100%;margin:0;padding:0;
  border:0;opacity:0;cursor:pointer}

/* ---- Reservierungs-Kalender (eigene Verfügbarkeit) ---- */
.field-label{display:block;font-weight:600;margin-bottom:8px;color:var(--ink)}
.cal{border:1.5px solid #d9cdc6;border-radius:12px;padding:12px;background:#fffdfc}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-title{font-family:Georgia,serif;font-weight:700;color:var(--brand);font-size:1.1rem}
.cal-nav{width:42px;height:42px;border:0;border-radius:9px;background:var(--brand-tint);color:var(--brand);
  font-size:1.4rem;line-height:1;cursor:pointer;font-weight:700}
.cal-nav:disabled{opacity:.3;cursor:not-allowed}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.cal-weekdays span{text-align:center;font-size:.78rem;font-weight:700;color:var(--muted)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;min-height:210px}
.cal-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  min-height:48px;border:1px solid transparent;border-radius:9px;background:#f4ece6;cursor:default;
  font-family:inherit;padding:2px}
.cal-cell.empty{background:transparent}
.cal-cell .cd{font-weight:700;font-size:1rem;color:var(--ink)}
.cal-cell .cs{font-size:.6rem;line-height:1}
.cal-cell.free{background:#e6f3e2;border-color:#bcdcb4;cursor:pointer}
.cal-cell.free .cs{color:#256b25}
.cal-cell.free:hover{background:#d4ebcd}
.cal-cell.full{background:#f6e3e3}
.cal-cell.full .cd,.cal-cell.full .cs{color:#9b2c2c}
.cal-cell.closed{background:#efe9df}
.cal-cell.closed .cd,.cal-cell.closed .cs{color:#a99}
.cal-cell.past{background:#f7f4ef}
.cal-cell.past .cd{color:#cabfb4}
.cal-cell.selected{background:var(--brand)!important;border-color:var(--brand)!important}
.cal-cell.selected .cd,.cal-cell.selected .cs{color:#fff!important}
.cal-loading{grid-column:1/-1;text-align:center;padding:40px;color:var(--muted)}
.cal-legend{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:12px;font-size:.82rem;color:var(--muted)}
.cal-legend .lg{width:14px;height:14px;border-radius:4px;display:inline-block;margin-left:10px}
.cal-legend .lg-free{background:#e6f3e2;border:1px solid #bcdcb4}
.cal-legend .lg-full{background:#f6e3e3}
.cal-legend .lg-closed{background:#efe9df}
.cal-selected{font-weight:700;color:var(--brand);margin:12px 0 2px;min-height:1.2em}

/* ---- Tisch-Auswahl (Drinnen / Biergarten) ---- */
.tablepick{margin:8px 0 4px}
.tp-group{margin-bottom:14px}
.tp-head{font-weight:700;color:var(--brand);margin-bottom:8px}
.tp-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:8px}
.tp-tile{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  border:1.5px solid #d9cdc6;border-radius:10px;padding:12px 8px;cursor:pointer;background:#fffdfc;
  font-weight:600;margin:0;text-align:center;transition:.12s}
.tp-tile input{position:absolute;opacity:0;pointer-events:none}
.tp-tile .tp-name{font-size:1rem;color:var(--ink)}
.tp-tile .tp-seats{font-size:.78rem;color:var(--muted);font-weight:600}
.tp-tile:hover{border-color:var(--brand)}
.tp-tile.sel{background:var(--brand);border-color:var(--brand);box-shadow:0 2px 10px rgba(153,0,51,.3)}
.tp-tile.sel .tp-name{color:#fff}
.tp-tile.sel .tp-seats{color:#f3dde4}
.tp-tile.taken{background:#f1ece6;cursor:not-allowed;border-style:dashed}
.tp-tile.taken .tp-name,.tp-tile.taken .tp-seats{color:#b3a99f}
.tp-x{font-size:.66rem;color:#9b2c2c;font-weight:700}

/* ---- Personenzahl-Frage + Großgruppen-Hinweis ---- */
.persons-q{display:block;font-weight:700;color:var(--brand);font-size:1.05rem;
  background:var(--brand-tint);border:1px solid #e7c3cf;border-radius:10px;padding:14px 16px;margin:4px 0 16px}
.persons-q input{max-width:130px;font-size:1.2rem;font-weight:700;text-align:center}
.big-group{background:var(--brand-tint);border:1px solid #e7c3cf;border-radius:12px;padding:18px;text-align:center}
.big-group p{margin:0 0 14px;font-size:1.05rem}
.big-group .btn{display:inline-block}

/* ---- Uhrzeit-Slots (Reservierung) ---- */
.slotpick{margin:8px 0 6px}
.slot-tiles{display:flex;flex-wrap:wrap;gap:8px}
.slot-tile{border:1.5px solid #d9cdc6;background:#fffdfc;color:var(--ink);font-weight:700;
  border-radius:10px;padding:12px 18px;cursor:pointer;font-family:inherit;font-size:1rem;transition:.12s}
.slot-tile:hover{border-color:var(--brand)}
.slot-tile.sel{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 2px 10px rgba(153,0,51,.3)}
