/* ═══════════════════════════════════════
   KULTA RESTAURANT ADMIN — admin.css
   Deep charcoal + warm gold theme
   ═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Cormorant+Garamond:ital,wght@0,500;0,600;1,400;1,500&display=swap');

:root {
  --gold:       #B8973C;
  --gold-l:     #D4B86A;
  --gold-pale:  rgba(184,151,60,.12);
  --navy:       #0F0D0A;
  --navy-2:     #1A1713;
  --navy-3:     #252118;
  --charcoal:   #2C2820;
  --emerald:    #10B981;
  --violet:     #8B5CF6;
  --sky:        #0EA5E9;
  --urgent:     #EF4444;
  --ok:         #10B981;
  --amber:      #F59E0B;
  --bg:         #F7F5F0;
  --bg-2:       #EEE9E0;
  --white:      #FFFFFF;
  --border:     rgba(184,151,60,.12);
  --border-mid: rgba(184,151,60,.25);
  --text-100:   #1A1612;
  --text-300:   #4A4030;
  --text-500:   #9A8A70;
  --shadow-sm:  0 2px 8px rgba(15,13,10,.06);
  --shadow-md:  0 4px 24px rgba(15,13,10,.10);
  --shadow-lg:  0 8px 40px rgba(15,13,10,.14);
  --font:       'Plus Jakarta Sans', sans-serif;
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --r:          10px;
  --r-sm:       6px;
  --sidebar-w:  230px;
  --topbar-h:   58px;
  --banner-h:   34px;
  --ease:       cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text-100);-webkit-font-smoothing:antialiased;overflow-x:hidden}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}

/* ── BANNER ── */
.adm-banner{
  position:fixed;top:0;left:0;right:0;z-index:200;height:var(--banner-h);
  background:var(--navy);border-bottom:1px solid rgba(184,151,60,.15);
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:.73rem;color:rgba(255,255,255,.5);flex-wrap:wrap;padding:0 16px;
}
.adm-banner .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold)}
.adm-banner b{color:#fff;font-weight:600}
.adm-banner a{color:var(--gold-l);display:inline-flex;align-items:center;gap:4px;transition:.2s}
.adm-banner a:hover{color:#fff}
.adm-banner .bn-sep{opacity:.3}

/* ── SHELL ── */
.adm-shell{display:flex;padding-top:var(--banner-h);min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{
  position:fixed;top:var(--banner-h);left:0;bottom:0;width:var(--sidebar-w);
  background:var(--navy);display:flex;flex-direction:column;z-index:100;
  border-right:1px solid rgba(184,151,60,.10);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.sidebar-logo{
  display:flex;align-items:center;gap:.75rem;
  padding:1.2rem 1.1rem;border-bottom:1px solid rgba(184,151,60,.08);flex-shrink:0;
}
.logo-mark{
  width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--gold) 0%,#8A6D1A 100%);
  display:grid;place-items:center;font-size:1rem;color:#fff;flex-shrink:0;
  box-shadow:0 2px 8px rgba(184,151,60,.35);
}
.sidebar-logo-name{
  color:#fff;font-size:1.15rem;font-weight:300;letter-spacing:.05em;line-height:1.1;
  font-family:var(--font-serif);font-style:italic;
}
.sidebar-logo-name b{color:var(--gold-l);font-weight:600}
.sidebar-logo-sub{font-size:.59rem;color:rgba(255,255,255,.28);letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.sidebar-nav{flex:1;padding:.7rem 0;overflow-y:auto}
.sidebar-nav-item{
  display:flex;align-items:center;gap:.7rem;
  width:100%;padding:.65rem 1.1rem;
  font-size:.81rem;font-weight:500;color:rgba(255,255,255,.42);
  transition:background .15s,color .15s;position:relative;letter-spacing:.01em;
}
.sidebar-nav-item i{font-size:1rem;flex-shrink:0}
.sidebar-nav-item:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.75)}
.sidebar-nav-item.active{color:var(--gold-l);background:rgba(184,151,60,.1)}
.sidebar-nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold);border-radius:0 2px 2px 0}
.sidebar-foot{padding:.75rem 1.1rem;font-size:.63rem;color:rgba(255,255,255,.18);border-top:1px solid rgba(255,255,255,.04);flex-shrink:0}
.sidebar-overlay{position:fixed;inset:0;z-index:99;background:rgba(15,13,10,.6);display:none;backdrop-filter:blur(2px)}
.sidebar-overlay.show{display:block}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ── */
.topbar{
  position:sticky;top:var(--banner-h);z-index:50;height:var(--topbar-h);
  background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;
  box-shadow:var(--shadow-sm);
}
.topbar-left{display:flex;align-items:center;gap:.75rem}
.topbar-burger{display:none;font-size:1.2rem;color:var(--text-300);padding:.3rem}
.topbar-title{font-size:.95rem;font-weight:700;color:var(--text-100);letter-spacing:-.01em}
.topbar-right{display:flex;align-items:center;gap:.85rem}
.online{display:flex;align-items:center;gap:.4rem;font-size:.74rem;color:var(--text-500)}
.online .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 6px var(--ok)}
.demo-badge{padding:.2rem .55rem;border-radius:4px;background:var(--gold);color:var(--navy);font-size:.63rem;font-weight:800;letter-spacing:.09em}
.adm-lang{display:flex;gap:.2rem}
.adm-lb{padding:.22rem .44rem;border-radius:4px;font-size:.7rem;font-weight:700;color:var(--text-500);border:1px solid transparent;transition:.15s}
.adm-lb:hover{color:var(--text-100)}
.adm-lb.adm-lb-active{color:var(--gold);border-color:var(--border-mid);background:var(--gold-pale)}
.topbar-site{display:flex;align-items:center;gap:.3rem;font-size:.76rem;font-weight:600;color:var(--gold);padding:.3rem .75rem;border-radius:var(--r-sm);border:1px solid var(--border);transition:.15s}
.topbar-site:hover{background:var(--gold-pale)}

/* ── CONTENT ── */
.content{flex:1;padding:1.4rem;display:flex;flex-direction:column;gap:1.2rem}

/* ── CARDS ── */
.card{background:var(--white);border-radius:var(--r);padding:1.2rem 1.4rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.card-title{font-size:.85rem;font-weight:700;color:var(--text-100);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.card-title i{color:var(--gold)}
.section-sub{font-size:.78rem;color:var(--text-500);background:var(--gold-pale);border:1px solid var(--border);border-radius:var(--r-sm);padding:.6rem .9rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}
.section-sub i{color:var(--gold)}

/* ── STAT GRID ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.stat-card{background:var(--white);border-radius:var(--r);padding:1.2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.5rem;transition:.2s}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.stat-card .ic{width:40px;height:40px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.stat-card-value{font-size:1.75rem;font-weight:700;color:var(--text-100);letter-spacing:-.04em;line-height:1}
.stat-card-value small{font-size:.82rem;font-weight:500;color:var(--text-500)}
.stat-card-label{font-size:.72rem;color:var(--text-500);font-weight:500}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.grid-3{display:grid;grid-template-columns:1fr 2fr;gap:1rem}
.an-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}

/* ── TOOLBAR ── */
.toolbar{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-bottom:.5rem}
.search-box{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);background:var(--bg);flex:1;min-width:180px}
.search-box i{color:var(--text-500);font-size:.9rem}
.search-box input{border:none;background:none;outline:none;font-size:.82rem;color:var(--text-100);width:100%}
.adm-select{padding:.42rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);background:var(--white);font-size:.8rem;color:var(--text-100);outline:none}
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}
.pill{padding:.28rem .75rem;border-radius:20px;font-size:.74rem;font-weight:600;border:1.5px solid var(--border-mid);color:var(--text-300);background:var(--white);transition:.15s;cursor:pointer}
.pill:hover{border-color:var(--gold);color:var(--gold)}
.pill.active{background:var(--gold);border-color:var(--gold);color:#fff}

/* ── BUTTONS ── */
.btn-a{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:var(--r-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:.15s;border:1.5px solid transparent}
.btn-a-primary{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-a-primary:hover{background:#A08230;border-color:#A08230}
.btn-a-outline{background:transparent;border-color:var(--border-mid);color:var(--text-300)}
.btn-a-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:.32rem .75rem;font-size:.76rem}

/* ── TABLE ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.8rem}
thead tr{border-bottom:2px solid var(--border)}
th{padding:.6rem .9rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--text-500);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
td{padding:.65rem .9rem;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--gold-pale)}
.cell-doc{display:flex;align-items:center;gap:.6rem}
.d-avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:700;flex-shrink:0}
.cell-name{font-weight:600;font-size:.82rem}
.cell-sub{font-size:.72rem;color:var(--text-500)}
.row-actions{display:flex;gap:.3rem;align-items:center}
.ia{width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:.9rem;color:var(--text-500);transition:.15s;border:1px solid transparent}
.ia:hover{background:var(--gold-pale);color:var(--gold);border-color:var(--border)}
.ia-del:hover{background:rgba(239,68,68,.1);color:var(--urgent);border-color:rgba(239,68,68,.2)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:20px;font-size:.68rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}
.b-new{background:rgba(14,165,233,.12);color:#0369A1}
.b-confirmed{background:rgba(16,185,129,.12);color:#065F46}
.b-seated{background:rgba(184,151,60,.15);color:#7A5C10}
.b-done{background:rgba(100,116,139,.12);color:#475569}
.b-cancelled{background:rgba(239,68,68,.10);color:#B91C1C}
.b-noshow{background:rgba(139,92,246,.10);color:#5B21B6}
.tbl-free{background:rgba(16,185,129,.12);color:#065F46}
.tbl-reserved{background:rgba(184,151,60,.15);color:#7A5C10}
.tbl-seated{background:rgba(239,68,68,.10);color:#B91C1C}
.tbl-blocked{background:rgba(148,163,184,.12);color:#475569}
.tbl-badge{display:inline-flex;align-items:center;padding:.18rem .5rem;border-radius:var(--r-sm);font-size:.73rem;font-weight:700;background:var(--gold-pale);color:var(--gold);border:1px solid var(--border)}

/* ── EMPTY ── */
.empty{padding:2rem;text-align:center;color:var(--text-500);font-size:.82rem;display:flex;flex-direction:column;align-items:center;gap:.4rem}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;z-index:400;background:rgba(15,13,10,.65);display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px)}
.modal{background:var(--white);border-radius:14px;max-height:90vh;overflow-y:auto;width:100%;max-width:560px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.modal-wide{max-width:720px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--white);z-index:1}
.modal-head h3{font-size:1rem;font-weight:700;letter-spacing:-.01em}
.modal-close{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:1rem;color:var(--text-500);transition:.15s}
.modal-close:hover{background:var(--bg);color:var(--text-100)}
.modal-body{padding:1.4rem 1.5rem;display:flex;flex-direction:column;gap:.9rem}
.modal-foot{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.7rem}
.mrow{display:grid;gap:.75rem}
.mrow-2{grid-template-columns:1fr 1fr}
.mfield{display:flex;flex-direction:column;gap:.3rem}
.mfield label{font-size:.74rem;font-weight:700;color:var(--text-300);text-transform:uppercase;letter-spacing:.04em}
.minput{padding:.48rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);font-size:.83rem;color:var(--text-100);background:var(--bg);outline:none;transition:.15s;width:100%}
.minput:focus{border-color:var(--gold);background:var(--white)}
.minput:read-only,.minput:disabled{opacity:.55;cursor:default}

/* ── DATE-TIME PICKER ── */
.dt-picker{border:1.5px solid var(--border-mid);border-radius:var(--r);overflow:hidden}
.dt-picker-tabs{display:flex;border-bottom:1px solid var(--border)}
.dt-tab{flex:1;padding:.6rem;font-size:.78rem;font-weight:600;color:var(--text-500);border-bottom:2px solid transparent;transition:.15s;display:flex;align-items:center;justify-content:center;gap:.4rem}
.dt-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:var(--gold-pale)}
.mini-cal{padding:.8rem}
.mini-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.mini-cal-title{font-size:.82rem;font-weight:700}
.mini-cal-arrow{width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;color:var(--text-500);transition:.15s;font-size:.9rem;border:1px solid var(--border)}
.mini-cal-arrow:hover{background:var(--gold-pale);color:var(--gold)}
.mini-cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.mini-cal-dow span{text-align:center;font-size:.67rem;font-weight:700;color:var(--text-500);padding:.2rem 0}
.mini-cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.mini-day{text-align:center;font-size:.78rem;padding:.35rem .2rem;border-radius:6px;cursor:pointer;transition:.15s;line-height:1}
.mini-day:hover:not(.md-empty):not(.md-past){background:var(--gold-pale);color:var(--gold)}
.mini-day.md-sel{background:var(--gold);color:#fff;font-weight:700}
.mini-day.md-today{font-weight:700;color:var(--gold);box-shadow:inset 0 0 0 1.5px var(--gold)}
.mini-day.md-past{color:var(--text-500);opacity:.4;cursor:default}
.mini-day.md-empty{cursor:default}
.time-grid-wrap{padding:.8rem}
.time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.tg-slot{padding:.45rem;text-align:center;font-size:.76rem;font-weight:600;border-radius:var(--r-sm);border:1.5px solid var(--border);cursor:pointer;transition:.15s}
.tg-slot:hover:not(.tg-taken){border-color:var(--gold);color:var(--gold);background:var(--gold-pale)}
.tg-slot.tg-sel{background:var(--gold);border-color:var(--gold);color:#fff}
.tg-slot.tg-taken{opacity:.4;cursor:default;text-decoration:line-through}
.dt-result{display:flex;align-items:center;gap:.5rem;padding:.6rem .8rem;background:var(--gold-pale);border-top:1px solid var(--border);font-size:.8rem;font-weight:600;color:var(--gold)}

/* ── TABLE PICKER ── */
.table-picker{border:1.5px solid var(--border-mid);border-radius:var(--r);padding:.8rem;max-height:260px;overflow-y:auto}
.tp-zones{display:flex;flex-direction:column;gap:.75rem}
.tp-zone{}
.tp-zone-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;display:flex;align-items:center;gap:.35rem}
.tp-tables{display:flex;flex-wrap:wrap;gap:.35rem}
.tp-tbl{padding:.28rem .6rem;border-radius:var(--r-sm);font-size:.73rem;font-weight:700;border:1.5px solid var(--border-mid);color:var(--text-300);background:var(--white);cursor:pointer;transition:.15s;position:relative}
.tp-tbl:hover:not(.tp-taken){border-color:var(--gold);color:var(--gold)}
.tp-tbl.tp-sel{background:var(--gold);border-color:var(--gold);color:#fff}
.tp-tbl.tp-taken{opacity:.4;cursor:default}
.tp-seats{font-size:.62rem;font-weight:400;margin-left:.2rem;opacity:.7}

/* ── FLOOR PLAN ── */
.fp-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}
.fp-date-pick,.fp-time-pick{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;color:var(--text-300)}
.fp-date-pick label,.fp-time-pick label{white-space:nowrap}
.fp-date-pick .minput,.fp-time-pick .minput{width:auto}
.fp-legend{display:flex;align-items:center;gap:.75rem;flex:1}
.fp-legend-item{display:flex;align-items:center;gap:.3rem;font-size:.74rem;color:var(--text-500)}
.fp-layout{display:flex;gap:1rem;align-items:flex-start;min-height:500px}
.fp-canvas-wrap{flex:1;min-width:0;position:relative}
.fp-zones-label{display:flex;margin-bottom:.3rem;font-size:.66rem;font-weight:700;color:var(--text-500);text-transform:uppercase;letter-spacing:.06em;position:relative;height:18px}
.zone-tag{position:absolute;display:flex;align-items:center;gap:.2rem}
.fp-svg-main{width:100%;height:auto;border-radius:var(--r-sm);overflow:visible}
.fp-tbl-g{cursor:pointer;transition:.2s}
.fp-tbl-g:hover .fp-tbl-rect{filter:brightness(1.05)}
.fp-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem}
.fp-info-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;min-height:120px}
.fp-info-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.fp-info-title{font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.4rem}
.fp-info-title i{color:var(--gold)}
.fp-info-meta{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.8rem}
.fp-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:.78rem}
.fp-meta-row span{color:var(--text-500)}
.fp-info-bookings{margin-bottom:.8rem}
.fp-info-sub{font-size:.7rem;font-weight:700;color:var(--text-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
.fp-bk-chip{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;border-radius:var(--r-sm);background:var(--bg);font-size:.76rem;margin-bottom:.3rem}
.fp-bk-time{font-weight:700;color:var(--gold);min-width:38px}
.fp-bk-guests{display:flex;align-items:center;gap:.2rem;color:var(--text-500);margin-left:auto;font-size:.72rem}
.fp-info-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.fp-list-row{display:flex;align-items:center;gap:.6rem;padding:.5rem .4rem;border-bottom:1px solid var(--border);cursor:pointer;transition:.15s}
.fp-list-row:hover{background:var(--gold-pale);border-radius:var(--r-sm)}
.fp-list-row:last-child{border-bottom:none}
.fp-list-time{font-size:.78rem;font-weight:700;color:var(--gold);min-width:38px}
.fp-list-info{flex:1;min-width:0}

/* ── MINI FLOORPLAN (dashboard) ── */
.mini-floorplan{padding:0}
.fp-legend-mini{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}
.fp-legend-mini span{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--text-500)}
.fp-svg-mini{width:100%;height:auto;border-radius:var(--r-sm)}
.fp-tbl{cursor:pointer}
.fp-tbl rect{transition:.15s}
.fp-tbl:hover rect{filter:brightness(1.1)}

/* ── FLOORPLAN LEGEND DOTS ── */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── OCCUPANCY RING ── */
.occ-wrap{position:relative;width:120px;height:120px;margin:0 auto .6rem}
.occ-ring{width:100%;height:100%;transform:rotate(0)}
.occ-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.occ-pct{font-size:1.4rem;font-weight:800;color:var(--gold);letter-spacing:-.04em}
.occ-sub{font-size:.7rem;color:var(--text-500)}
.occ-legend{text-align:center;font-size:.74rem;color:var(--text-500);display:flex;align-items:center;justify-content:center;gap:.3rem;flex-wrap:wrap}

/* ── TIMELINE ── */
.timeline-wrap{display:flex;flex-direction:column;gap:.3rem}
.tl-row{display:flex;align-items:flex-start;gap:.6rem}
.tl-time{font-size:.72rem;font-weight:700;color:var(--text-500);min-width:40px;padding-top:.3rem}
.tl-slots{display:flex;flex-wrap:wrap;gap:.3rem;flex:1}
.tl-chip{display:flex;align-items:center;gap:.25rem;padding:.22rem .55rem;border-radius:var(--r-sm);background:var(--gold-pale);border:1px solid var(--border);font-size:.72rem;font-weight:600;color:var(--gold)}
.tl-empty{height:24px}

/* ── SCHEDULE ── */
.sch-layout{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start}
.sch-cal{width:300px;flex-shrink:0}
.sch-day{flex:1}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.cal-month-title{font-size:.9rem;font-weight:700}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-dow span{text-align:center;font-size:.66rem;font-weight:700;color:var(--text-500);padding:.2rem 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-cell{position:relative;aspect-ratio:1;border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:.15s;font-size:.8rem}
.cal-cell:hover:not(.is-empty):not(.is-past){background:var(--gold-pale)}
.cal-cell.is-sel{background:var(--gold);color:#fff}
.cal-cell.is-today .cal-num{font-weight:800;color:var(--gold)}
.cal-cell.is-sel .cal-num{color:#fff}
.cal-num{}
.cal-dot{position:absolute;bottom:3px;width:5px;height:5px;border-radius:50%}
.cal-dot-gold{background:var(--gold);left:calc(50% - 5px)}
.cal-dot-red{background:var(--urgent);left:calc(50% + 1px)}
.day-bk-row{display:flex;align-items:center;gap:.6rem;padding:.6rem 0;border-bottom:1px solid var(--border)}
.day-bk-row:last-child{border-bottom:none}
.day-bk-time{font-size:.8rem;font-weight:700;color:var(--gold);min-width:44px}
.day-bk-info{flex:1;min-width:0}

/* ── REV BARS ── */
.rev-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.55rem}
.rev-name{font-size:.78rem;font-weight:600;min-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-300)}
.rev-bar-wrap{flex:1;height:8px;background:var(--bg-2);border-radius:4px;overflow:hidden}
.rev-bar{height:100%;border-radius:4px;transition:width .5s var(--ease)}
.rev-val{font-size:.76rem;font-weight:700;color:var(--text-300);min-width:35px;text-align:right}

/* ── MENU GRID ── */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}
.menu-item-card{padding:.9rem 1rem;border-radius:var(--r);border:1px solid var(--border);background:var(--bg);transition:.15s}
.menu-item-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.mi-name{font-size:.85rem;font-weight:700;margin-bottom:.2rem}
.mi-desc{font-size:.74rem;color:var(--text-500);margin-bottom:.6rem;line-height:1.4}
.mi-foot{display:flex;align-items:center;gap:.6rem}
.mi-price{font-size:.88rem;font-weight:800;color:var(--gold)}
.mi-allergens{font-size:.65rem;color:var(--text-500);display:flex;align-items:center;gap:.2rem}

/* ── STAFF ── */
.doc-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding:1.4rem 1.2rem}
.doc-photo{width:80px;height:80px;border-radius:50%;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.doc-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.doc-avatar{font-size:2rem;font-weight:700;width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.doc-name{font-size:.92rem;font-weight:700;letter-spacing:-.01em}
.doc-title{font-size:.74rem;font-weight:600;margin-top:-.2rem}
.doc-meta{display:flex;gap:.8rem;font-size:.74rem;color:var(--text-500)}
.doc-meta span{display:flex;align-items:center;gap:.25rem}
.doc-quote{font-size:.73rem;color:var(--text-500);font-style:italic;line-height:1.5;margin-top:.3rem}

/* ── GALLERY ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.7rem}
.gal-card{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;background:var(--bg-2)}
.gal-card img{width:100%;height:100%;object-fit:cover}

/* ── SETTINGS ── */
.set-tabs{display:flex;gap:.3rem;margin-bottom:1rem;border-bottom:2px solid var(--border);padding-bottom:.5rem}
.set-tab{padding:.4rem 1rem;border-radius:var(--r-sm) var(--r-sm) 0 0;font-size:.8rem;font-weight:600;color:var(--text-500);transition:.15s;border:1px solid transparent;border-bottom:none}
.set-tab:hover{color:var(--gold)}
.set-tab.active{color:var(--gold);border-color:var(--border);border-bottom-color:var(--white);background:var(--white);margin-bottom:-2px;z-index:1;position:relative}
.set-pane{display:none;flex-direction:column;gap:1rem}
.set-pane.active{display:flex}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.5rem}

/* ── INT CARDS ── */
.int-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.9rem;margin-bottom:1rem}
.int-head{display:flex;align-items:flex-start;gap:.8rem}
.int-logo{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.int-title-row{flex:1}
.int-name{font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.5rem}
.int-status{font-size:.62rem;font-weight:700;padding:.15rem .45rem;border-radius:4px;background:var(--gold-pale);color:var(--gold);letter-spacing:.06em}
.int-status-fi{background:#D1FAE5;color:#065F46}
.int-desc{font-size:.76rem;color:var(--text-500);margin-top:.15rem}
.int-fields{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.int-fields .field{display:flex;flex-direction:column;gap:.2rem}
.int-fields .field label{font-size:.68rem;font-weight:700;color:var(--text-500);text-transform:uppercase;letter-spacing:.05em}
.int-features{display:flex;gap:.8rem;flex-wrap:wrap;font-size:.74rem;color:var(--text-500)}
.int-features span{display:flex;align-items:center;gap:.25rem}

.ins-toggle-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.4rem}
.ins-toggle-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.ins-toggle-title{font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:.4rem}
.ins-toggle-sub{font-size:.74rem;color:var(--text-500);margin-top:.15rem}
.toggle{width:40px;height:22px;border-radius:11px;background:var(--bg-2);border:2px solid var(--border-mid);position:relative;cursor:pointer;transition:.2s;flex-shrink:0}
.toggle::after{content:'';position:absolute;left:2px;top:1px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on{background:var(--gold);border-color:var(--gold)}
.toggle.on::after{left:18px}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;background:var(--navy);color:#fff;padding:.7rem 1.1rem;border-radius:10px;font-size:.82rem;font-weight:600;display:flex;align-items:center;gap:.5rem;transform:translateY(20px);opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--shadow-lg);border:1px solid rgba(184,151,60,.2)}
.toast i{color:var(--gold)}
.toast.show{transform:translateY(0);opacity:1}

/* ── RESPONSIVE ── */
/* ══════ ADMIN TABLET 900px ══════ */
@media(max-width:900px){
  /* Sidebar becomes drawer */
  .sidebar{transform:translateX(-100%);box-shadow:none}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  .main{margin-left:0}
  .topbar-burger{display:flex;align-items:center;justify-content:center;
    width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border)}
  /* Content grids */
  .grid-2,.grid-3,.sch-layout{grid-template-columns:1fr}
  .sch-cal{width:100%}
  .fp-layout{flex-direction:column}
  .fp-sidebar{width:100%}
  .mrow-2{grid-template-columns:1fr}
  .int-fields{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  /* Floor plan */
  .fp-svg-main{max-height:60vw}
  /* Stats */
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  /* Menu grid admin */
  .menu-grid-adm{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  /* Gallery */
  .gallery-grid-adm{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
}

/* ══════ ADMIN MOBILE 600px ══════ */
@media(max-width:600px){
  :root{--topbar-h:52px;--banner-h:30px}
  .content{padding:.8rem}
  .card{padding:.9rem 1rem}
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat-card-value{font-size:1.4rem}
  /* Topbar */
  .topbar{padding:0 .8rem}
  .topbar-title{font-size:.85rem}
  .topbar-site{display:none}
  .demo-badge{display:none}
  /* Table */
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:520px}
  /* Modal */
  .modal{max-width:100%;margin:.5rem;border-radius:10px}
  .modal-wide{max-width:100%}
  .modal-body{padding:1rem}
  .modal-head{padding:.9rem 1rem}
  /* Floor plan */
  .fp-toolbar{flex-direction:column;align-items:flex-start;gap:.6rem}
  .fp-svg-main{max-height:55vw}
  .fp-sidebar .card{padding:.8rem}
  /* Occupancy */
  .grid-3{grid-template-columns:1fr}
  /* Timeline */
  .tl-chip{font-size:.66rem;padding:.18rem .4rem}
  /* Schedule */
  .day-bk-row{flex-wrap:wrap;gap:.3rem}
  /* Filter pills */
  .filter-pills{gap:.25rem}
  .pill{padding:.22rem .55rem;font-size:.7rem}
  /* Admin nav */
  .adm-lang{gap:.1rem}
  .adm-lb{padding:.18rem .35rem;font-size:.66rem}
}

/* ══════ ADMIN VERY SMALL 380px ══════ */
@media(max-width:380px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .content{padding:.6rem}
  .sidebar-logo-name{font-size:.95rem}
}

/* ════ MENU MANAGER with images ════ */
.menu-grid-adm{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.8rem;margin-top:.5rem}
.menu-item-card-adm{background:var(--bg);border-radius:var(--r);border:1px solid var(--border);overflow:hidden;transition:.2s}
.menu-item-card-adm:hover{border-color:var(--gold);box-shadow:var(--shadow-md)}
.mi-img-wrap{position:relative;aspect-ratio:4/3;background:var(--bg-2);cursor:pointer;overflow:hidden}
.mi-img-preview{width:100%;height:100%;object-fit:cover;display:block}
.mi-img-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;color:var(--text-500);font-size:.74rem}
.mi-img-ph i{font-size:1.5rem;color:var(--border-mid)}
.mi-img-overlay{position:absolute;inset:0;background:rgba(184,151,60,.18);display:flex;align-items:center;justify-content:center;opacity:0;transition:.2s}
.mi-img-overlay i{font-size:1.4rem;color:#fff}
.mi-img-wrap:hover .mi-img-overlay{opacity:1}
.mi-info{padding:.75rem .85rem}
.mi-name{font-size:.84rem;font-weight:700;margin-bottom:.2rem}
.mi-desc{font-size:.72rem;color:var(--text-500);line-height:1.4;margin-bottom:.5rem}
.mi-foot{display:flex;align-items:center;gap:.5rem}
.mi-price{font-size:.9rem;font-weight:800;color:var(--gold)}
.mi-allergens{font-size:.64rem;color:var(--text-500);display:flex;align-items:center;gap:.2rem}

/* ════ GALLERY with upload ════ */
.gallery-grid-adm{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.7rem;margin-top:.5rem}
.gal-card-adm{position:relative;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;background:var(--bg-2)}
.gal-card-adm img{width:100%;height:100%;object-fit:cover;display:block;transition:.2s}
.gal-card-adm:hover img{transform:scale(1.04)}
.gal-del-btn{position:absolute;top:.4rem;right:.4rem;width:26px;height:26px;border-radius:6px;background:rgba(239,68,68,.9);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;opacity:0;transition:.2s;border:none}
.gal-card-adm:hover .gal-del-btn{opacity:1}
.gal-add-card{aspect-ratio:4/3;border-radius:var(--r);border:2px dashed var(--border-mid);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;color:var(--text-500);font-size:.76rem;transition:.2s}
.gal-add-card:hover{border-color:var(--gold);color:var(--gold)}
.gal-add-card i{font-size:1.5rem}
