/*
Theme Name: Divadelná reštaurácia
Theme URI: https://divadelna.sk
Author: Divadelná reštaurácia Zvolen
Description: Elegantná bordová téma pre divadelnú reštauráciu. Denné menu s importom z DOCX/PDF cez AI, vertikálne rozloženie dní, správa gramáže, alergénov a cien.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: divadelna-rest
Tags: restaurant, dark, custom-menu, food, theater
*/

/* ── RESET & VARIABLES ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bord:        #8B1A2B;
  --bord-light:  #A8223A;
  --bord-pale:   rgba(139,26,43,.08);
  --bord-glow:   rgba(139,26,43,.2);
  --dark:        #120810;
  --darker:      #0A0608;
  --card:        #0E0A10;
  --surface:     #110B12;
  --lift:        #16101A;
  --cream:       #FDF8F5;
  --border:      #3A1E2E;
  --borderfaint: #281422;
  --muted:       #C4A0B0;
  --subtle:      #A07888;
  --faint:       #7A5870;
  --green:       #2D7A4F;
  --red:         #E24B4A;
  --amber:       #C48A2A;
}
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Lato', 'Helvetica Neue', sans-serif;
  background: var(--dark);
  color: var(--cream);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--bord-light); text-decoration: none; transition: color .2s; }
a:hover { color: var(--cream); }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5,h6 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 400;
  line-height: 1.2;
  color: var(--cream);
}
p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }
.eyebrow {
  font-size: .65rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--bord-light);
  margin-bottom: .35rem;
  display: block;
}
.section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 1.5rem;
}
.gold-line { width: 40px; height: 2px; background: var(--bord); margin-bottom: 1.25rem; }

/* ── LAYOUT ── */
.container      { max-width: 1100px; margin: 0 auto; padding: 0 2rem; }
.container--mid { max-width: 860px;  margin: 0 auto; padding: 0 2rem; }
section { padding: 4rem 0; }
.screen-reader-text { position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap; }

/* ── HEADER / NAV — biele pozadie ── */
#site-header {
  background: #FFFFFF;
  border-bottom: 1px solid #E5DDE0;
  position: sticky;
  top: 0;
  z-index: 1000;
  height: 80px;
  display: flex;
  align-items: center;
  box-shadow: 0 1px 8px rgba(0,0,0,.06);
}
#site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1100px;
}
.site-logo-link { display: flex; align-items: center; }
.site-logo-img  {
  height: 64px;
  width: auto;
  max-width: 240px;
  object-fit: contain;
  opacity: 1;
  transition: opacity .2s;
}
.site-logo-img:hover { opacity: .85; }
.site-logo-text { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--bord); }
#site-navigation { display: flex; align-items: center; gap: .75rem; }
#primary-menu { display: flex; list-style: none; }
#primary-menu > li > a {
  display: block;
  padding: 0 .85rem;
  height: 80px;
  line-height: 80px;
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #5A4550;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
#primary-menu > li > a:hover,
#primary-menu > li.current-menu-item > a,
#primary-menu > li.current_page_item > a {
  color: var(--bord);
  border-bottom-color: var(--bord);
}
.nav-social { display: flex; gap: .3rem; }
.nav-social a {
  color: #8A7580;
  font-size: 1.1rem;
  height: 80px;
  display: flex;
  align-items: center;
  padding: 0 .25rem;
  transition: color .2s;
}
.nav-social a:hover { color: var(--bord); }
.nav-reserve-btn {
  background: var(--bord);
  color: #fff !important;
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .45rem 1.1rem;
  border-radius: 2px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: .35rem;
  transition: background .2s;
  white-space: nowrap;
  height: auto !important;
  border-bottom: none !important;
}
.nav-reserve-btn:hover { background: var(--bord-light) !important; }
.menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid #D8CCD2;
  color: #5A4550;
  padding: .45rem .7rem;
  cursor: pointer;
  border-radius: 2px;
  font-size: 1.1rem;
  line-height: 1;
}

/* Košík tlačidlo v navigácii */
.nav-cart-btn {
  position: relative;
  background: transparent;
  border: 1px solid #D8CCD2;
  color: var(--bord);
  width: 40px;
  height: 40px;
  border-radius: 3px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  transition: all .2s;
}
.nav-cart-btn:hover { background: var(--bord-pale); border-color: var(--bord); }
.nav-cart-count {
  position: absolute;
  top: -6px;
  right: -6px;
  background: var(--bord);
  color: #fff;
  font-size: .62rem;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
}

/* ── HERO ── */
#hero {
  position: relative;
  min-height: auto;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hero-grid {
  position:absolute;inset:0;opacity:.04;z-index:1;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 48px,rgba(139,26,43,.5) 48px,rgba(139,26,43,.5) 49px),
    repeating-linear-gradient(90deg,transparent,transparent 48px,rgba(139,26,43,.5) 48px,rgba(139,26,43,.5) 49px);
}
.hero-ornament { color:var(--bord-light);font-size:1.1rem;letter-spacing:.5em;opacity:.5;margin-bottom:.8rem; }
.hero-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  line-height: 1.12;
  color: var(--cream);
  margin-bottom: .7rem;
}
.hero-title em { font-style:italic; color:var(--bord-light); }
.hero-subtitle { font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--subtle);margin-bottom:1.25rem; }
.hero-buttons { display:flex;gap:.75rem;flex-wrap:wrap; }
.hero-story {
  background: rgba(10,6,8,.5);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 2rem;
  backdrop-filter: blur(4px);
}
.hero-story--compact { padding: 1.5rem 1.75rem; }
.btn-primary {
  background:var(--bord);color:#fff;padding:.78rem 1.85rem;
  font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  border-radius:2px;transition:background .2s;display:inline-flex;align-items:center;gap:.4rem;
}
.btn-primary:hover { background:var(--bord-light);color:#fff; }
.btn-outline {
  border:1px solid var(--bord);color:var(--bord-light);padding:.78rem 1.85rem;
  font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  border-radius:2px;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem;
}
.btn-outline:hover { background:var(--bord);color:#fff; }

/* ── DAILY MENU SECTION ── */
#daily-menu-section { background:var(--card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 0; }
.menu-section-top { display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:.75rem; }
.menu-section-top .section-title { margin-bottom:0; }
.btn-toggle-admin {
  background:transparent;border:1px solid var(--border);color:var(--subtle);
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.45rem 1rem;
  border-radius:2px;cursor:pointer;font-family:'Lato',sans-serif;
  transition:all .2s;display:flex;align-items:center;gap:.35rem;
}
.btn-toggle-admin:hover { border-color:var(--bord);color:var(--bord-light); }

/* Admin add panel */
.menu-admin-bar {
  background:var(--surface);border:1px solid var(--border);border-radius:3px;
  padding:1.2rem 1.25rem;margin-bottom:1.5rem;
}
.menu-admin-bar h4 {
  font-family:'Playfair Display',serif;font-size:.95rem;color:var(--bord-light);
  font-weight:400;margin-bottom:.9rem;display:flex;align-items:center;gap:.4rem;
}
.admin-add-form { display:grid;grid-template-columns:1fr 1fr 2fr 1fr auto;gap:.5rem;align-items:center; }
.admin-add-form select,
.admin-add-form input {
  background:var(--dark);border:1px solid var(--border);color:var(--cream);
  padding:.42rem .6rem;font-size:.8rem;border-radius:2px;font-family:'Lato',sans-serif;width:100%;
}
.admin-add-form select:focus,
.admin-add-form input:focus { outline:none;border-color:var(--bord); }
.admin-add-form input::placeholder { color:var(--faint); }
.btn-add-item {
  background:var(--bord);color:#fff;border:none;padding:.42rem 1rem;
  font-size:.73rem;font-weight:700;cursor:pointer;border-radius:2px;
  white-space:nowrap;font-family:'Lato',sans-serif;transition:background .2s;
}
.btn-add-item:hover { background:var(--bord-light); }
#adminMessage { font-size:.78rem;margin-top:.6rem;display:none; }

/* Day blocks - vertical layout */
.menu-day-block {
  background:var(--darker);border:1px solid var(--border);border-radius:3px;
  margin-bottom:.8rem;overflow:hidden;
}
.menu-day-block:last-child { margin-bottom:0; }
.menu-day-block.is-today { border-color:var(--bord);box-shadow:0 0 0 1px var(--bord-glow); }
.menu-day-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.25rem;background:var(--bord-pale);border-bottom:1px solid var(--borderfaint);
  cursor:pointer;user-select:none;transition:background .2s;
}
.menu-day-block.is-today .menu-day-header { background:rgba(139,26,43,.12); }
.menu-day-header:hover { background:rgba(139,26,43,.1); }
.menu-day-name {
  font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--cream);
  display:flex;align-items:center;gap:.65rem;
}
.today-badge {
  background:var(--bord);color:#fff;font-size:.58rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.22rem .6rem;border-radius:2px;
  font-family:'Lato',sans-serif;font-weight:700;display:inline-flex;align-items:center;gap:.25rem;
}
.menu-day-date { font-size:.73rem;color:var(--subtle); }
.day-chevron { color:var(--subtle);font-size:1rem;display:flex;align-items:center;transition:transform .25s; }
.menu-day-block.collapsed .day-chevron { transform:rotate(-90deg); }
.menu-day-categories { display:block; }
.menu-day-block.collapsed .menu-day-categories { display:none; }
.cat-count { margin-left:auto;opacity:.5;font-size:.6rem;font-weight:400; }
.menu-item-weight { font-size:.72rem;color:var(--faint);white-space:nowrap;flex-shrink:0; }
.menu-item-center { flex:1;min-width:0; }
.menu-item-name { font-size:.85rem;color:var(--cream);line-height:1.4; }
.menu-item-allergens { display:flex;flex-wrap:wrap;gap:.15rem;margin-top:.2rem; }
.allergen-tag {
  display:inline-block;background:rgba(139,26,43,.15);color:var(--muted);
  font-size:.6rem;font-weight:700;padding:.1rem .35rem;border-radius:2px;
  border:1px solid rgba(139,26,43,.25);
}
.menu-item-right { display:flex;align-items:center;gap:.4rem;flex-shrink:0; }
.menu-item-price { font-size:.82rem;color:var(--bord-light);font-weight:700;white-space:nowrap; }
.btn-delete-item {
  background:transparent;border:1px solid var(--faint);color:var(--subtle);
  padding:.22rem .4rem;font-size:.65rem;cursor:pointer;border-radius:2px;
  transition:all .2s;line-height:1;
}
.btn-delete-item:hover { border-color:var(--red);color:var(--red); }
.menu-empty { font-size:.8rem;color:var(--faint);font-style:italic;padding:.5rem 0; }

/* ── TABUĽKOVÝ LAYOUT MENU (denné menu + úvodná stránka) ── */
.dm-cat-block {
  border-bottom: 1px solid var(--borderfaint);
  padding: .85rem 1.25rem 1rem;
}
.dm-cat-block:last-child { border-bottom: none; }
.dm-cat-label {
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--bord-light);
  opacity: .9;
  margin-bottom: .65rem;
  display: flex;
  align-items: center;
  gap: .35rem;
}
.dm-cat-label i { font-size: .95rem; opacity: .8; }
.dm-table {
  width: 100%;
  border-collapse: collapse;
}
.dm-table thead th {
  padding: .45rem .6rem;
  font-size: .6rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--subtle);
  font-weight: 400;
  text-align: left;
  border-bottom: 1px solid var(--borderfaint);
}
.dm-th-weight    { width: 80px; }
.dm-th-allergens { width: 130px; }
.dm-th-price     { width: 80px; text-align: right !important; }
.dm-table tbody tr { border-bottom: 1px dotted var(--borderfaint); transition: background .12s; }
.dm-table tbody tr:last-child { border-bottom: none; }
.dm-table tbody tr:hover { background: rgba(139,26,43,.04); }
.dm-td-weight {
  padding: .45rem .6rem;
  font-size: .8rem;
  color: var(--faint);
  white-space: nowrap;
  vertical-align: middle;
}
.dm-td-name {
  padding: .45rem .6rem;
  font-size: .95rem;
  color: var(--cream);
  vertical-align: middle;
  line-height: 1.4;
}
.dm-td-allergens {
  padding: .45rem .6rem;
  vertical-align: middle;
  line-height: 1.8;
}
.dm-td-price {
  padding: .45rem .6rem;
  font-size: .9rem;
  color: var(--bord-light);
  font-weight: 700;
  white-space: nowrap;
  text-align: right;
  vertical-align: middle;
}
.dm-none { font-size: .78rem; color: var(--faint); }
.dm-day-block {
  background: var(--darker);
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-bottom: .8rem;
  overflow: hidden;
}
.dm-day-block:last-child { margin-bottom: 0; }
.dm-today { border-color: var(--bord); box-shadow: 0 0 0 1px var(--bord-glow); }
.dm-day-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1.25rem;
  background: var(--bord-pale);
  border-bottom: 1px solid var(--borderfaint);
}
.dm-today .dm-day-header { background: rgba(139,26,43,.12); }
.dm-day-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: .65rem;
}
.dm-day-date { font-size: .82rem; color: rgba(255,255,255,.75); font-weight: 300; letter-spacing: .03em; }
.dm-empty {
  padding: 1rem 1.25rem;
  font-size: .82rem;
  color: var(--faint);
  font-style: italic;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.dm-extra-wrap { margin-top: 2rem; padding-top: 1.75rem; border-top: 1px solid var(--border); }
.dm-extra-grid { display: grid; grid-template-columns: 1fr; }
.dm-extra-block {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1.25rem;
}
.dm-extra-block h4 {
  font-family: 'Playfair Display', serif;
  font-size: .95rem;
  font-weight: 400;
  color: var(--cream);
  margin-bottom: .75rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.dm-extra-block h4 i { color: var(--bord-light); }

/* Responsive — na mobile schovaj gramáž stĺpec */
@media(max-width:560px) {
  .dm-table .dm-th-weight,
  .dm-table .dm-td-weight { display: none; }
  .dm-th-allergens { width: 90px; }
}

/* ── ABOUT ── */
#about-section { background:var(--surface); }
.about-grid { display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center; }
.about-img { width:100%;height:340px;object-fit:cover;border-radius:2px; }
.about-img-placeholder {
  width:100%;height:340px;background:linear-gradient(135deg,var(--lift),var(--darker));
  border:1px solid var(--border);border-radius:2px;display:flex;align-items:center;
  justify-content:center;font-family:'Playfair Display',serif;font-style:italic;color:var(--faint);
}
.about-text { font-size:.9rem;line-height:1.85;color:var(--muted); }

/* ── INFO / CONTACT ── */
#info-section { background:var(--card);border-top:1px solid var(--border); }
.info-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:2rem; }
.info-block h3 {
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bord-light);
  margin-bottom:.7rem;font-family:'Lato',sans-serif;font-weight:700;
  display:flex;align-items:center;gap:.35rem;
}
.info-block h3 i { font-size:1rem;opacity:.8; }
.info-block p,
.info-block address { font-size:.85rem;color:var(--subtle);line-height:1.8;font-style:normal; }
.info-block a { color:var(--subtle); }
.info-block a:hover { color:var(--bord-light); }
.info-block strong { color:var(--cream); }
.social-links { display:flex;flex-direction:column;gap:.55rem; }
.social-btn { display:flex;align-items:center;gap:.55rem;color:var(--subtle);font-size:.85rem;transition:color .2s; }
.social-btn:hover { color:var(--bord-light); }
.social-btn i { font-size:1.15rem; }

/* ── FOOTER ── */
#site-footer { background:#060208;border-top:1px solid var(--borderfaint);padding:1.5rem 0; }
.footer-inner { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem; }
.footer-copy { font-size:.75rem;color:var(--faint); }
.footer-copy a { color:var(--faint); }
.footer-copy a:hover { color:var(--bord-light); }
.footer-social { display:flex;gap:.8rem; }
.footer-social a { color:var(--faint);font-size:1.2rem;display:flex;align-items:center;transition:color .2s; }
.footer-social a:hover { color:var(--bord-light); }

/* ── PAGE CONTENT ── */
.page-hero {
  position:relative;min-height:220px;background:linear-gradient(135deg,#0A0608,#280A18,#0A0608);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:3rem 2rem;overflow:hidden;
}
.page-hero .hero-grid { opacity:.05; }
.page-hero-content { position:relative;z-index:2; }
.content-area { padding:4rem 0; }
.entry-content { font-size:.95rem;line-height:1.85;color:var(--muted); }
.entry-content h2,.entry-content h3 { color:var(--cream);margin:2rem 0 1rem; }
.entry-content ul,.entry-content ol { padding-left:1.5rem;margin-bottom:1rem; }
.entry-content li { margin-bottom:.5rem; }

/* ── MENU IMPORTER PAGE ── */
.importer-wrap { padding:3rem 0 5rem; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:5px;height:5px; }
::-webkit-scrollbar-track { background:var(--darker); }
::-webkit-scrollbar-thumb { background:var(--border);border-radius:3px; }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .about-grid { grid-template-columns:1fr;gap:2rem; }
  .info-grid  { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  #primary-menu { display:none;flex-direction:column;position:absolute;top:66px;left:0;right:0;background:var(--darker);border-bottom:1px solid var(--border); }
  #primary-menu.open { display:flex; }
  #primary-menu > li > a { height:auto;line-height:1;padding:.75rem 2rem;border-bottom:none;border-left:2px solid transparent; }
  #primary-menu > li > a:hover { border-left-color:var(--bord); }
  .menu-toggle { display:block; }
  .nav-reserve-btn { display:none; }
  .admin-add-form { grid-template-columns:1fr 1fr; }
  .admin-add-form .btn-add-item { grid-column:span 2; }
}
@media(max-width:480px) {
  .container { padding:0 1.25rem; }
  .info-grid  { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════
   IMPORTER PAGE STYLES
   ══════════════════════════════════════════════ */

/* Header row */
.imp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: .75rem;
}
.imp-back {
  font-size: .75rem;
  letter-spacing: .08em;
  color: var(--subtle);
  display: flex;
  align-items: center;
  gap: .3rem;
  transition: color .2s;
}
.imp-back:hover { color: var(--bord-light); }

/* Status pill */
.imp-status {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
  padding: .38rem .9rem;
  border-radius: 20px;
  border: 1px solid;
}
.imp-status.idle    { color: var(--subtle);     border-color: var(--border);  background: var(--card); }
.imp-status.loading { color: var(--amber);       border-color: var(--amber);   background: rgba(196,138,42,.1); animation: imp-pulse 1.4s ease-in-out infinite; }
.imp-status.done    { color: var(--green);       border-color: var(--green);   background: rgba(45,122,79,.12); }
.imp-status.error   { color: var(--red);         border-color: var(--red);     background: rgba(226,75,74,.1); }
@keyframes imp-pulse { 0%,100%{opacity:1} 50%{opacity:.5} }

/* Upload zone */
.imp-upload-zone {
  position: relative;
  border: 2px dashed var(--border);
  border-radius: 4px;
  padding: 2.75rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .25s, background .25s;
  background: var(--card);
  margin-bottom: 1.5rem;
}
.imp-upload-zone:hover,
.imp-upload-zone.drag-over { border-color: var(--bord);  background: var(--bord-pale); }
.imp-upload-zone.has-file  { border-style: solid; border-color: var(--bord); background: var(--bord-pale); }
.imp-upload-zone input[type=file] { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }
.imp-upload-icon { font-size: 2.4rem; color: var(--subtle); margin-bottom: .75rem; display: block; transition: color .25s; }
.imp-upload-zone:hover .imp-upload-icon,
.imp-upload-zone.has-file .imp-upload-icon { color: var(--bord-light); }
.imp-upload-label strong { display:block;font-size:1rem;color:var(--cream);margin-bottom:.25rem; }
.imp-upload-label span   { font-size:.78rem;color:var(--subtle); }
.imp-file-name { margin-top:.8rem;font-size:.82rem;color:var(--bord-light);display:flex;align-items:center;justify-content:center;gap:.4rem; }

/* Controls row */
.imp-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.imp-label { font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--subtle);display:block;margin-bottom:.45rem; }
.imp-day-btns { display:flex;gap:.35rem;flex-wrap:wrap; }
.imp-day-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--subtle);
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .4rem .9rem;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  transition: all .2s;
}
.imp-day-btn:hover  { border-color: var(--bord); color: var(--bord-light); }
.imp-day-btn.active { background: var(--bord); border-color: var(--bord); color: #fff; font-weight: 700; }
.imp-btn-parse {
  background: var(--bord);
  color: #fff;
  border: none;
  padding: .55rem 1.5rem;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex;
  align-items: center;
  gap: .4rem;
  transition: background .2s;
}
.imp-btn-parse:hover:not(:disabled) { background: var(--bord-light); }
.imp-btn-parse:disabled { opacity: .4; cursor: not-allowed; }

/* Progress */
.imp-progress { margin-bottom: 1.5rem; }
.imp-progress-head { display:flex;justify-content:space-between;font-size:.75rem;color:var(--subtle);margin-bottom:.4rem; }
.imp-progress-bar  { height:3px;background:var(--borderfaint);border-radius:2px;overflow:hidden; }
.imp-progress-bar div { height:100%;background:var(--bord);border-radius:2px;transition:width .4s ease;width:0; }

/* Error / Saved */
.imp-error,
.imp-saved {
  border-radius: 3px;
  padding: .9rem 1.1rem;
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.25rem;
  font-size: .85rem;
}
.imp-error { background: rgba(226,75,74,.1); border: 1px solid rgba(226,75,74,.3); }
.imp-error i { color: var(--red); font-size: 1.15rem; flex-shrink: 0; }
.imp-error p { color: var(--cream); }
.imp-saved { background: rgba(45,122,79,.12); border: 1px solid rgba(45,122,79,.3); flex-wrap: wrap; }
.imp-saved i { color: var(--green); font-size: 1.15rem; flex-shrink: 0; }
.imp-saved p { color: var(--cream); flex: 1; }
.imp-saved strong { color: var(--green); }

/* Result header */
.imp-result-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
  gap: .75rem;
}
.imp-result-title { font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:400;color:var(--cream);display:flex;align-items:center;gap:.5rem; }
.imp-result-title i { color: var(--bord-light); }
.imp-accent { color: var(--bord-light); }
.imp-result-meta { font-size:.75rem;color:var(--subtle);margin-top:.25rem; }
.imp-result-actions { display:flex;gap:.5rem;flex-wrap:wrap; }

/* Small buttons */
.imp-btn-sm {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--subtle);
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .4rem .9rem;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: all .2s;
  text-decoration: none;
}
.imp-btn-sm:hover  { border-color: var(--bord); color: var(--bord-light); }
.imp-btn-sm.primary { background: var(--bord); border-color: var(--bord); color: #fff; }
.imp-btn-sm.primary:hover { background: var(--bord-light); color: #fff; }

/* Table */
.imp-table-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 1rem;
}
.imp-table-head {
  background: var(--bord-pale);
  border-bottom: 1px solid var(--border);
  padding: .65rem 1.1rem;
  font-size: .63rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bord-light);
  display: flex;
  align-items: center;
  gap: .4rem;
}
.imp-limit-badge { margin-left: auto; opacity: .6; font-weight: 400; font-size: .6rem; }
.imp-table { width:100%;border-collapse:collapse; }
.imp-table thead th {
  padding: .6rem .9rem;
  font-size: .63rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--subtle);
  font-weight: 400;
  text-align: left;
  border-bottom: 1px solid var(--borderfaint);
  background: var(--darker);
}
.imp-table thead th:first-child  { width: 90px; }
.imp-table thead th:nth-child(3) { width: 160px; }
.imp-table thead th:nth-child(4) { width: 100px; text-align: right; }
.imp-table thead th:last-child   { width: 46px; }
.imp-table tbody tr { border-bottom: 1px solid var(--borderfaint); transition: background .15s; }
.imp-table tbody tr:last-child { border: none; }
.imp-table tbody tr:hover { background: rgba(139,26,43,.04); }
.imp-table tbody td { padding: .6rem .9rem; font-size: .85rem; color: var(--cream); vertical-align: middle; }
.imp-table tbody td:nth-child(4) { text-align: right; color: var(--bord-light); font-weight: 700; }

/* Editable cells */
.imp-cell { outline: none; border-radius: 2px; transition: background .15s; }
.imp-cell:focus { background: rgba(139,26,43,.1); box-shadow: inset 0 0 0 1px var(--bord); }
.imp-cell-name  { min-width: 160px; }
.imp-cell-price { min-width: 80px; }

/* Allergen display in table */
.imp-allergens-cell { line-height: 1.9; }
.imp-none { font-size: .78rem; color: var(--faint); }

/* Delete row button */
.imp-del-btn {
  background: transparent;
  border: 1px solid var(--borderfaint);
  color: var(--faint);
  padding: .28rem .42rem;
  font-size: .85rem;
  cursor: pointer;
  border-radius: 2px;
  transition: all .2s;
  line-height: 1;
  display: flex;
  align-items: center;
}
.imp-del-btn:hover { border-color: var(--red); color: var(--red); }

/* Add row button */
.imp-add-row {
  width: 100%;
  background: transparent;
  border: none;
  border-top: 1px solid var(--borderfaint);
  color: var(--subtle);
  font-size: .73rem;
  padding: .55rem;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: all .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
}
.imp-add-row:hover { background: var(--bord-pale); color: var(--bord-light); }

/* Raw text */
.imp-raw-toggle {
  background: transparent;
  border: 1px solid var(--borderfaint);
  color: var(--faint);
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .35rem .8rem;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  transition: all .2s;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}
.imp-raw-toggle:hover { border-color: var(--border); color: var(--subtle); }
.imp-raw-box {
  background: var(--darker);
  border: 1px solid var(--borderfaint);
  border-radius: 3px;
  padding: 1rem;
  font-size: .73rem;
  color: var(--subtle);
  line-height: 1.7;
  max-height: 220px;
  overflow-y: auto;
  margin-top: .75rem;
  display: none;
  white-space: pre-wrap;
  word-break: break-word;
}
.imp-raw-box.open { display: block; }

@media(max-width:680px) {
  .imp-table thead th:nth-child(3),
  .imp-table tbody td:nth-child(3) { display: none; }
  .imp-controls { flex-direction: column; align-items: flex-start; }
  .imp-btn-parse { width: 100%; justify-content: center; }
}

/* ══════════════════════════════════════════════
   MANUAL MENU MANAGER STYLES
   ══════════════════════════════════════════════ */

/* Day tabs */
.man-day-tabs {
  display: flex;
  gap: .35rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.man-day-tab {
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--subtle);
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .55rem 1.3rem;
  border-radius: 3px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  font-weight: 400;
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: .4rem;
  position: relative;
}
.man-day-tab:hover { border-color: var(--bord); color: var(--bord-light); }
.man-day-tab.active {
  background: var(--bord);
  border-color: var(--bord);
  color: #fff;
  font-weight: 700;
}
.man-today-dot {
  width: 6px; height: 6px;
  background: #fff;
  border-radius: 50%;
  display: inline-block;
}
.man-day-tab:not(.active) .man-today-dot { background: var(--bord-light); }
.man-today-label {
  font-size: .6rem;
  opacity: .8;
  font-weight: 400;
  letter-spacing: .05em;
}

/* Day panel */
.man-day-panel { display: none; }
.man-day-panel.active { display: block; }

.man-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1.25rem;
  background: rgba(139,26,43,.1);
  border: 1px solid var(--bord);
  border-radius: 3px 3px 0 0;
  margin-bottom: 0;
}
.man-panel-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: .65rem;
}
.man-panel-date { font-size: .73rem; color: var(--subtle); }

/* Category block */
.man-cat-block {
  background: var(--card);
  border: 1px solid var(--border);
  border-top: none;
  padding: 1.1rem 1.25rem;
}
.man-cat-block + .man-cat-block { border-top: 1px solid var(--borderfaint); }
.man-cat-head {
  font-size: .63rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--bord-light);
  margin-bottom: .75rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.man-cat-head i { font-size: .95rem; opacity: .85; }
.man-cat-limit {
  margin-left: auto;
  font-size: .6rem;
  color: var(--faint);
  font-weight: 400;
  letter-spacing: .05em;
  text-transform: none;
}

/* Item rows */
.man-items { display: flex; flex-direction: column; gap: .45rem; margin-bottom: .65rem; }
.man-item-row {
  display: grid;
  grid-template-columns: 90px 1fr 110px 90px 36px;
  gap: .4rem;
  align-items: center;
  transition: opacity .2s;
}
.man-inp {
  background: var(--darker);
  border: 1px solid var(--border);
  color: var(--cream);
  padding: .5rem .65rem;
  font-size: .83rem;
  border-radius: 2px;
  font-family: 'Lato', sans-serif;
  width: 100%;
  transition: border-color .2s;
}
.man-inp:focus { outline: none; border-color: var(--bord); background: rgba(139,26,43,.06); }
.man-inp::placeholder { color: var(--faint); font-size: .78rem; }
.man-inp-name { font-size: .85rem; }

.man-del-btn {
  background: transparent;
  border: 1px solid var(--borderfaint);
  color: var(--faint);
  padding: .45rem;
  font-size: .9rem;
  cursor: pointer;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  line-height: 1;
}
.man-del-btn:hover { border-color: var(--red); color: var(--red); }

/* Add row button */
.man-add-row-btn {
  background: transparent;
  border: 1px dashed var(--border);
  color: var(--subtle);
  font-size: .75rem;
  padding: .5rem 1rem;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  letter-spacing: .08em;
  display: flex;
  align-items: center;
  gap: .35rem;
  transition: all .2s;
  width: 100%;
  justify-content: center;
}
.man-add-row-btn:hover { border-color: var(--bord); color: var(--bord-light); background: var(--bord-pale); }

.man-limit-reached {
  font-size: .72rem;
  color: var(--green);
  padding: .45rem 1rem;
  display: flex;
  align-items: center;
  gap: .35rem;
  opacity: .7;
}

/* Actions bar */
.man-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 3px 3px;
  gap: .75rem;
  flex-wrap: wrap;
}
.man-save-btn {
  background: var(--bord);
  color: #fff;
  border: none;
  padding: .6rem 1.5rem;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex;
  align-items: center;
  gap: .4rem;
  transition: background .2s;
}
.man-save-btn:hover:not(:disabled) { background: var(--bord-light); }
.man-save-btn:disabled { opacity: .5; cursor: not-allowed; }

.man-clear-btn {
  background: transparent;
  border: 1px solid var(--borderfaint);
  color: var(--faint);
  padding: .6rem 1.1rem;
  font-size: .73rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex;
  align-items: center;
  gap: .4rem;
  transition: all .2s;
}
.man-clear-btn:hover { border-color: var(--red); color: var(--red); }

/* Allergen help */
.man-allerg-help { margin-top: 2rem; }
.man-allerg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: .5rem .75rem;
}
.man-allerg-item {
  font-size: .8rem;
  color: var(--subtle);
  display: flex;
  align-items: center;
  gap: .45rem;
}

/* Responsive */
@media(max-width:680px) {
  .man-item-row {
    grid-template-columns: 70px 1fr 36px;
    grid-template-rows: auto auto;
  }
  .man-inp-name   { grid-column: 2; grid-row: 1; }
  .man-inp-weight { grid-column: 1; grid-row: 1; }
  .man-inp-allerg { grid-column: 1; grid-row: 2; }
  .man-inp-price  { grid-column: 2; grid-row: 2; }
  .man-del-btn    { grid-column: 3; grid-row: 1 / 3; }
}

/* ══════════════════════════════════════════════
   HOMEPAGE STYLES
   ══════════════════════════════════════════════ */

/* Hero quote */
.hero-quote {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: .95rem;
  color: var(--muted);
  margin-top: 1rem;
  opacity: .85;
}
.hero-quote i { color: var(--bord-light); margin-right: .3rem; }
.hero-quote em { font-style: normal; color: var(--subtle); font-size: .82rem; }

/* Info strip */
#home-info-strip { background: var(--card); border-bottom: 1px solid var(--border); padding: 2.5rem 0; }
.home-strip-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.home-strip-card {
  background: var(--darker); border: 1px solid var(--border); border-radius: 3px;
  padding: 1.5rem 1.25rem;
}
.home-strip-card--accent { border-color: var(--bord); background: rgba(139,26,43,.06); }
.home-strip-icon { font-size: 1.6rem; color: var(--bord-light); margin-bottom: .75rem; display: block; }
.home-strip-card h3 { font-family: 'Playfair Display',serif; font-size: 1rem; font-weight:400; color: var(--cream); margin-bottom: .6rem; }
.home-strip-card p { font-size: .85rem; color: var(--subtle); line-height: 1.75; }
.btn-sm { font-size: .68rem !important; padding: .38rem .85rem !important; }

/* Daily preview */
#home-daily-preview { background: var(--dark); padding: 3.5rem 0; }
.home-daily-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 1.5rem; flex-wrap: wrap; gap: .75rem; }
.home-daily-head .section-title { margin-bottom: 0; }
.home-menu-grid { display: grid; grid-template-columns: 1fr 2fr 1fr; gap: 1.25rem; }
.home-menu-cat { background: var(--card); border: 1px solid var(--border); border-radius: 3px; padding: 1.1rem 1.25rem; }
.home-menu-empty {
  background: var(--card); border: 1px solid var(--border); border-radius: 3px;
  padding: 2rem; text-align: center; color: var(--faint);
  display: flex; align-items: center; justify-content: center; gap: .75rem; font-size: .88rem;
}
.home-menu-empty i { font-size: 1.4rem; color: var(--border); }

/* Panorama */
#home-panorama { overflow: hidden; max-height: 280px; }
.panorama-img { width: 100%; height: 280px; object-fit: cover; object-position: center 40%; display: block; }

/* Section cards */
#home-sections { background: var(--surface); padding: 3.5rem 0; }
.hs-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.hs-card { display: block; background: var(--card); border: 1px solid var(--border); border-radius: 3px; overflow: hidden; transition: border-color .25s; text-decoration: none; }
.hs-card:hover { border-color: var(--bord); }
.hs-card-img { height: 180px; background-size: cover; background-position: center; transition: transform .4s; }
.hs-card:hover .hs-card-img { transform: scale(1.03); }
.hs-card-body { padding: 1.1rem 1.25rem; }
.hs-card-body h3 { font-family: 'Playfair Display',serif; font-size: 1rem; font-weight:400; color: var(--cream); margin-bottom: .4rem; }
.hs-card-body p { font-size: .82rem; color: var(--subtle); line-height: 1.65; margin-bottom: .75rem; }
.hs-link { font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--bord-light); display: flex; align-items: center; gap: .3rem; }

/* Partner */
#partner-section { background: var(--card); border-top: 1px solid var(--border); padding: 2.5rem 0; }
.partner-logo-wrap { display: flex; align-items: center; gap: 2rem; justify-content: center; margin-top: 1rem; flex-wrap: wrap; }
.partner-logo { height: 60px; width: auto; filter: brightness(0) invert(.6); }

/* ── PAGE HERO with overlay ── */
.page-hero { position: relative; min-height: 260px; display: flex; align-items: center; justify-content: center; text-align: center; padding: 3.5rem 2rem; overflow: hidden; background: var(--darker); }
.page-hero-overlay { position: absolute; inset: 0; background: rgba(10,6,8,.6); z-index: 1; }
.page-hero .page-hero-content { position: relative; z-index: 2; }
.page-hero .hero-grid { z-index: 0; }

/* ── RESTAURANT PAGE ── */
.rest-services-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap: 1.25rem; margin-top: 1.5rem; }
.rest-service-card { background: var(--card); border: 1px solid var(--border); border-radius: 3px; padding: 1.4rem 1.25rem; transition: border-color .25s; }
.rest-service-card:hover { border-color: var(--bord); }
.rest-service-card i { font-size: 1.6rem; color: var(--bord-light); display: block; margin-bottom: .75rem; }
.rest-service-card h3 { font-family: 'Playfair Display',serif; font-size: .95rem; font-weight:400; color: var(--cream); margin-bottom: .4rem; }
.rest-service-card p { font-size: .83rem; color: var(--subtle); line-height: 1.7; }
.rest-gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 1rem; margin-top: 1.5rem; }
.rest-gallery-img { width: 100%; height: 200px; object-fit: cover; border-radius: 2px; }
.rest-gallery-img--wide { grid-row: span 2; height: auto; min-height: 200px; max-height: 414px; }
.about-img-wrap { overflow: hidden; border-radius: 2px; }

/* ── WEEKLY MENU ── */
.weekly-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: 1rem; margin-top: 1.5rem; }
.weekly-day-card { background: var(--card); border: 1px solid var(--border); border-radius: 3px; overflow: hidden; }
.weekly-day-head { background: var(--bord-pale); border-bottom: 1px solid var(--border); padding: .65rem 1rem; font-family: 'Playfair Display',serif; font-size: .95rem; color: var(--cream); }
.weekly-cat { padding: .75rem 1rem; border-bottom: 1px solid var(--borderfaint); }
.weekly-cat:last-child { border-bottom: none; }
.weekly-cat-label { font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--bord-light); opacity:.85; margin-bottom: .5rem; display: flex; align-items: center; gap: .3rem; }
.weekly-item { margin-bottom: .4rem; padding-bottom: .4rem; border-bottom: 1px dotted var(--borderfaint); }
.weekly-item:last-child { border: none; margin-bottom: 0; padding-bottom: 0; }
.weekly-item-row { display: flex; align-items: baseline; gap: .4rem; }
.weekly-item-name { font-size: .82rem; color: var(--cream); line-height: 1.4; }
.weekly-item-footer { display: flex; align-items: center; gap: .3rem; flex-wrap: wrap; margin-top: .2rem; }

/* Extra info block */
.weekly-extra-info { margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.extra-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.extra-info-block { background: var(--card); border: 1px solid var(--border); border-radius: 3px; padding: 1.25rem; }
.extra-info-block h4 { font-family: 'Playfair Display',serif; font-size: .95rem; font-weight:400; color: var(--cream); margin-bottom: .75rem; display: flex; align-items: center; gap: .4rem; }
.extra-info-block h4 i { color: var(--bord-light); }

/* Allergen full list */
.allergen-section { margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.allergen-section-head { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.allergen-section-head i { font-size: 1.3rem; color: var(--amber); }
.allergen-section-head h3 { font-family: 'Playfair Display',serif; font-size: 1.1rem; font-weight:400; color: var(--cream); }
.allergen-section-head span { font-size: .72rem; color: var(--subtle); letter-spacing: .08em; }
.allergen-full-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr)); gap: .65rem .5rem; margin-bottom: 1.25rem; }
.allergen-full-item { display: flex; align-items: center; gap: .55rem; font-size: .85rem; color: var(--subtle); }
.allergen-tag--lg { font-size: .72rem; padding: .18rem .5rem; min-width: 28px; text-align: center; }
.allergen-note { font-size: .78rem; color: var(--faint); display: flex; align-items: center; gap: .4rem; }
.allergen-note i { color: var(--subtle); }

/* ── KONGRES PAGE ── */
.kongres-events-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: 1rem; margin-top: 1.5rem; }
.kongres-event-item { display: flex; align-items: flex-start; gap: .85rem; background: var(--card); border: 1px solid var(--border); border-radius: 3px; padding: 1.1rem; transition: border-color .2s; }
.kongres-event-item:hover { border-color: var(--bord); }
.kongres-event-item > i { font-size: 1.4rem; color: var(--bord-light); flex-shrink: 0; margin-top: .1rem; }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .home-strip-grid { grid-template-columns: 1fr 1fr; }
  .home-menu-grid  { grid-template-columns: 1fr; }
  .hs-grid         { grid-template-columns: 1fr 1fr; }
  .rest-gallery    { grid-template-columns: 1fr 1fr; }
  .rest-gallery-img--wide { grid-row: span 1; height: 200px; grid-column: span 2; }
  .extra-info-grid { grid-template-columns: 1fr; }
  .weekly-grid     { grid-template-columns: 1fr 1fr; }
}
@media(max-width:600px) {
  .home-strip-grid { grid-template-columns: 1fr; }
  .hs-grid         { grid-template-columns: 1fr; }
  .rest-gallery    { grid-template-columns: 1fr; }
  .rest-gallery-img--wide { grid-column: span 1; }
  .weekly-grid     { grid-template-columns: 1fr; }
  .allergen-full-grid { grid-template-columns: 1fr 1fr; }
}

@media(max-width:900px) {
  #hero .container { grid-template-columns:1fr !important; gap:2rem !important; padding-top:6rem !important; }
  .hero-story { display:none; }
}

/* ══════════════════════════════════════════════
   KONTAKT PAGE
   ══════════════════════════════════════════════ */
.kontakt-grid {
  margin-bottom: 3rem;
}
.kontakt-udaje {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.kontakt-block {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1.25rem;
  transition: border-color .2s;
}
.kontakt-block:hover { border-color: var(--bord); }
.kontakt-icon {
  width: 38px;
  height: 38px;
  background: var(--bord-pale);
  border: 1px solid var(--border);
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--bord-light);
  font-size: 1.15rem;
}
.kontakt-block h3 {
  font-family: 'Lato', sans-serif;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--bord-light);
  font-weight: 700;
  margin-bottom: .4rem;
}
.kontakt-block p,
.kontakt-block address {
  font-size: .85rem;
  color: var(--subtle);
  line-height: 1.75;
  font-style: normal;
}
.kontakt-block a { color: var(--subtle); transition: color .2s; }
.kontakt-block a:hover { color: var(--bord-light); }

/* Mapa */
.kontakt-mapa-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.kontakt-mapa-head {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: var(--bord-pale);
}
.kontakt-mapa-head i { color: var(--bord-light); font-size: 1.1rem; }
.kontakt-mapa-head h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  font-weight: 400;
  color: var(--cream);
}
.kontakt-mapa iframe { display: block; width: 100%; filter: grayscale(20%) contrast(95%); }
.kontakt-mapa-footer {
  padding: .85rem 1.25rem;
  border-top: 1px solid var(--borderfaint);
  display: flex;
  justify-content: flex-end;
}

@media(max-width:600px) {
  .kontakt-udaje { grid-template-columns: 1fr; }
}

/* ── KONTAKT FOTOGRAFIE ── */
.kontakt-foto-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 1.25rem;
}
.kontakt-foto-head {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: var(--bord-pale);
}
.kontakt-foto-head i { color: var(--bord-light); font-size: 1.1rem; }
.kontakt-foto-head h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  font-weight: 400;
  color: var(--cream);
}
.kontakt-foto-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 4px;
  padding: 4px;
  background: var(--borderfaint);
}
.kontakt-foto-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  transition: opacity .2s;
}
.kontakt-foto-img:hover { opacity: .9; }
.kontakt-foto-img--wide {
  grid-column: 1;
  grid-row: 1 / 3;
  height: 100%;
  min-height: 200px;
  max-height: 408px;
}
@media(max-width:680px) {
  .kontakt-foto-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .kontakt-foto-img--wide { grid-column: span 2; grid-row: 1; height: 200px; }
  .kontakt-foto-img { height: 150px; }
}

/* ── FOTO STRIP na úvodnej stránke ── */
.home-photo-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  height: 240px;
  gap: 3px;
}
.home-photo-strip-img {
  background-size: cover;
  background-position: center;
  transition: transform .4s ease;
  overflow: hidden;
}
.home-photo-strip-img:hover {
  transform: scale(1.03);
}

/* ── FOTO GRID na stránke reštaurácie ── */
.rest-photo-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 220px 220px;
  gap: 6px;
  margin-top: 1.5rem;
}
.rest-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2px;
  display: block;
  transition: opacity .2s;
}
.rest-photo:hover { opacity: .9; }
.rest-photo--wide {
  grid-column: 1;
  grid-row: 1 / 3;
}

@media(max-width:768px) {
  .home-photo-strip { grid-template-columns: 1fr 1fr; height: 300px; }
  .rest-photo-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .rest-photo--wide { grid-column: span 2; grid-row: 1; height: 200px; }
  .rest-photo { height: 150px; }
}
@media(max-width:480px) {
  .home-photo-strip { grid-template-columns: 1fr; height: auto; }
  .home-photo-strip-img { height: 160px; }
}

.menu-day-date { font-size: .82rem; color: rgba(255,255,255,.75); font-weight: 300; letter-spacing: .03em; }

/* ══════════════════════════════════════════════
   MENU MANAGER v2 — SETTINGS, WEEK TABS, VACATION
   ══════════════════════════════════════════════ */

/* Nastavenia limitov */
.mgr-settings-bar {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}
.mgr-settings-title {
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--bord-light);
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-shrink: 0;
}
.mgr-settings-grid {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.mgr-setting {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.mgr-setting label {
  font-size: .78rem;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: .3rem;
  white-space: nowrap;
}
.mgr-setting label i { color: var(--bord-light); }
.mgr-spinner {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.mgr-spinner button {
  background: var(--surface);
  border: none;
  color: var(--cream);
  width: 30px;
  height: 32px;
  font-size: 1.1rem;
  cursor: pointer;
  transition: background .15s;
  line-height: 1;
  font-family: 'Lato', sans-serif;
}
.mgr-spinner button:hover { background: var(--bord); }
.mgr-spinner input {
  width: 44px;
  text-align: center;
  background: var(--darker);
  border: none;
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  color: var(--cream);
  font-size: .9rem;
  font-weight: 700;
  height: 32px;
  padding: 0;
  -moz-appearance: textfield;
}
.mgr-spinner input::-webkit-outer-spin-button,
.mgr-spinner input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Týždenné záložky */
.mgr-week-tabs {
  display: flex;
  gap: .5rem;
  margin-bottom: 0;
  flex-wrap: wrap;
}
.mgr-week-tab {
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--subtle);
  font-size: .75rem;
  letter-spacing: .06em;
  padding: .6rem 1.1rem;
  border-radius: 3px 3px 0 0;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .2rem;
  transition: all .2s;
  border-bottom: none;
}
.mgr-week-tab:hover { border-color: var(--bord); color: var(--bord-light); }
.mgr-week-tab.active { background: var(--darker); border-color: var(--bord); color: var(--cream); font-weight: 700; }
.mgr-week-tab i { font-size: 1rem; }
.mgr-week-range { font-size: .65rem; color: var(--subtle); font-weight: 400; }
.mgr-vacation-tab { border-color: var(--amber) !important; }
.mgr-vacation-tab:hover,
.mgr-vacation-tab.active { background: rgba(196,138,42,.1) !important; color: var(--amber) !important; }

/* Záložky dní */
.mgr-week-panel {
  background: var(--darker);
  border: 1px solid var(--bord);
  border-radius: 0 3px 3px 3px;
  padding: 0;
  overflow: hidden;
}
.mgr-day-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
}
.mgr-day-tab {
  background: transparent;
  border: none;
  border-right: 1px solid var(--borderfaint);
  color: var(--subtle);
  font-family: 'Lato', sans-serif;
  padding: .6rem .9rem;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .15rem;
  transition: all .15s;
  min-width: 52px;
}
.mgr-day-tab:hover { background: var(--bord-pale); color: var(--bord-light); }
.mgr-day-tab.active { background: var(--bord-pale); color: var(--cream); border-bottom: 2px solid var(--bord); }
.mgr-day-tab--weekend { color: var(--amber); opacity: .7; }
.mgr-day-tab--weekend.active { color: var(--amber); opacity: 1; }
.mgr-day-tab-short { font-size: .78rem; font-weight: 700; letter-spacing: .05em; }
.mgr-day-tab-date  { font-size: .65rem; }

/* Panel dňa */
.mgr-day-panel { display: none; }
.mgr-day-panel.active { display: block; }
.mgr-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .8rem 1.25rem;
  background: rgba(139,26,43,.08);
  border-bottom: 1px solid var(--borderfaint);
}
.mgr-panel-title {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: .75rem;
}
.mgr-panel-date {
  font-family: 'Lato', sans-serif;
  font-size: .78rem;
  color: rgba(255,255,255,.6);
  font-weight: 300;
}

/* Dovolenka panel */
.mgr-vacation-panel {
  background: var(--darker);
  border: 1px solid var(--amber);
  border-radius: 0 3px 3px 3px;
  overflow: hidden;
  margin-bottom: 1.25rem;
}
.mgr-vacation-inner { padding: 1.5rem 1.25rem; }
.mgr-vacation-inner h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--amber);
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .5rem;
}
.mgr-vacation-desc { font-size: .83rem; color: var(--subtle); margin-bottom: 1.1rem; }
.mgr-vacation-form {}
.mgr-vacation-row { display: grid; grid-template-columns: 1fr 1fr 2fr; gap: .75rem; margin-bottom: 1rem; }
.mgr-vacation-field label { font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--subtle); display: block; margin-bottom: .35rem; }
.mgr-vacation-field input {
  width: 100%;
  background: var(--dark);
  border: 1px solid var(--border);
  color: var(--cream);
  padding: .5rem .75rem;
  font-size: .85rem;
  border-radius: 2px;
  font-family: 'Lato', sans-serif;
}
.mgr-vacation-field input:focus { outline: none; border-color: var(--amber); }
.mgr-vacation-field--wide { grid-column: span 1; }
.mgr-vacation-actions { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.mgr-btn-vacation-save {
  background: var(--amber);
  color: var(--dark);
  border: none;
  padding: .55rem 1.25rem;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex; align-items: center; gap: .35rem;
  transition: opacity .2s;
}
.mgr-btn-vacation-save:hover { opacity: .85; }
.mgr-btn-vacation-cancel {
  background: transparent;
  border: 1px solid var(--green);
  color: var(--green);
  padding: .55rem 1.25rem;
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex; align-items: center; gap: .35rem;
  transition: all .2s;
}
.mgr-btn-vacation-cancel:hover { background: rgba(45,122,79,.12); }
.mgr-vacation-active-badge {
  background: rgba(196,138,42,.15);
  border: 1px solid var(--amber);
  color: var(--amber);
  font-size: .72rem;
  padding: .35rem .75rem;
  border-radius: 2px;
  display: flex; align-items: center; gap: .35rem;
}
.mgr-vacation-preview {
  margin-top: 1rem;
  padding: .75rem 1rem;
  background: rgba(196,138,42,.08);
  border: 1px solid rgba(196,138,42,.25);
  border-radius: 2px;
  font-size: .82rem;
  color: var(--muted);
}
.mgr-vacation-preview strong { color: var(--amber); margin-right: .4rem; }

@media(max-width:680px) {
  .mgr-vacation-row { grid-template-columns: 1fr; }
  .mgr-settings-bar { flex-direction: column; align-items: flex-start; gap: .75rem; }
  .mgr-settings-grid { gap: .75rem; }
}

/* ── VACATION NOTICE ── */
.vacation-notice {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  background: rgba(196,138,42,.1);
  border: 1px solid var(--amber);
  border-radius: 3px;
  padding: 2rem 1.5rem;
  margin: 2rem 0;
}
.vacation-notice i {
  font-size: 2.2rem;
  color: var(--amber);
  flex-shrink: 0;
}
.vacation-notice strong {
  display: block;
  font-size: 1.1rem;
  color: var(--cream);
  margin-bottom: .4rem;
  font-family: 'Playfair Display', serif;
  font-weight: 400;
}
.vacation-notice p { font-size: .9rem; color: var(--muted); margin-bottom: .3rem; }
.vacation-dates { font-size: .78rem !important; color: var(--subtle) !important; }

/* ── MANAGER — uložené indikátory ── */
.mgr-panel-saved-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .72rem;
  font-family: 'Lato', sans-serif;
  color: var(--green);
  background: rgba(45,122,79,.12);
  border: 1px solid rgba(45,122,79,.3);
  padding: .25rem .7rem;
  border-radius: 20px;
  font-weight: 700;
}
.mgr-panel-empty-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .72rem;
  font-family: 'Lato', sans-serif;
  color: var(--faint);
  border: 1px solid var(--borderfaint);
  padding: .25rem .7rem;
  border-radius: 20px;
}
.mgr-cat-saved-count {
  margin-left: auto;
  font-size: .65rem;
  color: var(--green);
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: none;
}
.mgr-cat-saved-count i { font-size: .75rem; }

/* Uložené riadky — jemný zelený ľavý okraj */
.man-item-row--saved {
  border-left: 2px solid rgba(45,122,79,.4);
  padding-left: .4rem;
}
.man-item-row--saved .man-inp-name {
  color: var(--cream);
  font-weight: 500;
}

/* Prázdny stav */
.mgr-empty-row {
  font-size: .8rem;
  color: var(--faint);
  font-style: italic;
  padding: .4rem 0 .2rem;
}

/* Počítadlo v záložke dňa */
.mgr-day-tab-count {
  background: var(--green);
  color: #fff;
  font-size: .58rem;
  font-weight: 700;
  padding: .1rem .35rem;
  border-radius: 10px;
  line-height: 1.4;
  min-width: 18px;
  text-align: center;
}
.mgr-day-tab--weekend .mgr-day-tab-count {
  background: var(--amber);
}

/* ── IMPORT SEKCIA ── */
.mgr-import-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-top: 1.5rem;
  overflow: hidden;
}
.mgr-import-toggle {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--muted);
  font-size: .82rem;
  font-family: 'Lato', sans-serif;
  padding: .9rem 1.25rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: .5rem;
  transition: background .2s, color .2s;
  text-align: left;
}
.mgr-import-toggle i:first-child { color: var(--bord-light); font-size: 1rem; }
.mgr-import-toggle:hover { background: var(--bord-pale); color: var(--cream); }
.mgr-import-panel {
  padding: 1.25rem;
  border-top: 1px solid var(--border);
}
.mgr-import-info {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  background: rgba(139,26,43,.06);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: .85rem 1rem;
  margin-bottom: 1.1rem;
  font-size: .83rem;
  color: var(--muted);
}
.mgr-import-info i { color: var(--bord-light); font-size: 1.1rem; flex-shrink: 0; margin-top: .1rem; }
.mgr-import-info strong { color: var(--cream); }
.mgr-upload-zone {
  position: relative;
  border: 2px dashed var(--border);
  border-radius: 3px;
  padding: 2rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  background: var(--darker);
}
.mgr-upload-zone:hover,
.mgr-upload-zone.drag-over { border-color: var(--bord); background: var(--bord-pale); }
.mgr-upload-zone.has-file  { border-color: var(--green); border-style: solid; }

/* Importované riadky — jantárový ľavý okraj (čakajú na uloženie) */
.man-item-row--imported {
  border-left: 2px solid var(--amber);
  padding-left: .4rem;
  animation: fadeInRow .3s ease;
}
@keyframes fadeInRow {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── IMPORT SEKCIA v2 — navrchu ── */
.mgr-import-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-bottom: 1.25rem;
  overflow: hidden;
}
.mgr-import-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  cursor: pointer;
  transition: background .2s;
  user-select: none;
}
.mgr-import-header:hover { background: var(--bord-pale); }
.mgr-import-header strong { font-size: .9rem; color: var(--cream); }
.mgr-import-body {
  padding: 1.25rem;
  border-top: 1px solid var(--border);
}
.mgr-import-info {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  background: rgba(139,26,43,.06);
  border: 1px solid var(--borderfaint);
  border-radius: 3px;
  padding: .85rem 1rem;
  margin-bottom: 1.1rem;
  font-size: .83rem;
  color: var(--muted);
}
.mgr-import-info i { color: var(--bord-light); font-size: 1.1rem; flex-shrink: 0; margin-top: .1rem; }
.mgr-import-info strong { color: var(--cream); }

/* Drop zóna */
.mgr-drop-zone {
  position: relative;
  border: 2px dashed var(--border);
  border-radius: 3px;
  padding: 2.25rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  background: var(--darker);
}
.mgr-drop-zone input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.mgr-drop-zone:hover,
.mgr-drop-zone.drag-over {
  border-color: var(--bord);
  background: var(--bord-pale);
}
.mgr-drop-zone.has-file {
  border-color: var(--green);
  border-style: solid;
  background: rgba(45,122,79,.05);
}
.mgr-file-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: rgba(45,122,79,.15);
  border: 1px solid rgba(45,122,79,.3);
  color: var(--green);
  font-size: .82rem;
  padding: .3rem .75rem;
  border-radius: 20px;
}

/* Dovolenka panel — teraz je to mgr-week-panel */
.mgr-vacation-panel {
  border-color: var(--amber) !important;
}
.mgr-vacation-panel .mgr-vacation-inner {
  padding: 1.5rem 1.25rem;
}

/* ══════════════════════════════════════════════
   ZÁKAZNÍCKY SYSTÉM — MÔJ ÚČET
   ══════════════════════════════════════════════ */

/* Alerty */
.acct-alert {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: 1rem 1.25rem;
  border-radius: 3px;
  margin-bottom: 1.5rem;
  font-size: .88rem;
}
.acct-alert i { font-size: 1.2rem; flex-shrink: 0; margin-top: .1rem; }
.acct-alert--success { background: rgba(45,122,79,.12); border: 1px solid rgba(45,122,79,.3); color: var(--green); }
.acct-alert--success p { color: var(--cream); }
.acct-alert--info { background: rgba(139,26,43,.08); border: 1px solid var(--border); color: var(--bord-light); }
.acct-alert--info p { color: var(--muted); }
.acct-alert--error { background: rgba(226,75,74,.1); border: 1px solid rgba(226,75,74,.3); color: var(--red); }
.acct-alert--error p { color: var(--cream); }

/* Tabs Login/Register */
.acct-tabs { display: flex; gap: .5rem; margin-bottom: 1.5rem; }
.acct-tab {
  flex: 1;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--subtle);
  padding: .85rem 1.25rem;
  border-radius: 3px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  font-size: .9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  transition: all .2s;
}
.acct-tab:hover { border-color: var(--bord); color: var(--bord-light); }
.acct-tab.active { background: var(--bord); border-color: var(--bord); color: #fff; font-weight: 700; }

.acct-panel { display: none; }
.acct-panel.active { display: block; }

/* Card */
.acct-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 2rem;
}
.acct-card-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.3rem;
  font-weight: 400;
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .5rem;
}
.acct-card-title i { color: var(--bord-light); }
.acct-card-sub { font-size: .85rem; color: var(--subtle); margin-bottom: 1.5rem; line-height: 1.7; }

/* Form */
.acct-form { display: flex; flex-direction: column; gap: .25rem; }
.acct-form label { font-size: .78rem; color: var(--subtle); margin-top: .75rem; margin-bottom: .3rem; }
.acct-form input {
  background: var(--darker);
  border: 1px solid var(--border);
  color: var(--cream);
  padding: .7rem .9rem;
  font-size: .9rem;
  border-radius: 2px;
  font-family: 'Lato', sans-serif;
}
.acct-form input:focus { outline: none; border-color: var(--bord); }
.acct-form input::placeholder { color: var(--faint); }

.acct-btn-primary {
  background: var(--bord);
  color: #fff;
  border: none;
  padding: .85rem 1.5rem;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  margin-top: 1.25rem;
  transition: background .2s;
}
.acct-btn-primary:hover:not(:disabled) { background: var(--bord-light); }
.acct-btn-primary:disabled { opacity: .6; cursor: not-allowed; }

.acct-btn-outline {
  background: transparent;
  border: 1px solid var(--bord);
  color: var(--bord-light);
  padding: .7rem 1.4rem;
  font-size: .82rem;
  border-radius: 2px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  transition: all .2s;
  text-decoration: none;
}
.acct-btn-outline:hover { background: var(--bord); color: #fff; }
.acct-btn-sm { padding: .5rem 1rem; font-size: .75rem; }

.acct-resend-link { font-size: .82rem; color: var(--subtle); margin-top: 1.25rem; text-align: center; }
.acct-resend-link a { color: var(--bord-light); }
.acct-resend-form { margin-top: .85rem; display: flex; gap: .5rem; flex-wrap: wrap; }
.acct-resend-form input {
  flex: 1; min-width: 180px;
  background: var(--darker); border: 1px solid var(--border); color: var(--cream);
  padding: .55rem .8rem; border-radius: 2px; font-size: .85rem;
}

/* Message */
.acct-msg { padding: .75rem 1rem; border-radius: 3px; font-size: .85rem; margin-bottom: 1rem; }
.acct-msg--success { background: rgba(45,122,79,.12); border: 1px solid rgba(45,122,79,.3); color: var(--green); }
.acct-msg--error { background: rgba(226,75,74,.1); border: 1px solid rgba(226,75,74,.3); color: var(--red); }

/* Welcome bar */
.acct-welcome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 1rem;
}

/* Order box */
.acct-order-box {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1.75rem;
  margin-bottom: 2rem;
}
.acct-order-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.acct-order-title { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 400; color: var(--cream); margin-top: .3rem; }
.acct-status-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .75rem;
  padding: .4rem .9rem;
  border-radius: 20px;
  font-weight: 600;
  white-space: nowrap;
}
.acct-status-pill--open { background: rgba(45,122,79,.15); border: 1px solid var(--green); color: var(--green); }
.acct-status-pill--closed { background: rgba(226,75,74,.12); border: 1px solid var(--red); color: var(--red); }

/* Menu kategórie v objednávke */
.acct-menu-cat { margin-bottom: 1.5rem; }
.acct-menu-cat-head {
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bord-light);
  margin-bottom: .75rem;
  display: flex;
  align-items: center;
  gap: .4rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--borderfaint);
}
.acct-menu-item {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: .75rem .9rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-bottom: .5rem;
  cursor: pointer;
  transition: all .2s;
  background: var(--darker);
}
.acct-menu-item:hover { border-color: var(--bord); background: var(--bord-pale); }
.acct-item-checkbox {
  width: 19px; height: 19px;
  accent-color: var(--bord);
  cursor: pointer;
  flex-shrink: 0;
}
.acct-menu-item-info { flex: 1; display: flex; flex-direction: column; gap: .2rem; }
.acct-menu-item-name { font-size: .92rem; color: var(--cream); }
.acct-menu-item-price { font-size: .9rem; color: var(--bord-light); font-weight: 700; white-space: nowrap; }

/* Delivery block */
.acct-delivery-block {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.acct-delivery-label { font-size: .78rem; color: var(--subtle); margin-bottom: .75rem; }
.acct-delivery-options { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.acct-radio-card {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  cursor: pointer;
  transition: all .2s;
  background: var(--darker);
}
.acct-radio-card:hover { border-color: var(--bord); }
.acct-radio-card input[type=radio] { accent-color: var(--bord); }
.acct-radio-card i { color: var(--bord-light); font-size: 1.2rem; }
.acct-radio-card span { font-size: .85rem; color: var(--cream); }
.acct-radio-card input:checked ~ span { font-weight: 700; }
.acct-delivery-block textarea {
  width: 100%;
  background: var(--darker);
  border: 1px solid var(--border);
  color: var(--cream);
  padding: .65rem .85rem;
  border-radius: 2px;
  font-size: .85rem;
  font-family: 'Lato', sans-serif;
  resize: vertical;
}
.acct-btn-order { width: 100%; padding: 1rem; font-size: .92rem; }

/* History table */
.acct-history { margin-top: 2.5rem; }
.acct-history-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.acct-history-empty { font-size: .85rem; color: var(--faint); font-style: italic; }
.acct-history-table { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border); border-radius: 3px; overflow: hidden; }
.acct-history-table thead th {
  padding: .6rem .9rem;
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--subtle);
  text-align: left;
  border-bottom: 1px solid var(--border);
  background: var(--darker);
}
.acct-history-table tbody td { padding: .6rem .9rem; font-size: .85rem; color: var(--cream); border-bottom: 1px solid var(--borderfaint); }
.acct-history-table tbody tr:last-child td { border-bottom: none; }
.acct-status-badge { font-size: .72rem; padding: .2rem .55rem; border-radius: 3px; font-weight: 600; }
.acct-status-badge--new { background: rgba(196,138,42,.15); color: var(--amber); }
.acct-status-badge--done { background: rgba(45,122,79,.15); color: var(--green); }
.acct-status-badge--cancelled { background: rgba(226,75,74,.12); color: var(--red); }

@media(max-width:600px) {
  .acct-delivery-options { grid-template-columns: 1fr; }
  .acct-tabs { flex-direction: column; }
  .acct-card { padding: 1.5rem; }
}

/* ══════════════════════════════════════════════
   KOŠÍK — slide-in panel
   ══════════════════════════════════════════════ */
.cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,6,8,.55);
  z-index: 1998;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s;
}
.cart-overlay.open { opacity: 1; visibility: visible; }

.cart-panel {
  position: fixed;
  top: 0;
  right: -420px;
  width: 400px;
  max-width: 92vw;
  height: 100vh;
  background: var(--dark);
  border-left: 1px solid var(--border);
  z-index: 1999;
  display: flex;
  flex-direction: column;
  transition: right .3s ease;
  box-shadow: -8px 0 30px rgba(0,0,0,.3);
}
.cart-panel.open { right: 0; }

.cart-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--card);
}
.cart-panel-header h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  font-weight: 400;
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: .5rem;
}
.cart-panel-header h3 i { color: var(--bord-light); }
.cart-close-btn {
  background: transparent;
  border: none;
  color: var(--subtle);
  font-size: 1.3rem;
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: all .2s;
}
.cart-close-btn:hover { background: var(--bord-pale); color: var(--cream); }

.cart-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 1.25rem;
}
.cart-empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--faint);
}
.cart-empty i { font-size: 2.5rem; display: block; margin-bottom: 1rem; opacity: .5; }
.cart-empty p { font-size: .95rem; color: var(--subtle); margin-bottom: .3rem; }
.cart-empty span { font-size: .8rem; }

.cart-item {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: .9rem 1rem;
  margin-bottom: .75rem;
}
.cart-item-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: .5rem;
  margin-bottom: .5rem;
}
.cart-item-name { font-size: .9rem; color: var(--cream); font-weight: 500; line-height: 1.3; }
.cart-item-day {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .65rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--bord-light);
  background: var(--bord-pale);
  padding: .15rem .5rem;
  border-radius: 10px;
  margin-top: .3rem;
}
.cart-item-remove {
  background: transparent;
  border: none;
  color: var(--faint);
  cursor: pointer;
  font-size: 1rem;
  flex-shrink: 0;
  padding: .15rem;
  transition: color .2s;
}
.cart-item-remove:hover { color: var(--red); }
.cart-item-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cart-qty-control {
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.cart-qty-control button {
  background: var(--darker);
  border: none;
  color: var(--cream);
  width: 26px;
  height: 26px;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
}
.cart-qty-control button:hover { background: var(--bord); }
.cart-qty-control span {
  width: 32px;
  text-align: center;
  font-size: .85rem;
  color: var(--cream);
  font-weight: 700;
}
.cart-item-price { font-size: .88rem; color: var(--bord-light); font-weight: 700; }

.cart-panel-footer {
  border-top: 1px solid var(--border);
  padding: 1.25rem 1.5rem;
  background: var(--card);
}
.cart-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  font-size: .95rem;
  color: var(--muted);
}
.cart-total-row strong { color: var(--cream); font-size: 1.2rem; }
.cart-checkout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  background: var(--bord);
  color: #fff;
  padding: .85rem;
  border-radius: 3px;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-decoration: none;
  transition: background .2s;
}
.cart-checkout-btn:hover { background: var(--bord-light); }

/* Tlačidlo "Pridať do košíka" pri jedlách v dennom menu */
.menu-add-to-cart-btn {
  background: transparent;
  border: 1px solid var(--bord);
  color: var(--bord-light);
  width: 30px;
  height: 30px;
  border-radius: 3px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  transition: all .2s;
  flex-shrink: 0;
}
.menu-add-to-cart-btn:hover { background: var(--bord); color: #fff; }
.menu-add-to-cart-btn.added { background: var(--green); border-color: var(--green); color: #fff; }

@media(max-width: 480px) {
  .cart-panel { width: 100%; max-width: 100vw; }
}

/* ── Súhrn košíka v rámci stránky Môj účet ── */
.acct-cart-summary {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
.acct-cart-summary-head {
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bord-light);
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .9rem;
}
.acct-cart-line {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .6rem 0;
  border-bottom: 1px dotted var(--borderfaint);
}
.acct-cart-line-name { flex: 1; font-size: .87rem; color: var(--cream); }
.acct-cart-line-price { font-size: .85rem; color: var(--bord-light); font-weight: 700; white-space: nowrap; min-width: 60px; text-align: right; }
.acct-cart-total-row {
  display: flex;
  justify-content: space-between;
  padding: .85rem 0 .5rem;
  font-size: .95rem;
  color: var(--muted);
}
.acct-cart-total-row strong { color: var(--cream); font-size: 1.15rem; }

.acct-menu-item--cart { cursor: default; }
.acct-menu-item--cart:hover { border-color: var(--border); background: var(--darker); }
