/* ============================================================
   index-extra.css — extracted from inline <style> blocks in
   index.html. Loaded after theme.css. No functional changes.
   ============================================================ */

/* ── Block 1: RESTEL custom component styles ──────────────── */
/* ── RESTEL custom component styles (hotel-specific, Aurora-compatible) ── */

/* View containers */
/* FIX: --nav-h is set dynamically by the inline script in index.html
   which measures the real #nav height after app.js injects it.
   Fallback of 80px covers first-paint before the script fires. */
/* Nav is two rows: Row1 42px + Row2 38px = 80px total.
   padding-top gives 12px breathing room below the nav. */
:root { --nav-h: 80px; }
.view { display:none; padding:16px; padding-top:calc(var(--nav-h) + 12px) !important; }
.view.active { display:block; }

/* ── HUB SCREENS (landing + domain-hub) ─────────────────────
   Both screens are full-page card grids that render BEFORE the
   user has chosen a working view. They have their own self-
   contained header so the global navbar must stay hidden, and
   the .view padding-top must not push content below a phantom
   nav (--nav-h) that isn't there. The body-level data-screen
   attribute lets CSS win over Alpine's x-show on #nav. */
body[data-screen="hub"] #nav { display:none !important; }
body[data-screen="hub"] .view.active { padding:0 !important; }

/* Hub views — only render as flex columns when actually active.
   IMPORTANT: do NOT put display:flex in the inline style attribute
   on the element, or .view's display:none rule loses the specificity
   battle and BOTH hubs render simultaneously (stacked). */
.view-hub { background:linear-gradient(135deg,#FBF7F2 0%,#F5EDE3 100%); min-height:100vh; }
.view-hub.active { display:flex !important; flex-direction:column; }
/* When one of the hubs is the active view, kill .view.active's default
   display:block so flex wins. */

/* Section header */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; flex-wrap:wrap; gap:10px; }
.section-title { font-family:'Sora',sans-serif; font-size:1.2rem; font-weight:700; color:var(--ink-800); letter-spacing:-0.02em; }

/* Buttons — Aurora-mapped hotel palette */
.btn-primary { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border:none; border-radius:var(--r); padding:9px 16px; font-size:.85rem; font-weight:600; cursor:pointer; font-family:'Sora',sans-serif; transition:all .2s var(--ease-out); }
.btn-primary:hover { background:linear-gradient(135deg,#4A1219,#6B1F2A); transform:translateY(-1px); box-shadow:0 6px 18px -4px rgba(107,31,42,.45); }
.btn-secondary { background:#fff; color:var(--ink-800); border:1.5px solid var(--border); border-radius:var(--r); padding:8px 14px; font-size:.82rem; font-weight:500; cursor:pointer; font-family:'Sora',sans-serif; transition:all .2s var(--ease-out); }
.btn-secondary:hover { border-color:var(--border-strong); transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.btn-gold { background:linear-gradient(135deg,#C9952A,#E8B84B); color:#2C0A0F; border:none; border-radius:var(--r); padding:9px 16px; font-size:.85rem; font-weight:600; cursor:pointer; font-family:'Sora',sans-serif; }
.btn-danger { background:linear-gradient(135deg,#E11D48,#F43F5E); color:#fff; border:none; border-radius:var(--r-sm); padding:7px 12px; font-size:.8rem; font-weight:600; cursor:pointer; }
.btn-sm { padding:6px 12px; font-size:.78rem; }

/* Stat cards — Aurora */
.stats-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-bottom:20px; }
@media(min-width:600px) { .stats-grid { grid-template-columns:repeat(4,1fr); } }
.stat-card {
  background:var(--surface); border-radius:var(--r-lg); padding:18px; position:relative; overflow:hidden;
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out);
}
.stat-card::after { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; border-radius:var(--r-lg) 0 0 var(--r-lg); }
.stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.stat-card.gold::after   { background:linear-gradient(180deg,#C9952A,#E8B84B); }
.stat-card.red::after    { background:var(--grad-rose); }
.stat-card.green::after  { background:var(--grad-emerald); }
.stat-card.blue::after   { background:var(--grad-primary); }
.stat-num { font-size:1.8rem; font-weight:700; color:var(--ink-800); letter-spacing:-0.03em; }
.stat-label { font-size:.72rem; color:var(--ink-400); text-transform:uppercase; letter-spacing:.06em; margin-top:2px; font-weight:600; }

/* Card */
.card { background:var(--surface); border-radius:var(--r-lg); padding:16px; border:1px solid var(--border); box-shadow:var(--shadow-sm); margin-bottom:12px; }
.card-row { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.card-title { font-weight:600; font-size:.95rem; color:var(--ink-800); }
.card-sub { font-size:.78rem; color:var(--ink-400); margin-top:2px; }

/* Badges */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:.72rem; font-weight:600; }
.badge-green  { background:#D1FAE5; color:#065F46; }
.badge-red    { background:#FEE2E2; color:#991B1B; }
.badge-yellow { background:#FEF3C7; color:#92400E; }
.badge-blue   { background:#DBEAFE; color:#1E40AF; }
.badge-gray   { background:var(--ink-100); color:var(--ink-600); }
.badge-purple { background:#EDE9FE; color:#5B21B6; }

/* Forms */
.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:.72rem; color:var(--ink-500); text-transform:uppercase; letter-spacing:.06em; margin-bottom:5px; font-weight:600; }
.form-group input, .form-group select, .form-group textarea { width:100%; border:1.5px solid var(--border); border-radius:var(--r); padding:10px 12px; font-size:16px; font-family:'Sora',sans-serif; color:var(--ink-900); background:#fff; outline:none; transition:border-color .2s, box-shadow .2s; min-height:44px; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--violet-500); box-shadow:0 0 0 4px rgba(109,60,240,0.12); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* Tables */
.table-wrap { overflow-x:auto; border-radius:var(--r-lg); border:1px solid var(--border); }
table { width:100%; border-collapse:collapse; font-size:.85rem; }
th { background:var(--surface-muted); color:var(--ink-500); font-weight:600; padding:10px 12px; text-align:left; font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; border-bottom:1px solid var(--border); }
td { padding:10px 12px; border-bottom:1px solid var(--border); color:var(--ink-800); }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--surface-muted); }

/* Modal */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(14,18,48,.45); z-index:500; align-items:flex-end; justify-content:center; padding:0; backdrop-filter:blur(4px); }
.modal-overlay.show { display:flex; }
@media(min-width:600px) { .modal-overlay { align-items:center; padding:20px; } }
.modal-box, .modal { background:var(--surface); border-radius:var(--r-xl) var(--r-xl) 0 0; width:100%; max-width:520px; max-height:92vh; overflow-y:auto; padding:24px 20px 32px; border:1px solid var(--border); box-shadow:var(--shadow-lg); }
@media(min-width:600px) { .modal-box, .modal { border-radius:var(--r-xl); } }
.modal-title { font-size:1.1rem; font-weight:700; color:var(--ink-800); margin-bottom:16px; letter-spacing:-0.02em; }
.modal-close { float:right; background:none; border:none; font-size:1.3rem; cursor:pointer; color:var(--ink-400); padding:4px 8px; border-radius:8px; transition:background .15s; }
.modal-close:hover { background:var(--surface-muted); }

/* Kitchen PIN modal */
.km-box { background:var(--surface); border-radius:var(--r-xl); padding:28px 24px; width:90%; max-width:340px; text-align:center; border:1px solid var(--border); box-shadow:var(--shadow-lg); }
.km-box h3 { font-size:1.1rem; font-weight:700; color:var(--ink-800); margin-bottom:8px; }
.km-box p { font-size:.85rem; color:var(--ink-400); margin-bottom:20px; }
.km-input { width:100%; border:1.5px solid var(--border); border-radius:var(--r); padding:12px; font-size:1.1rem; text-align:center; letter-spacing:.2em; margin-bottom:12px; outline:none; }
.km-input:focus { border-color:var(--violet-500); box-shadow:0 0 0 4px rgba(109,60,240,0.12); }
.km-btn { width:100%; background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border:none; border-radius:var(--r); padding:12px; font-size:1rem; font-weight:600; cursor:pointer; margin-bottom:8px; }
.km-cancel { background:none; border:none; color:var(--ink-400); cursor:pointer; font-size:.9rem; }

/* Menu view */
#cat-scroll { display:flex; gap:8px; overflow-x:auto; padding-bottom:8px; scrollbar-width:none; margin-bottom:12px; }
#cat-scroll::-webkit-scrollbar { display:none; }
.cat-btn { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:7px 14px; font-size:.82rem; cursor:pointer; white-space:nowrap; color:var(--ink-500); transition:all .2s; font-family:'Sora',sans-serif; }
.cat-btn.active { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }
#sub-toggle { display:flex; gap:6px; overflow-x:auto; margin-bottom:12px; scrollbar-width:none; }
#sub-toggle::-webkit-scrollbar { display:none; }
.sub-btn { background:var(--surface-muted); border:none; border-radius:var(--r-xl); padding:5px 12px; font-size:.78rem; cursor:pointer; color:var(--ink-500); white-space:nowrap; font-family:'Sora',sans-serif; }
.sub-btn.active { background:rgba(201,149,42,0.12); color:#6B1F2A; }
.room-bar { display:flex; align-items:center; gap:8px; background:var(--surface); border-radius:var(--r); padding:10px 14px; border:1px solid var(--border); box-shadow:var(--shadow-sm); margin-bottom:16px; }
.room-bar input, .room-bar select { flex:1; border:none; outline:none; font-size:16px; color:var(--ink-800); background:transparent; }
.menu-section { margin-bottom:24px; }
.menu-section-title { font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-400); margin-bottom:10px; padding-left:4px; font-weight:700; }
.item-card { background:var(--surface); border-radius:var(--r-lg); padding:14px; border:1px solid var(--border); box-shadow:var(--shadow-sm); display:flex; align-items:flex-start; gap:12px; margin-bottom:10px; transition:box-shadow .2s; }
.item-card:hover { box-shadow:var(--shadow); }
.veg-dot { width:14px; height:14px; border-radius:3px; flex-shrink:0; margin-top:3px; }
.veg-dot.veg    { background:#10B981; border:2px solid #059669; }
.veg-dot.nonveg { background:#F43F5E; border:2px solid #E11D48; }
.item-info { flex:1; }
.item-name  { font-size:.9rem; font-weight:600; color:var(--ink-800); }
.item-desc  { font-size:.75rem; color:var(--ink-400); margin-top:2px; line-height:1.4; }
.item-price { font-size:.9rem; color:#6B1F2A; font-weight:700; margin-top:4px; }
.item-ctrl  { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.qty-btn { width:30px; height:30px; border-radius:50%; border:1.5px solid var(--border); background:var(--surface); cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; color:var(--ink-800); transition:all .15s; }
.qty-btn.add { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }
.qty-num { font-size:.9rem; font-weight:600; color:var(--ink-800); min-width:16px; text-align:center; }
.search-bar { display:flex; align-items:center; gap:8px; background:var(--surface); border-radius:var(--r); padding:10px 14px; border:1px solid var(--border); box-shadow:var(--shadow-sm); margin-bottom:12px; }
.search-bar input { flex:1; border:none; outline:none; font-size:16px; color:var(--ink-800); background:transparent; min-height:24px; }
.search-results-list { background:var(--surface); border-radius:var(--r-lg); border:1px solid var(--border); box-shadow:var(--shadow); overflow:hidden; margin-bottom:12px; }

/* Cart */
#cart-bar { position:fixed; bottom:0; left:0; right:0; background:linear-gradient(135deg,#6B1F2A,#4A1219); color:#fff; padding:14px 20px; display:none; align-items:center; justify-content:space-between; z-index:200; backdrop-filter:blur(10px); }
#cart-bar.show { display:flex; }
.cart-bar-info { font-size:.85rem; }
.cart-bar-btn { background:linear-gradient(135deg,#C9952A,#E8B84B); color:#2C0A0F; border:none; border-radius:var(--r); padding:8px 16px; font-size:.85rem; font-weight:600; cursor:pointer; }
#cart-drawer { position:fixed; bottom:0; left:0; right:0; background:var(--surface); border-radius:var(--r-xl) var(--r-xl) 0 0; border:1px solid var(--border); box-shadow:0 -8px 32px rgba(14,18,48,.2); z-index:300; transform:translateY(100%); transition:transform .35s var(--ease-out); max-height:85vh; max-height:85dvh; display:flex; flex-direction:column; padding-bottom:env(safe-area-inset-bottom); }
@media(min-width:900px) { #cart-drawer { left:auto; right:24px; bottom:24px; width:400px; border-radius:var(--r-xl); max-height:80vh; transform:translateY(calc(100% + 24px)); } #cart-drawer.open { transform:translateY(0); } }
#cart-drawer.open { transform:translateY(0); }
.cart-header { padding:16px 20px 12px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.cart-title { font-size:1rem; font-weight:700; color:var(--ink-800); }
.cart-close { background:none; border:none; font-size:1.3rem; cursor:pointer; color:var(--ink-400); }
#cart-items-list { flex:1; overflow-y:auto; padding:12px 20px; }
.cart-item { display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--border); }
.cart-item:last-child { border-bottom:none; }
.cart-item-name { flex:1; font-size:.88rem; color:var(--ink-800); }
.cart-item-ctrl { display:flex; align-items:center; gap:8px; }
.cart-item-price { font-size:.85rem; color:#6B1F2A; font-weight:600; min-width:60px; text-align:right; }
#cart-footer { padding:16px 20px; border-top:1px solid var(--border); flex-shrink:0; }
.cart-note { width:100%; border:1.5px solid var(--border); border-radius:var(--r); padding:8px 12px; font-size:.85rem; font-family:'Sora',sans-serif; resize:none; outline:none; margin-bottom:12px; color:var(--ink-800); }
.cart-total { display:flex; justify-content:space-between; font-size:.9rem; margin-bottom:12px; }
.cart-total strong { color:#6B1F2A; }
.place-btn { width:100%; background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border:none; border-radius:var(--r); padding:14px; font-size:1rem; font-weight:600; cursor:pointer; font-family:'Sora',sans-serif; }
.place-btn:disabled { opacity:0.6; cursor:wait; }

/* Filter buttons (kitchen, hk) */
.kitchen-filters { display:flex; gap:8px; margin-bottom:16px; overflow-x:auto; scrollbar-width:none; flex-wrap:wrap; }
.filter-btn { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:6px 14px; font-size:.8rem; cursor:pointer; color:var(--ink-500); white-space:nowrap; font-family:'Sora',sans-serif; transition:all .2s; }
.filter-btn.active { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }

/* Tabs (billing, reports, ota) */
.billing-tabs { display:flex; gap:8px; margin-bottom:16px; overflow-x:auto; scrollbar-width:none; }
.billing-tab  { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:7px 16px; font-size:.82rem; cursor:pointer; color:var(--ink-500); white-space:nowrap; font-family:'Sora',sans-serif; }
.billing-tab.active { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }
.billing-panel { display:none; }
.billing-panel.active { display:block; }
.report-tabs { display:flex; gap:8px; margin-bottom:20px; overflow-x:auto; scrollbar-width:none; }
.report-tab  { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:7px 16px; font-size:.82rem; cursor:pointer; color:var(--ink-500); white-space:nowrap; font-family:'Sora',sans-serif; }
.report-tab.active { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }
.report-panel { display:none; }
.report-panel.active { display:block; }
.report-date-row { display:flex; gap:8px; align-items:center; margin-bottom:16px; flex-wrap:wrap; }

/* KPI cards */
.kpi-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-bottom:20px; }
@media(min-width:640px) { .kpi-grid { grid-template-columns:repeat(4,1fr); } }
.kpi-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px 16px;
  box-shadow:0 1px 3px rgba(0,0,0,.04), 0 4px 14px -8px rgba(0,0,0,.08);
  transition:transform .2s var(--ease-out), box-shadow .2s var(--ease-out);
  position:relative;
  overflow:hidden;
}
.kpi-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#6B1F2A,#C9952A);
  border-radius:3px 0 0 3px;
}
.kpi-card:hover{ transform:translateY(-1px); box-shadow:0 2px 6px rgba(0,0,0,.06), 0 8px 22px -8px rgba(0,0,0,.12); }
.kpi-num,.kpi-val{
  font-family:'Sora',sans-serif;
  font-size:1.35rem;
  font-weight:800;
  color:var(--ink-800,#161B45);
  letter-spacing:-.02em;
  line-height:1.1;
}
.kpi-label{
  font-size:.72rem;
  color:var(--ink-500,#6B7280);
  margin-top:6px;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-weight:600;
}

/* QR */
.qr-container { max-width:440px; margin:0 auto; }
.qr-display { background:var(--surface); border-radius:var(--r-lg); padding:24px; border:1px solid var(--border); box-shadow:var(--shadow); margin:16px 0; text-align:center; }
.qr-url { font-size:.75rem; color:var(--ink-400); word-break:break-all; margin-top:12px; font-family:'JetBrains Mono',monospace; }
.qr-room-badge { font-size:1.3rem; font-weight:700; color:var(--ink-800); }

/* OTA */
.ota-summary-cards { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.ota-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-lg); padding:14px 18px; min-width:130px; cursor:pointer; transition:box-shadow .15s; }
.ota-card:hover { box-shadow:var(--shadow); }
.ota-card-num { font-size:1.6rem; font-weight:700; color:#6B1F2A; letter-spacing:-0.03em; }
.ota-card-label { font-size:.72rem; color:var(--ink-400); margin-top:2px; text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.ota-filter-tabs { display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.ota-filter-tab { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:6px 14px; font-size:.8rem; cursor:pointer; color:var(--ink-500); white-space:nowrap; font-family:'Sora',sans-serif; }
.ota-filter-tab.active { background:linear-gradient(135deg,#6B1F2A,#8B3040); color:#fff; border-color:#6B1F2A; }
.ota-badge { display:inline-block; padding:2px 8px; border-radius:var(--r-sm); font-size:.72rem; font-weight:600; }
.ota-status-badge { display:inline-block; padding:3px 10px; border-radius:var(--r-sm); font-size:.75rem; font-weight:600; }
.ota-source-row { display:flex; align-items:center; gap:10px; padding:5px 0; border-bottom:1px solid var(--border); }
.ota-search-bar { margin-bottom:14px; }
.ota-search-bar input { width:100%; border:1.5px solid var(--border); border-radius:var(--r); padding:11px 14px; font-size:16px; outline:none; min-height:44px; }
.ota-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:16px; }
@media(max-width:480px) { .ota-form-grid { grid-template-columns:1fr; } }
.webhook-info { background:var(--surface-muted); border-radius:var(--r-lg); padding:16px; font-size:.8rem; color:var(--ink-500); border:1px solid var(--border); line-height:1.7; }
.webhook-info code { background:var(--ink-100); padding:2px 6px; border-radius:4px; font-family:'JetBrains Mono',monospace; color:var(--ink-800); font-size:.78rem; }

/* Print */
@media print {
  #loading, #toast, .nav-tab, button:not(.no-print), nav, #cart-bar, #cart-drawer, .modal-overlay, #main-nav, #nav { display:none!important; }
  body { background:#fff; }
  .bill-print { max-width:320px; margin:0 auto; }
  .no-print { display:none!important; }
  .print-only { display:block!important; }
}
.print-only { display:none; }

/* KOT/Bill print styles (unchanged) */
.kot-wrap{font-family:'Courier New',monospace;max-width:300px;margin:0 auto;padding:10px;}
.kot-header{text-align:center;border-bottom:2px dashed #000;padding-bottom:8px;margin-bottom:8px;}
.kot-hotel{font-size:1.1rem;font-weight:700;letter-spacing:.05em;}
.kot-title{font-size:.85rem;font-weight:700;background:#000;color:#fff;padding:3px 8px;display:inline-block;margin:4px 0;}
.kot-meta{font-size:.78rem;margin:6px 0;}
.kot-items{border-top:1px dashed #000;border-bottom:1px dashed #000;padding:8px 0;margin:8px 0;}
.kot-item{display:flex;justify-content:space-between;font-size:.82rem;padding:2px 0;}
.kot-item-name{flex:1;}
.kot-item-qty{font-weight:700;min-width:30px;}
.kot-item-price{min-width:60px;text-align:right;}
.kot-note{font-size:.75rem;font-style:italic;background:#f5f5f5;padding:4px 6px;border-radius:4px;margin:4px 0;}
.kot-total{display:flex;justify-content:space-between;font-weight:700;font-size:.9rem;padding:4px 0;}
.kot-footer{text-align:center;font-size:.72rem;margin-top:8px;border-top:1px dashed #000;padding-top:8px;}
.cbill-wrap{font-family:'Sora',Arial,sans-serif;max-width:760px;margin:0 auto;padding:12px;font-size:.78rem;color:#111;}
.cbill-header{text-align:center;margin-bottom:8px;}
.cbill-hotel{font-size:1.4rem;font-weight:700;color:#111;letter-spacing:.04em;}
.cbill-addr{font-size:.72rem;color:#333;margin-top:2px;}
.cbill-divider{border:none;border-top:1px dashed #C9952A;margin:8px 0;}
.cbill-title{text-align:center;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#4A1219;margin:6px 0;}
.cbill-meta{font-size:.78rem;margin:3px 0;display:flex;justify-content:space-between;}
.cbill-items th{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;padding:4px 0;border-bottom:1px solid #ddd;text-align:left;}
.cbill-items td{font-size:.78rem;padding:4px 0;border-bottom:1px dotted #eee;vertical-align:top;}
.cbill-items td:last-child{text-align:right;}
.cbill-summary{margin-top:8px;}
.cbill-sum-row{display:flex;justify-content:space-between;font-size:.78rem;padding:2px 0;}
.cbill-total-row{display:flex;justify-content:space-between;font-size:.95rem;font-weight:700;padding:5px 0;border-top:2px solid #4A1219;margin-top:4px;}
.cbill-payment{background:#f9f3e8;border-radius:6px;padding:6px 8px;margin-top:8px;font-size:.78rem;}
.cbill-footer{text-align:center;font-size:.68rem;color:#999;margin-top:12px;border-top:1px dashed #ddd;padding-top:8px;line-height:1.6;}
.mb-title-bar{text-align:center;font-size:1rem;font-weight:700;border-bottom:1px solid #333;border-top:1px solid #333;padding:3px 0;margin:6px 0;}
.mb-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;margin:8px 0 6px;}
.mb-info-row{display:flex;gap:3px;margin-bottom:2px;font-size:.74rem;}
.mb-label{min-width:100px;color:#555;flex-shrink:0;}
.mb-sep{color:#333;flex-shrink:0;}
.mb-val{flex:1;}
.mb-bold{font-weight:700;}
.mb-ledger{width:100%;border-collapse:collapse;font-size:.73rem;}
.mb-ledger th{border-bottom:1px solid #bbb;padding:4px 3px;text-align:left;font-weight:700;background:#f0f0f0;}
.mb-ledger td{padding:2px 3px;vertical-align:top;}
/* Bill view */
.bill-section{border-top:1px dashed rgba(201,149,42,.4);margin-top:12px;padding-top:12px;}
.bill-row{display:flex;justify-content:space-between;font-size:.82rem;padding:3px 0;}
.bill-total-row{display:flex;justify-content:space-between;font-size:.95rem;font-weight:700;padding:6px 0;}
.divider{border:none;border-top:1px dashed rgba(201,149,42,.35);margin:10px 0;}
/* Calendar */
.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px;}
.cal-dow{text-align:center;font-size:.7rem;font-weight:700;color:var(--ink-400);padding:4px 0;text-transform:uppercase;letter-spacing:.06em;}
.cal-body{display:flex;flex-direction:column;gap:2px;}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-cell{min-height:72px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 5px;cursor:pointer;transition:box-shadow .15s;overflow:hidden;}
.cal-cell:hover{box-shadow:var(--shadow);border-color:rgba(201,149,42,.5);}
.cal-cell-empty{background:var(--surface-muted);border:1px solid transparent;cursor:default;border-radius:var(--r-sm);}
.cal-today{border:2px solid #6B1F2A!important;background:#fff8f8;}
.cal-past .cal-day-num{color:var(--ink-300);}
.cal-has-events{background:#fffdf5;}
.cal-day-num{font-size:.75rem;font-weight:700;color:var(--ink-800);margin-bottom:3px;}
.cal-today .cal-day-num{background:#6B1F2A;color:white;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;margin-bottom:4px;}
.cal-pills{display:flex;flex-direction:column;gap:2px;}
.cal-pill{font-size:.62rem;color:white;padding:1px 4px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;}
.cal-overflow{font-size:.6rem;color:var(--ink-400);margin-top:1px;padding-left:2px;}
/* Minibar */
#mb-cat-filter{padding-bottom:8px;scrollbar-width:none;}
#mb-cat-filter::-webkit-scrollbar{display:none;}
#restock-qty{font-size:1.3rem;text-align:center;padding:14px;letter-spacing:.05em;}
/* Mobile */
@media(max-width:480px){
  .modal-box,.modal{padding:18px 14px 28px;}
  .form-row{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .cal-cell{min-height:54px;padding:3px;}
  .cal-pill{font-size:.55rem;}
}
/* Bulk import */
.bulk-template{display:inline-block;margin-top:10px;font-size:.75rem;color:#6B1F2A;text-decoration:underline;cursor:pointer;}
.bulk-errors{margin-top:6px;max-height:80px;overflow-y:auto;font-size:.72rem;opacity:.8;}
/* Admin tabs */
.admin-tab-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:7px 16px;font-size:.82rem;cursor:pointer;color:var(--ink-500);white-space:nowrap;font-family:'Sora',sans-serif;}
.admin-tab-btn.active{background:linear-gradient(135deg,#6B1F2A,#8B3040);color:#fff;border-color:#6B1F2A;}

/* Settings panel — sectioned card grid */
.settings-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:16px;
}
.settings-section-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px 20px;
  box-shadow:0 1px 3px rgba(0,0,0,.04), 0 6px 20px -10px rgba(0,0,0,.08);
  transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out);
}
.settings-section-card:hover{
  transform:translateY(-2px);
  box-shadow:0 2px 8px rgba(0,0,0,.06), 0 12px 28px -10px rgba(0,0,0,.12);
}
.settings-section-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:14px;margin-bottom:14px;
  border-bottom:1px solid var(--border);
}
.settings-section-icon{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:#fff;
  box-shadow:0 4px 12px -4px rgba(0,0,0,.25);
  flex-shrink:0;
}
.settings-section-title{
  font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;color:var(--ink-800);
  letter-spacing:-.01em;
}
.settings-section-sub{
  font-size:.72rem;color:var(--ink-400);margin-top:2px;
}

/* Housekeeping */
.hk-card{background:var(--surface);border-radius:var(--r-lg);padding:14px;border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:10px;transition:transform .2s var(--ease-out), box-shadow .2s var(--ease-out);}
.hk-card:hover{transform:translateY(-1px);box-shadow:var(--shadow);}
.hk-card.urgent{border-left:4px solid #F43F5E;}
.hk-card.high{border-left:4px solid #F59E0B;}
.hk-card.in_progress{border-left:4px solid #6D3CF0;}
.hk-card.done{border-left:4px solid #10B981;opacity:.85;}
.hk-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px;flex-wrap:wrap;}
.hk-room{font-weight:700;font-size:1rem;color:var(--ink-800);}
.hk-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;}

/* Status pills (re-used across screens) */
.status-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:capitalize;}
.status-pending{background:#FEF3C7;color:#92400E;}
.status-progress{background:#DBEAFE;color:#1E40AF;}
.status-completed{background:#D1FAE5;color:#065F46;}
.status-cancelled{background:#FEE2E2;color:#991B1B;}
.status-draft{background:var(--ink-100);color:var(--ink-600);}

/* Kitchen order cards */
.order-card{background:var(--surface);border-radius:var(--r-lg);padding:14px;border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:10px;}
.order-card.urgent{border-color:#F43F5E;box-shadow:0 0 0 2px rgba(244,63,94,.15);}

/* Rooms grid – richer cards */
.room-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .2s var(--ease-out), box-shadow .2s var(--ease-out);position:relative;overflow:hidden;}
.room-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;}
.room-card.available::before{background:linear-gradient(180deg,#10B981,#059669);}
.room-card.occupied::before{background:linear-gradient(180deg,#F43F5E,#E11D48);}
.room-card.maintenance::before{background:linear-gradient(180deg,#F59E0B,#D97706);}
.room-card.cleaning::before{background:linear-gradient(180deg,#6D3CF0,#4338CA);}
.room-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.room-num{font-size:1.4rem;font-weight:800;color:var(--ink-800);letter-spacing:-.02em;}
.room-type{font-size:.78rem;color:var(--ink-500);margin-top:2px;}
.room-rate{font-size:.85rem;color:var(--ink-700);margin-top:6px;font-weight:600;}

/* WebSocket indicator */
#ws-indicator{font-size:.72rem;font-weight:600;}

/* ── Block 2: Calendar grid styles ────────────────────────── */
/* ── Calendar grid ──────────────────────────────────────── */
.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px;}
.cal-dow{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-mid);padding:4px 0;text-transform:uppercase;letter-spacing:.04em;}
.cal-body{display:flex;flex-direction:column;gap:2px;}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-cell{
  min-height:72px;background:var(--white);border:1px solid var(--border);
  border-radius:6px;padding:4px 5px;cursor:pointer;transition:box-shadow .15s;
  overflow:hidden;
}
.cal-cell:hover{box-shadow:0 2px 8px rgba(0,0,0,.12);border-color:var(--gold);}
.cal-cell-empty{background:var(--cream);border:1px solid transparent;cursor:default;border-radius:6px;}
.cal-today{border:2px solid var(--maroon)!important;background:#fff8f8;}
.cal-past{background:#fafafa;}
.cal-past .cal-day-num{color:#bbb;}
.cal-has-events{background:#fffdf5;}
.cal-day-num{font-size:.75rem;font-weight:700;color:var(--text-dark);margin-bottom:3px;}
.cal-today .cal-day-num{
  background:var(--maroon);color:white;
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;margin-bottom:4px;
}
.cal-pills{display:flex;flex-direction:column;gap:2px;}
.cal-pill{
  font-size:.62rem;color:white;padding:1px 4px;border-radius:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;
}
.cal-overflow{font-size:.6rem;color:var(--text-light);margin-top:1px;padding-left:2px;}

/* Mobile tweaks */
@media(max-width:480px){
  .cal-cell{min-height:54px;padding:3px;}
  .cal-pill{font-size:.55rem;}
  .cal-day-num{font-size:.68rem;}
}

/* ── MINIBAR MODULE ─────────────────────────────────────── */
#view-minibar .section-header { margin-bottom: 14px; }
/* Item cards stack nicely on all screen sizes */
.mb-item-card { transition: box-shadow .15s; }
.mb-item-card:active { box-shadow: var(--shadow-lg); }
/* Category filter pills */
#mb-cat-filter { padding-bottom: 8px; scrollbar-width: none; }
#mb-cat-filter::-webkit-scrollbar { display: none; }
/* Consume modal: make the +/- hit targets larger on small screens */
@media(max-width:380px) {
  #mb-consume-picker button[onclick*="adjustConsumeQty"] { width:44px;height:44px; }
  #mb-consume-picker div[id^="cq-"] { width:36px;height:44px; }
}
/* Restock modal qty input — big and thumb-friendly */
#restock-qty { font-size:1.3rem;text-align:center;padding:14px;letter-spacing:.05em; }
/* Minibar add modal — category suggestions datalist */
#mb-category-list option { font-size:.9rem; }
/* Tablet: 2-col item grid */
@media(min-width:640px) {
  #minibar-catalogue > div > .mb-item-card:not(:last-child) { margin-bottom:10px; }
}
/* Mobile: full-width consume modal picker rows */
@media(max-width:480px) {
  #minibar-consume-modal .modal-box { padding: 20px 14px 32px; }
  #mb-submit-btn { font-size:.9rem; padding:13px; }
}

/* ============================================================================
   GLOBAL MOBILE/A11Y OVERRIDES (added)
   Catches inline-styled inputs across OTA form, QR setup, room bar, etc.
   ============================================================================ */

/* Prevent iOS auto-zoom: force inputs to 16px on touch screens, regardless
   of inline style="font-size:0.88rem" that the OTA/QR forms set. */
@media (max-width: 768px) {
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="number"], input[type="date"], input[type="search"],
  input[type="password"], input[type="url"],
  select, textarea {
    font-size: 16px !important;
  }
}

/* Cart bar — respect bottom safe area on notched phones */
#cart-bar {
  padding-bottom: calc(14px + env(safe-area-inset-bottom)) !important;
}

/* Modal box — full-bleed bottom-sheet on small phones for thumb reach */
@media (max-width: 480px) {
  .modal-box, .modal {
    margin: 0 !important;
    border-radius: 18px 18px 0 0 !important;
    max-height: 92vh;
    max-height: 92dvh;
  }
  .modal-overlay { align-items: flex-end !important; padding: 0 !important; }
}

/* OTA form 2-column grid — single column on phones, already in CSS but reinforce */
@media (max-width: 480px) {
  .ota-form-grid { grid-template-columns: 1fr !important; }
  .ota-form-grid > div[style*="grid-column: span 2"] { grid-column: 1 !important; }
}

/* Calendar — horizontal scroll on phones instead of cell crush */
@media (max-width: 480px) {
  .cal-grid {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cal-grid::-webkit-scrollbar { display: none; }
}

/* Tap-target safety for any unstyled buttons inside views */
@media (max-width: 768px) {
  .view button:not(.btn-sm):not([class*="-xs"]) {
    min-height: 44px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    transition-duration: 0.001s !important;
  }
}

/* Print-friendly admin (folio/bill printing) */
@media print {
  #cart-bar, #cart-drawer, #mobileNavDrawer, #toast,
  nav, #nav, .section-header > button { display: none !important; }
  body { background: #fff !important; }
  .card { box-shadow: none !important; border: 1px solid #ccc !important; }
}

/* ── BILLING — Room Guests cards ──────────────────────────
   These classes are referenced from billing.js loadGuests(). They were
   previously undefined, which is why the panel rendered as a wall of
   unstyled text. Cards use the same Aurora palette as the rest of the
   app so they slot in cleanly under the existing tab bar. */

.guest-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 14px;
}
@media (min-width: 720px) {
  .guest-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1200px) {
  .guest-grid { grid-template-columns: repeat(3, 1fr); }
}

.guest-card {
  background: var(--surface, #fff);
  border: 1px solid var(--border, rgba(15,23,66,0.08));
  border-radius: var(--r-lg, 20px);
  padding: 16px 18px;
  box-shadow: var(--shadow-sm, 0 1px 3px rgba(15,23,66,0.06));
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
  overflow: hidden;
}
.guest-card::before {
  /* subtle maroon accent bar on the left edge */
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
  border-radius: 4px 0 0 4px;
}
.guest-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -8px rgba(15,23,66,0.18), 0 2px 6px rgba(15,23,66,0.08);
  border-color: rgba(107,31,42,0.20);
}

/* Header — name + room pill on the left, status badge on the right */
.guest-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.guest-id { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.guest-name {
  font-family: 'Sora', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink-900, #0E1230);
  letter-spacing: -0.01em;
  line-height: 1.2;
  word-break: break-word;
}
.guest-room-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  align-self: flex-start;
  background: linear-gradient(135deg, rgba(201,149,42,0.16), rgba(232,184,75,0.10));
  color: #6B1F2A;
  border: 1px solid rgba(201,149,42,0.35);
  border-radius: 999px;
  padding: 3px 10px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.guest-status { flex-shrink: 0; align-self: flex-start; }

/* Meta row — phone · guests · check-in · nights */
.guest-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  font-size: .8rem;
  color: var(--ink-500, #4F5BB5);
  font-weight: 500;
}
.g-meta { display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }

/* Optional tag row — corporate / foreign / advance paid */
.guest-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.g-tag {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .7rem; font-weight: 600;
  padding: 3px 8px; border-radius: 6px;
  max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.g-tag-corp    { background: #EEF2FF; color: #3730A3; border: 1px solid #C7D2FE; }
.g-tag-foreign { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.g-tag-advance { background: #DCFCE7; color: #166534; border: 1px solid #BBF7D0; }

/* Footer — money summary on the left, action buttons on the right */
.guest-card-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--border, rgba(15,23,66,0.08));
  flex-wrap: wrap;
}
.guest-money { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.guest-money-row {
  display: flex; align-items: baseline; gap: 8px;
  font-size: .78rem;
}
.g-money-label {
  color: var(--ink-400, #8993D0);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: .68rem;
  min-width: 64px;
}
.g-money-val {
  color: var(--ink-800, #161B45);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.g-money-val-strong {
  color: #6B1F2A;
  font-weight: 700;
  font-size: .92rem;
}
.g-money-unit { color: var(--ink-400, #8993D0); font-weight: 500; font-size: .72rem; margin-left: 2px; }
.g-money-balance .g-money-val-strong { color: #B91C1C; }

.guest-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

/* Empty state */
.guest-empty {
  text-align: center;
  padding: 48px 16px;
  color: var(--ink-400, #8993D0);
}
.guest-empty-icon { font-size: 2.5rem; margin-bottom: 8px; }
.guest-empty-title { font-size: 1rem; font-weight: 600; color: var(--ink-700, #1F2660); }
.guest-empty-sub { font-size: .85rem; margin-top: 4px; }

/* Tighten cards on phones so all the info still reads cleanly */
@media (max-width: 480px) {
  .guest-card { padding: 14px; gap: 10px; }
  .guest-name { font-size: 1rem; }
  .guest-card-foot { flex-direction: column; align-items: stretch; }
  .guest-actions { justify-content: flex-end; }
}

/* ============================================================
   BOOKINGS — compact mobile cards
   ============================================================
   The base .data-table CSS in theme.css turns every cell into a
   label/value row on mobile, which produced 9 stacked rows per
   booking — too tall and hard to scan. Below we override that
   behavior for `.bookings-data-table` only and reflow the cells
   into a 2-column grid that mirrors how a person reads a card:
   identity at the top, dates and counts in the middle, money
   and actions at the bottom. Desktop layout is untouched. */

/* The .td-dates cell carries a one-line combined check-in→check-out
   summary and is only used on mobile. Hide it everywhere else. */
.bookings-data-table .td-dates { display: none; }

@media (max-width: 640px) {
  .bookings-data-table tbody tr {
    display: grid !important;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "guest    source"
      "room     room"
      "dates    dates"
      "amount   status"
      "actions  actions";
    gap: 8px 12px;
    padding: 14px 16px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border-radius: var(--r-lg, 20px);
    border: 1px solid var(--border, rgba(15,23,66,0.08));
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15,23,66,0.06));
    position: relative;
    overflow: hidden;
  }
  .bookings-data-table tbody tr::before {
    /* maroon/gold accent strip on the left */
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
  }

  /* Re-style every cell as a normal block (kill the row-flex from theme.css) */
  .bookings-data-table tbody td {
    display: block !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    text-align: left !important;
  }
  .bookings-data-table tbody td::before { display: none !important; }

  /* Place each cell in its grid area */
  .bookings-data-table .td-guest   { grid-area: guest; }
  .bookings-data-table .td-source  { grid-area: source; justify-self: end; align-self: start; }
  .bookings-data-table .td-room    { grid-area: room; }
  /* Hide the per-field date cells on mobile — replaced by .td-dates below */
  .bookings-data-table .td-cin,
  .bookings-data-table .td-cout,
  .bookings-data-table .td-nights,
  .bookings-data-table .td-ref     { display: none !important; }
  /* Combined dates line, only rendered on mobile */
  .bookings-data-table .td-dates {
    grid-area: dates;
    display: block !important;
    font-size: .78rem;
    color: var(--ink-500, #4F5BB5);
    padding-top: 6px !important;
    border-top: 1px dashed var(--border, rgba(15,23,66,0.08));
    margin-top: 2px;
  }
  .bookings-data-table .td-amount  { grid-area: amount; text-align: left !important; }
  .bookings-data-table .td-status  { grid-area: status; justify-self: end; align-self: end; }
  .bookings-data-table .td-actions { grid-area: actions; }
  .bookings-data-table .td-actions > div { justify-content: flex-end !important; }

  /* Guest name — bigger and bolder so it reads as the card heading */
  .bookings-data-table .td-guest > div:first-child {
    font-size: 1rem !important;
    color: var(--ink-900, #0E1230);
    letter-spacing: -0.01em;
  }
  .bookings-data-table .td-guest > div:nth-child(2) {
    font-size: .76rem !important;
    margin-top: 2px;
  }

  /* Room — show "Room ###" prefix as a pill */
  .bookings-data-table .td-room {
    font-size: .78rem;
    color: var(--ink-500, #4F5BB5);
  }
  .bookings-data-table .td-room::before {
    content: '🛏 Room ';
    font-size: .72rem;
    color: var(--ink-400, #8993D0);
    font-weight: 500;
  }
  .bookings-data-table .td-room strong {
    color: var(--ink-900, #0E1230);
    font-size: .9rem;
  }

  /* Amount — big maroon number on the left */
  .bookings-data-table .td-amount > div:first-child strong {
    font-size: 1.1rem;
    color: #6B1F2A;
    font-weight: 700;
  }
  .bookings-data-table .td-amount > div:nth-child(2),
  .bookings-data-table .td-amount > div:nth-child(3) {
    font-size: .68rem !important;
  }
}

/* ============================================================
   ALL BILLS — same compact card treatment
   ============================================================ */

@media (max-width: 640px) {
  .bills-data-table tbody tr {
    display: grid !important;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "billno   billno"
      "guest    status"
      "room     amount"
      "actions  actions";
    gap: 6px 12px;
    padding: 14px 16px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border-radius: var(--r-lg, 20px);
    border: 1px solid var(--border, rgba(15,23,66,0.08));
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15,23,66,0.06));
    position: relative;
    overflow: hidden;
  }
  .bills-data-table tbody tr::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
  }
  .bills-data-table tbody td {
    display: block !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    text-align: left !important;
  }
  .bills-data-table tbody td::before { display: none !important; }

  .bills-data-table .td-billno {
    grid-area: billno;
    font-size: .7rem !important;
    color: var(--ink-400, #8993D0) !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700 !important;
    padding-bottom: 4px !important;
    border-bottom: 1px dashed var(--border, rgba(15,23,66,0.08));
    margin-bottom: 4px;
  }
  .bills-data-table .td-guest {
    grid-area: guest;
    font-size: 1rem;
    font-weight: 700;
    color: var(--ink-900, #0E1230);
  }
  .bills-data-table .td-room {
    grid-area: room;
    font-size: .82rem;
    color: var(--ink-500, #4F5BB5);
  }
  .bills-data-table .td-room::before {
    content: '🛏 Room ';
    color: var(--ink-400, #8993D0);
    font-weight: 500;
  }
  .bills-data-table .td-amount {
    grid-area: amount;
    justify-self: end;
    text-align: right !important;
  }
  .bills-data-table .td-amount strong {
    font-size: 1.15rem;
    color: #6B1F2A;
    font-weight: 700;
  }
  .bills-data-table .td-status {
    grid-area: status;
    justify-self: end;
  }
  .bills-data-table .td-actions {
    grid-area: actions;
    text-align: right !important;
    padding-top: 6px !important;
    border-top: 1px dashed var(--border, rgba(15,23,66,0.08));
  }
  .bills-data-table .td-actions button {
    width: 100%;
  }
}

/* Bills empty state */
.bills-empty {
  text-align: center;
  padding: 48px 16px;
  color: var(--ink-400, #8993D0);
}
.bills-empty-icon { font-size: 2.5rem; margin-bottom: 8px; }
.bills-empty-title { font-size: 1rem; font-weight: 600; color: var(--ink-700, #1F2660); }
.bills-empty-sub { font-size: .85rem; margin-top: 4px; }

/* ============================================================
   ADMIN — Settings & Tables save-button states
   ============================================================
   The save buttons are always visible but disabled when nothing
   has changed. The .settings-save-dirty class adds a soft pulse
   to draw attention once the user starts editing. */

#settings-save-btn:disabled,
.btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none !important;
  transform: none !important;
}
.settings-save-dirty {
  animation: pulseSave 2.4s ease-in-out infinite;
}
@keyframes pulseSave {
  0%, 100% { box-shadow: 0 8px 24px -8px rgba(107,31,42,.5); }
  50%      { box-shadow: 0 12px 32px -8px rgba(107,31,42,.75); }
}

#settings-status-pill {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.95);
  letter-spacing: 0.02em;
}
#settings-status-pill.pill-dirty {
  background: rgba(245,158,11,0.95);
  color: #1F2937;
  animation: pulseSave 2.4s ease-in-out infinite;
}

/* ============================================================
   ADMIN — Bulk Upload UI
   ============================================================
   None of the bulk-* classes were defined anywhere, so the panel
   rendered as plain unstyled HTML — bare file inputs, raw "Drag
   & drop or browse" text, no card boundaries. Below adds the full
   visual treatment: a 2-column responsive grid of cards, each
   with a generous drop zone, hidden native file input (clicked
   via the wrapping div), and a clear primary action button. */

.bulk-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 16px;
}
@media (min-width: 720px) {
  .bulk-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1280px) {
  .bulk-grid { grid-template-columns: repeat(2, 1fr); }
}

.bulk-card {
  background: var(--surface, #fff);
  border: 1px solid var(--border, rgba(15,23,66,0.08));
  border-radius: var(--r-lg, 20px);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-sm, 0 1px 3px rgba(15,23,66,0.06));
  transition: box-shadow .2s ease, border-color .2s ease;
}
.bulk-card::before {
  /* maroon→gold accent strip on left edge, matches the rest of the app */
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
}
.bulk-card:hover {
  border-color: rgba(107,31,42,0.20);
  box-shadow: 0 8px 24px -10px rgba(15,23,66,0.18);
}
.bulk-card h4 {
  margin: 0;
  font-family: var(--font-display, 'Sora', sans-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--maroon, #6B1F2A);
  letter-spacing: -0.01em;
}
.bulk-card > p {
  margin: 0;
  font-size: .82rem;
  color: var(--ink-500, #4F5BB5);
  line-height: 1.5;
}

/* Drop zone — the heart of each card */
.bulk-drop {
  position: relative;
  border: 2px dashed rgba(107,31,42,0.22);
  background: linear-gradient(135deg, rgba(201,149,42,0.04), rgba(107,31,42,0.02));
  border-radius: var(--r, 14px);
  padding: 28px 16px;
  text-align: center;
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-height: 130px;
  justify-content: center;
}
.bulk-drop:hover {
  border-color: rgba(107,31,42,0.55);
  background: linear-gradient(135deg, rgba(201,149,42,0.10), rgba(107,31,42,0.05));
  transform: translateY(-1px);
}
.bulk-drop.drag-over {
  border-color: #C9952A;
  background: linear-gradient(135deg, rgba(201,149,42,0.20), rgba(201,149,42,0.10));
  transform: scale(1.01);
}

/* Hide the native file input — the wrapping .bulk-drop is what users click */
.bulk-drop input[type=file] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 1;
}

.bulk-drop-icon {
  font-size: 2.2rem;
  line-height: 1;
  filter: drop-shadow(0 2px 4px rgba(107,31,42,0.15));
  pointer-events: none;
}
.bulk-drop-label {
  font-size: .88rem;
  color: var(--ink-700, #1F2660);
  font-weight: 500;
  pointer-events: none;
}
.bulk-drop-label span {
  color: var(--maroon, #6B1F2A);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.bulk-drop-filename {
  font-size: .8rem;
  color: var(--maroon, #6B1F2A);
  font-weight: 600;
  margin-top: 4px;
  word-break: break-all;
  pointer-events: none;
}
.bulk-drop-filename:not(:empty)::before {
  content: '📄 ';
  margin-right: 2px;
}

/* When a file is selected, give the dropzone a confirmed look */
.bulk-drop.has-file {
  border-style: solid;
  border-color: #16A34A;
  background: linear-gradient(135deg, rgba(22,163,74,0.06), rgba(22,163,74,0.02));
}
.bulk-drop.has-file .bulk-drop-icon { content: '✅'; }

/* Override the existing .bulk-template (was already partially styled) */
.bulk-template {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  align-self: flex-start;
  font-size: .76rem;
  color: var(--maroon, #6B1F2A);
  background: rgba(107,31,42,0.06);
  border: 1px solid rgba(107,31,42,0.15);
  padding: 5px 10px;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
  font-weight: 600;
  transition: background .15s ease, border-color .15s ease;
}
.bulk-template:hover {
  background: rgba(107,31,42,0.12);
  border-color: rgba(107,31,42,0.30);
}

/* Primary upload button */
.bulk-btn {
  width: 100%;
  padding: 11px 16px;
  background: linear-gradient(135deg, #6B1F2A 0%, #8B2635 100%);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
  margin-top: 4px;
}
.bulk-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -8px rgba(107,31,42,0.5);
}
.bulk-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  background: var(--ink-300, #B8BFE3);
}

/* Result feedback (success / error after upload) */
.bulk-result {
  font-size: .82rem;
  line-height: 1.5;
  border-radius: 10px;
  padding: 0;
  background: transparent;
  color: var(--ink-700, #1F2660);
}
.bulk-result:not(:empty) {
  padding: 10px 12px;
  background: rgba(22,163,74,0.08);
  border: 1px solid rgba(22,163,74,0.25);
  color: #15803D;
}
.bulk-result.is-error {
  background: rgba(220,38,38,0.06);
  border-color: rgba(220,38,38,0.25);
  color: #B91C1C;
}

/* ============================================================
   NAV — defensive hamburger hide on desktop
   ============================================================
   Tailwind's `md:hidden` should already hide #navHamburger at
   ≥768px, but the Tailwind CDN runtime can briefly miss class
   recognition on first paint in some browsers (notably Edge),
   leaving the hamburger visible alongside the user-info block.
   This hard CSS rule guarantees the hamburger is never visible
   on desktop, regardless of Tailwind's load timing. */
@media (min-width: 768px) {
  #navHamburger { display: none !important; }
}

/* ============================================================
   ALL BILLS — desktop "best-class" table styling
   ============================================================ */
@media (min-width: 641px) {
  .bills-data-table {
    border: 1px solid var(--border, rgba(15,23,66,0.08));
    border-radius: var(--r-lg, 20px);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(15,23,66,0.04), 0 8px 32px -16px rgba(15,23,66,0.10);
  }
  .bills-data-table thead th {
    background: linear-gradient(180deg, #FAF9FC, #F4F2F8);
    color: #6B1F2A;
    font-weight: 700;
    font-size: .68rem;
    letter-spacing: 0.08em;
    padding: 14px 18px;
    border-bottom: 2px solid rgba(107,31,42,0.12);
  }
  .bills-data-table tbody tr {
    transition: background .15s ease, box-shadow .15s ease;
  }
  .bills-data-table tbody tr > td:first-child {
    position: relative;
  }
  .bills-data-table tbody tr:hover > td:first-child::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
  }
  .bills-data-table tbody tr:hover td {
    background: linear-gradient(90deg, rgba(201,149,42,0.04), rgba(107,31,42,0.02)) !important;
  }
  .bills-data-table tbody td {
    padding: 16px 18px;
    vertical-align: middle;
    border-bottom: 1px solid rgba(15,23,66,0.05);
  }
  .bills-data-table tbody tr:last-child td { border-bottom: none; }
  /* Bill # — small uppercase pill so it doesn't dominate the row */
  .bills-data-table .td-billno {
    font-family: 'SF Mono', 'Monaco', monospace !important;
    font-size: .72rem !important;
    color: var(--ink-500, #4F5BB5) !important;
    letter-spacing: 0.04em;
    font-weight: 600 !important;
  }
  /* Guest name — main identity, larger and darker */
  .bills-data-table .td-guest {
    font-weight: 600;
    color: var(--ink-900, #0E1230);
    font-size: .92rem;
  }
  /* Room — small pill with bed icon */
  .bills-data-table .td-room strong {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: linear-gradient(135deg, rgba(201,149,42,0.14), rgba(232,184,75,0.08));
    color: #6B1F2A;
    border: 1px solid rgba(201,149,42,0.30);
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: 0.01em;
  }
  .bills-data-table .td-room strong::before {
    content: '🛏';
    font-size: .85em;
    margin-right: 1px;
  }
  /* Amount — big maroon number on right */
  .bills-data-table .td-amount {
    text-align: right;
  }
  .bills-data-table .td-amount strong {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 1.05rem;
    font-weight: 700;
    color: #6B1F2A;
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
  }
  /* Status column — center the pill */
  .bills-data-table .td-status {
    text-align: center;
  }
  /* View button — make it pop subtly */
  .bills-data-table .td-actions button {
    background: #fff;
    border: 1px solid rgba(107,31,42,0.20);
    color: #6B1F2A;
    padding: 6px 16px;
    border-radius: 8px;
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s ease;
  }
  .bills-data-table .td-actions button:hover {
    background: #6B1F2A;
    color: #fff;
    border-color: #6B1F2A;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px -4px rgba(107,31,42,0.4);
  }
}

/* ============================================================
   BOOKINGS — desktop "best-class" table styling
   ============================================================ */
@media (min-width: 641px) {
  .bookings-data-table {
    border: 1px solid var(--border, rgba(15,23,66,0.08));
    border-radius: var(--r-lg, 20px);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(15,23,66,0.04), 0 8px 32px -16px rgba(15,23,66,0.10);
  }
  .bookings-data-table thead th {
    background: linear-gradient(180deg, #FAF9FC, #F4F2F8);
    color: #6B1F2A;
    font-weight: 700;
    font-size: .68rem;
    letter-spacing: 0.08em;
    padding: 14px 14px;
    border-bottom: 2px solid rgba(107,31,42,0.12);
    white-space: nowrap;
  }
  .bookings-data-table tbody tr {
    transition: background .15s ease;
  }
  .bookings-data-table tbody tr > td:first-child {
    position: relative;
  }
  .bookings-data-table tbody tr:hover > td:first-child::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, #6B1F2A 0%, #C9952A 100%);
  }
  .bookings-data-table tbody tr:hover td {
    background: linear-gradient(90deg, rgba(201,149,42,0.04), rgba(107,31,42,0.02)) !important;
  }
  .bookings-data-table tbody td {
    padding: 14px;
    vertical-align: middle;
    border-bottom: 1px solid rgba(15,23,66,0.05);
  }
  .bookings-data-table tbody tr:last-child td { border-bottom: none; }
  /* Guest name — strong identity */
  .bookings-data-table .td-guest > div:first-child {
    font-weight: 600;
    color: var(--ink-900, #0E1230);
    font-size: .92rem;
  }
  .bookings-data-table .td-guest > div:nth-child(2) {
    font-size: .76rem;
    color: var(--ink-500, #4F5BB5);
    margin-top: 2px;
    font-variant-numeric: tabular-nums;
  }
  /* OTA Ref — secondary mono text */
  .bookings-data-table .td-ref {
    font-family: 'SF Mono', 'Monaco', monospace !important;
    font-size: .76rem !important;
    color: var(--ink-400, #8993D0) !important;
  }
  /* Room — gold pill matching All Bills */
  .bookings-data-table .td-room > span:not(.status-pill) {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: linear-gradient(135deg, rgba(201,149,42,0.14), rgba(232,184,75,0.08));
    color: #6B1F2A;
    border: 1px solid rgba(201,149,42,0.30);
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
  }
  .bookings-data-table .td-room > span:not(.status-pill)::before {
    content: '🛏';
    margin-right: 1px;
  }
  /* Date cells — subtle tabular numerals */
  .bookings-data-table .td-cin,
  .bookings-data-table .td-cout {
    font-size: .82rem;
    color: var(--ink-700, #1F2660);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
  }
  /* Nights — small badge in the center */
  .bookings-data-table .td-nights {
    font-weight: 600;
    color: var(--ink-700, #1F2660);
    font-variant-numeric: tabular-nums;
  }
  /* Amount column — strong maroon number with breakdown below */
  .bookings-data-table .td-amount {
    text-align: right;
  }
  .bookings-data-table .td-amount > div:first-child strong {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: #6B1F2A;
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
  }
  .bookings-data-table .td-amount > div:nth-child(n+2) {
    font-size: .7rem !important;
    margin-top: 1px;
  }
  /* Status pill centered */
  .bookings-data-table .td-status { text-align: center; }
  /* Actions column — compact buttons */
  .bookings-data-table .td-actions { white-space: nowrap; }
  .bookings-data-table .td-actions button {
    padding: 5px 10px;
    border-radius: 7px;
    font-size: .75rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s ease;
    border: 1px solid transparent;
  }
  .bookings-data-table .td-actions .btn-sm:not(.btn-primary):not(.btn-danger) {
    background: #fff;
    border-color: rgba(15,23,66,0.12);
    color: var(--ink-700, #1F2660);
  }
  .bookings-data-table .td-actions .btn-sm:not(.btn-primary):not(.btn-danger):hover {
    background: #047857;
    color: #fff;
    border-color: #047857;
  }
  .bookings-data-table .td-actions .btn-primary {
    background: linear-gradient(135deg, #6B1F2A, #8B2635);
    color: #fff;
  }
  .bookings-data-table .td-actions .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px -4px rgba(107,31,42,0.5);
  }
  .bookings-data-table .td-actions .btn-danger {
    background: #fff;
    border-color: rgba(220,38,38,0.25);
    color: #B91C1C;
  }
  .bookings-data-table .td-actions .btn-danger:hover {
    background: #B91C1C;
    color: #fff;
    border-color: #B91C1C;
  }
}

/* Always tighten the OTA stat row above the bookings table */
.ota-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

/* ════════════════════════════════════════════════════════════
   REPORTS & ANALYTICS — world-class redesign (CSS only)
   ════════════════════════════════════════════════════════════
   No JS or HTML changes. Selectors are scoped under #view-reports
   to avoid leaking the colorful styling into other parts of the
   app. Each report panel gets its own accent palette so the user
   can identify the section at a glance. Animations are subtle —
   number entrance, card hover lift, tab glow — not distracting. */

/* ─────────────────────────── Page header ─────────────────── */
#view-reports {
  position: relative;
  /* Subtle gradient mesh in the background gives depth without
     interfering with form readability. Two soft radial blobs:
     emerald top-right, gold bottom-left. */
  background:
    radial-gradient(700px 400px at 110% -10%, rgba(16,185,129,0.06), transparent 60%),
    radial-gradient(600px 380px at -10% 110%, rgba(201,149,42,0.05), transparent 60%);
  min-height: 100%;
  padding-bottom: 30px;
}
#view-reports .section-title {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.6rem, 3.5vw, 2rem);
  font-weight: 800;
  background: linear-gradient(135deg, #6B1F2A 0%, #C9952A 60%, #16A34A 100%);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  letter-spacing: -0.02em;
  position: relative;
  display: inline-block;
  padding-right: 8px;
}
#view-reports .section-title::after {
  /* Decorative gradient underline */
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  margin-top: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, #6B1F2A, #C9952A, #16A34A);
  box-shadow: 0 4px 12px -2px rgba(107,31,42,0.3);
}

/* ─────────────────────────── Tab bar ─────────────────────── */
#view-reports .report-tabs {
  display: flex;
  gap: 8px;
  margin: 18px 0 22px;
  padding: 6px;
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: 999px;
  box-shadow: 0 4px 24px -8px rgba(15,23,66,0.10), inset 0 1px 0 rgba(255,255,255,0.8);
  overflow-x: auto;
  scrollbar-width: none;
}
#view-reports .report-tabs::-webkit-scrollbar { display: none; }

#view-reports .report-tab {
  background: transparent;
  border: none;
  border-radius: 999px;
  padding: 9px 18px;
  font-size: .85rem;
  font-weight: 600;
  font-family: 'Sora', sans-serif;
  color: var(--ink-500, #4F5BB5);
  cursor: pointer;
  white-space: nowrap;
  transition: all .25s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}
#view-reports .report-tab:hover:not(.active) {
  color: #6B1F2A;
  background: rgba(107,31,42,0.05);
}
/* Per-tab gradient when active — each report has its own color
   identity so the user always knows which section they're in. */
#view-reports .report-tab.active {
  color: #fff;
  border: none;
  box-shadow: 0 6px 20px -4px var(--tab-shadow, rgba(107,31,42,0.45)),
              inset 0 1px 0 rgba(255,255,255,0.25);
  background: var(--tab-gradient, linear-gradient(135deg, #6B1F2A, #8B3040));
  transform: translateY(-1px);
}
/* Color each tab uniquely when active */
#view-reports .report-tab:nth-child(1).active {
  --tab-gradient: linear-gradient(135deg, #059669, #10B981);
  --tab-shadow: rgba(16,185,129,0.45);
}
#view-reports .report-tab:nth-child(2).active {
  --tab-gradient: linear-gradient(135deg, #1E40AF, #3B82F6);
  --tab-shadow: rgba(59,130,246,0.45);
}
#view-reports .report-tab:nth-child(3).active {
  --tab-gradient: linear-gradient(135deg, #6D28D9, #8B5CF6);
  --tab-shadow: rgba(139,92,246,0.45);
}
#view-reports .report-tab:nth-child(4).active {
  --tab-gradient: linear-gradient(135deg, #B45309, #F59E0B);
  --tab-shadow: rgba(245,158,11,0.45);
}
#view-reports .report-tab:nth-child(5).active {
  --tab-gradient: linear-gradient(135deg, #6B1F2A, #C9952A);
  --tab-shadow: rgba(201,149,42,0.45);
}
#view-reports .report-tab:nth-child(6).active {
  --tab-gradient: linear-gradient(135deg, #BE185D, #EC4899);
  --tab-shadow: rgba(236,72,153,0.45);
}
#view-reports .report-tab:nth-child(7).active {
  --tab-gradient: linear-gradient(135deg, #1E1B4B, #4338CA);
  --tab-shadow: rgba(67,56,202,0.45);
}

/* ─────────────────────────── Date control row ────────────── */
#view-reports .report-date-row {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 20px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(15,23,66,0.06);
  border-radius: 16px;
  box-shadow: 0 2px 10px -4px rgba(15,23,66,0.08);
  flex-wrap: wrap;
}
#view-reports .report-date-row::before {
  content: '📅';
  font-size: 1.05rem;
  margin-right: -2px;
}
#view-reports .report-date-row > span {
  color: var(--ink-400, #8993D0);
  font-size: .82rem;
  font-weight: 500;
}
#view-reports .report-date-row input[type="date"] {
  border: 1.5px solid rgba(15,23,66,0.10);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: .85rem;
  font-family: 'Sora', sans-serif;
  color: #161B45;
  background: #fff;
  outline: none;
  font-variant-numeric: tabular-nums;
  transition: border-color .15s ease, box-shadow .15s ease;
  min-width: 140px;
}
#view-reports .report-date-row input[type="date"]:focus {
  border-color: #6B1F2A;
  box-shadow: 0 0 0 3px rgba(107,31,42,0.1);
}
#view-reports .report-date-row .btn-primary {
  background: linear-gradient(135deg, #6B1F2A, #8B3040);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 8px 18px;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 12px -4px rgba(107,31,42,0.4);
  transition: transform .15s ease, box-shadow .15s ease;
}
#view-reports .report-date-row .btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -6px rgba(107,31,42,0.5);
}
#view-reports .report-date-row .btn-secondary {
  background: #fff;
  border: 1.5px solid rgba(107,31,42,0.20);
  color: #6B1F2A;
  border-radius: 10px;
  padding: 8px 14px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s ease;
}
#view-reports .report-date-row .btn-secondary:hover {
  background: #6B1F2A;
  color: #fff;
}
#view-reports .report-date-row .btn-gold {
  background: linear-gradient(135deg, #B45309, #F59E0B);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 8px 16px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 12px -4px rgba(245,158,11,0.5);
  transition: transform .15s ease, box-shadow .15s ease;
}
#view-reports .report-date-row .btn-gold:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -6px rgba(245,158,11,0.6);
}

/* ─────────────────────────── KPI cards ──────────────────── */
#view-reports .kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 24px;
}
@media (min-width: 720px) {
  #view-reports .kpi-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}
@media (min-width: 1100px) {
  #view-reports .kpi-grid { grid-template-columns: repeat(6, 1fr); }
}

#view-reports .kpi-card {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.95), rgba(255,255,255,0.85));
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 18px;
  padding: 18px 18px 16px;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 1px 3px rgba(15,23,66,0.04),
    0 8px 24px -12px rgba(15,23,66,0.10);
  transition: transform .25s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow .25s cubic-bezier(0.4, 0, 0.2, 1);
  /* The colored accent comes from --kpi-color, set per panel below */
  --kpi-color: #6B1F2A;
  --kpi-color-2: #C9952A;
  isolation: isolate;
}
/* Replace the old left-edge bar with a vibrant top-right glow */
#view-reports .kpi-card::before {
  content: '';
  position: absolute;
  inset: -50% -30% auto auto;
  width: 140px;
  height: 140px;
  background: radial-gradient(circle, var(--kpi-color) 0%, transparent 65%);
  opacity: 0.15;
  border-radius: 50%;
  z-index: -1;
  transition: transform .35s ease, opacity .35s ease;
  pointer-events: none;
}
#view-reports .kpi-card::after {
  /* Thin gradient stripe at the very top of the card */
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--kpi-color), var(--kpi-color-2));
  border-radius: 18px 18px 0 0;
  z-index: 1;
}
#view-reports .kpi-card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 4px 12px -2px rgba(15,23,66,0.06),
    0 16px 40px -12px var(--kpi-color);
  border-color: rgba(255,255,255,1);
}
#view-reports .kpi-card:hover::before {
  transform: scale(1.3);
  opacity: 0.22;
}

#view-reports .kpi-val,
#view-reports .kpi-num {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.35rem, 2.5vw, 1.7rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.05;
  background: linear-gradient(135deg, var(--kpi-color), var(--kpi-color-2));
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
  position: relative;
  z-index: 1;
  /* Subtle entrance animation when the panel becomes active */
  animation: kpiFadeUp .45s cubic-bezier(0.16, 1, 0.3, 1) backwards;
}
@keyframes kpiFadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0);   }
}
#view-reports .kpi-card:nth-child(1) .kpi-val { animation-delay: 0.02s; }
#view-reports .kpi-card:nth-child(2) .kpi-val { animation-delay: 0.06s; }
#view-reports .kpi-card:nth-child(3) .kpi-val { animation-delay: 0.10s; }
#view-reports .kpi-card:nth-child(4) .kpi-val { animation-delay: 0.14s; }
#view-reports .kpi-card:nth-child(5) .kpi-val { animation-delay: 0.18s; }
#view-reports .kpi-card:nth-child(6) .kpi-val { animation-delay: 0.22s; }

#view-reports .kpi-label {
  font-size: .68rem;
  color: var(--ink-500, #4F5BB5);
  margin-top: 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ─── Per-panel KPI color theming.
   Each report panel sets its kpi-card --kpi-color so the numbers,
   the corner glow and the top stripe all coordinate. ─────────── */
#view-reports #rev-kpis  .kpi-card { --kpi-color: #059669; --kpi-color-2: #10B981; }  /* Revenue – emerald */
#view-reports #occ-kpis  .kpi-card { --kpi-color: #1E40AF; --kpi-color-2: #3B82F6; }  /* Occupancy – blue */
#view-reports #ord-kpis  .kpi-card { --kpi-color: #6D28D9; --kpi-color-2: #8B5CF6; }  /* Orders – purple */
#view-reports #ar-kpis   .kpi-card { --kpi-color: #B45309; --kpi-color-2: #F59E0B; }  /* ADR/RevPAR – amber */

/* Rotate the accent on alternating cards within a panel for visual rhythm */
#view-reports #rev-kpis .kpi-card:nth-child(2n) { --kpi-color-2: #34D399; }
#view-reports #rev-kpis .kpi-card:nth-child(3n) { --kpi-color-2: #6EE7B7; }
#view-reports #occ-kpis .kpi-card:nth-child(2n) { --kpi-color-2: #60A5FA; }
#view-reports #occ-kpis .kpi-card:nth-child(3n) { --kpi-color-2: #93C5FD; }
#view-reports #ord-kpis .kpi-card:nth-child(2n) { --kpi-color-2: #A78BFA; }
#view-reports #ord-kpis .kpi-card:nth-child(3n) { --kpi-color-2: #C4B5FD; }
#view-reports #ar-kpis  .kpi-card:nth-child(2n) { --kpi-color-2: #FBBF24; }
#view-reports #ar-kpis  .kpi-card:nth-child(3n) { --kpi-color-2: #FCD34D; }

/* ─── Decorative emoji prefix on each KPI label, scoped per panel.
   These emojis come from CSS content — no HTML/JS edits. The set
   cycles via :nth-child so even when reports.js renders a varying
   number of KPIs, each card still gets a relevant icon. ──────── */
#view-reports #rev-kpis .kpi-card:nth-child(1) .kpi-label::before { content: '💰'; }
#view-reports #rev-kpis .kpi-card:nth-child(2) .kpi-label::before { content: '🛏'; }
#view-reports #rev-kpis .kpi-card:nth-child(3) .kpi-label::before { content: '🍽'; }
#view-reports #rev-kpis .kpi-card:nth-child(4) .kpi-label::before { content: '📄'; }
#view-reports #rev-kpis .kpi-card:nth-child(5) .kpi-label::before { content: '📊'; }
#view-reports #rev-kpis .kpi-card:nth-child(6) .kpi-label::before { content: '🛒'; }

#view-reports #occ-kpis .kpi-card:nth-child(1) .kpi-label::before { content: '📈'; }
#view-reports #occ-kpis .kpi-card:nth-child(2) .kpi-label::before { content: '👥'; }
#view-reports #occ-kpis .kpi-card:nth-child(3) .kpi-label::before { content: '🏨'; }
#view-reports #occ-kpis .kpi-card:nth-child(4) .kpi-label::before { content: '🛎'; }
#view-reports #occ-kpis .kpi-card:nth-child(5) .kpi-label::before { content: '🚪'; }
#view-reports #occ-kpis .kpi-card:nth-child(6) .kpi-label::before { content: '🌙'; }

#view-reports #ord-kpis .kpi-card:nth-child(1) .kpi-label::before { content: '🛒'; }
#view-reports #ord-kpis .kpi-card:nth-child(2) .kpi-label::before { content: '✅'; }
#view-reports #ord-kpis .kpi-card:nth-child(3) .kpi-label::before { content: '⏳'; }
#view-reports #ord-kpis .kpi-card:nth-child(4) .kpi-label::before { content: '💵'; }
#view-reports #ord-kpis .kpi-card:nth-child(5) .kpi-label::before { content: '📋'; }
#view-reports #ord-kpis .kpi-card:nth-child(6) .kpi-label::before { content: '⭐'; }

#view-reports #ar-kpis  .kpi-card:nth-child(1) .kpi-label::before { content: '📈'; }
#view-reports #ar-kpis  .kpi-card:nth-child(2) .kpi-label::before { content: '💎'; }
#view-reports #ar-kpis  .kpi-card:nth-child(3) .kpi-label::before { content: '🎯'; }
#view-reports #ar-kpis  .kpi-card:nth-child(4) .kpi-label::before { content: '📊'; }
#view-reports #ar-kpis  .kpi-card:nth-child(5) .kpi-label::before { content: '🔑'; }
#view-reports #ar-kpis  .kpi-card:nth-child(6) .kpi-label::before { content: '🌟'; }

#view-reports .kpi-label::before {
  font-size: .9rem;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
}

/* ─────────────────────────── Tables inside reports ───────── */
#view-reports table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(15,23,66,0.06);
  border-radius: 16px;
  overflow: hidden;
  box-shadow:
    0 1px 3px rgba(15,23,66,0.04),
    0 12px 32px -16px rgba(15,23,66,0.12);
  margin-bottom: 16px;
  font-size: .85rem;
}
#view-reports table thead th {
  background: linear-gradient(180deg, #FAF9FC, #F0EEF6);
  color: #6B1F2A;
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 14px;
  border-bottom: 2px solid rgba(107,31,42,0.12);
  text-align: left;
}
#view-reports table tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(15,23,66,0.05);
  color: var(--ink-700, #1F2660);
  font-variant-numeric: tabular-nums;
}
#view-reports table tbody tr:last-child td { border-bottom: none; }
#view-reports table tbody tr:nth-child(even) td {
  background: rgba(201,149,42,0.025);
}
#view-reports table tbody tr:hover td {
  background: linear-gradient(90deg, rgba(201,149,42,0.06), rgba(107,31,42,0.03)) !important;
}

/* Section headings inside report panels (e.g. "Daily Breakdown",
   "Top Items") rendered by reports.js usually as <h3> or <h4>. */
#view-reports h3,
#view-reports h4 {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  color: #6B1F2A;
  margin: 24px 0 12px;
  font-size: 1rem;
  letter-spacing: -0.01em;
  display: flex;
  align-items: center;
  gap: 8px;
}
#view-reports h3::before,
#view-reports h4::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 18px;
  background: linear-gradient(180deg, #6B1F2A, #C9952A);
  border-radius: 2px;
}

/* Panel entrance animation — runs once when a panel becomes active */
#view-reports .report-panel.active {
  animation: panelFadeIn .35s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes panelFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* ─────────────────────────── Mobile polish ───────────────── */
@media (max-width: 540px) {
  #view-reports .report-tabs {
    border-radius: 16px;
    padding: 5px;
  }
  #view-reports .report-tab {
    padding: 8px 14px;
    font-size: .8rem;
  }
  #view-reports .report-date-row {
    padding: 10px 12px;
    gap: 8px;
  }
  #view-reports .report-date-row input[type="date"] {
    flex: 1 1 auto;
    min-width: 130px;
  }
  #view-reports .kpi-card {
    padding: 14px 14px 12px;
  }
  #view-reports .kpi-val,
  #view-reports .kpi-num {
    font-size: 1.25rem;
  }
}

/* ════════════════════════════════════════════════════════════
   ANALYTICS DESIGN LANGUAGE — applied to all stat-card / ota-card
   regions across the app. Same vocabulary as Reports & Analytics:
   gradient numbers, per-card color theming, glow accent, top
   stripe, hover lift, staggered fade-up entrance.

   Pure CSS, no JS or HTML changes. Each block is scoped under
   the relevant #view-* selector so the styles never leak.
   ════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────
   Shared base — any .stat-card or .ota-card inside a target view
   gets the same premium treatment. Per-card color comes from
   --kpi-color / --kpi-color-2 set lower down per nth-child.
   ───────────────────────────────────────────────────────────── */
#view-kitchen .stat-card,
#view-housekeeping .stat-card,
#view-minibar .stat-card,
#view-ota .ota-card {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.95), rgba(255,255,255,0.85));
  border: 1px solid rgba(255,255,255,0.9) !important;
  border-radius: 18px !important;
  padding: 18px 18px 16px !important;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 1px 3px rgba(15,23,66,0.04),
    0 8px 24px -12px rgba(15,23,66,0.10);
  transition: transform .25s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow .25s cubic-bezier(0.4, 0, 0.2, 1);
  --kpi-color: #6B1F2A;
  --kpi-color-2: #C9952A;
  isolation: isolate;
  cursor: pointer;
  animation: kpiFadeUp .45s cubic-bezier(0.16, 1, 0.3, 1) backwards;
}
#view-kitchen .stat-card::before,
#view-housekeeping .stat-card::before,
#view-minibar .stat-card::before,
#view-ota .ota-card::before {
  content: '';
  position: absolute;
  inset: -50% -30% auto auto;
  width: 140px;
  height: 140px;
  background: radial-gradient(circle, var(--kpi-color) 0%, transparent 65%);
  opacity: 0.15;
  border-radius: 50%;
  z-index: -1;
  transition: transform .35s ease, opacity .35s ease;
  pointer-events: none;
}
#view-kitchen .stat-card::after,
#view-housekeeping .stat-card::after,
#view-minibar .stat-card::after,
#view-ota .ota-card::after {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--kpi-color), var(--kpi-color-2));
  border-radius: 18px 18px 0 0;
  z-index: 1;
}
#view-kitchen .stat-card:hover,
#view-housekeeping .stat-card:hover,
#view-minibar .stat-card:hover,
#view-ota .ota-card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 4px 12px -2px rgba(15,23,66,0.06),
    0 16px 40px -12px var(--kpi-color);
  border-color: rgba(255,255,255,1) !important;
}
#view-kitchen .stat-card:hover::before,
#view-housekeeping .stat-card:hover::before,
#view-minibar .stat-card:hover::before,
#view-ota .ota-card:hover::before {
  transform: scale(1.3);
  opacity: 0.22;
}

/* Numbers — gradient-clipped tabular */
#view-kitchen .stat-card .stat-num,
#view-housekeeping .stat-card .stat-num,
#view-minibar .stat-card .stat-num,
#view-ota .ota-card .ota-card-num {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.35rem, 2.5vw, 1.7rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em;
  line-height: 1.05;
  background: linear-gradient(135deg, var(--kpi-color), var(--kpi-color-2));
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent !important;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
  position: relative;
  z-index: 1;
}

/* Labels */
#view-kitchen .stat-card .stat-label,
#view-housekeeping .stat-card .stat-label,
#view-minibar .stat-card .stat-label,
#view-ota .ota-card .ota-card-label {
  font-size: .68rem !important;
  color: var(--ink-500, #4F5BB5) !important;
  margin-top: 8px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  font-weight: 700 !important;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 6px;
}
#view-kitchen .stat-card .stat-label::before,
#view-housekeeping .stat-card .stat-label::before,
#view-minibar .stat-card .stat-label::before,
#view-ota .ota-card .ota-card-label::before {
  font-size: .9rem;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.1));
}

/* Staggered fade-in for whichever wrapper holds the cards */
#view-kitchen .stat-card:nth-child(1),
#view-housekeeping .stat-card:nth-child(1),
#view-minibar .stat-card:nth-child(1),
#view-ota .ota-card:nth-child(1) { animation-delay: 0.02s; }
#view-kitchen .stat-card:nth-child(2),
#view-housekeeping .stat-card:nth-child(2),
#view-minibar .stat-card:nth-child(2),
#view-ota .ota-card:nth-child(2) { animation-delay: 0.06s; }
#view-kitchen .stat-card:nth-child(3),
#view-housekeeping .stat-card:nth-child(3),
#view-minibar .stat-card:nth-child(3),
#view-ota .ota-card:nth-child(3) { animation-delay: 0.10s; }
#view-kitchen .stat-card:nth-child(4),
#view-housekeeping .stat-card:nth-child(4),
#view-minibar .stat-card:nth-child(4),
#view-ota .ota-card:nth-child(4) { animation-delay: 0.14s; }
#view-ota .ota-card:nth-child(5) { animation-delay: 0.18s; }

/* ─────────────────────────────────────────────────────────────
   KITCHEN — Pending / Preparing / Ready / Today Revenue
   ───────────────────────────────────────────────────────────── */
#view-kitchen .stat-card:nth-child(1) {
  /* Pending — red→orange */
  --kpi-color: #DC2626; --kpi-color-2: #F59E0B;
}
#view-kitchen .stat-card:nth-child(1) .stat-label::before { content: '⏳'; }
#view-kitchen .stat-card:nth-child(2) {
  /* Preparing — blue */
  --kpi-color: #1E40AF; --kpi-color-2: #3B82F6;
}
#view-kitchen .stat-card:nth-child(2) .stat-label::before { content: '🔥'; }
#view-kitchen .stat-card:nth-child(3) {
  /* Ready — green */
  --kpi-color: #059669; --kpi-color-2: #10B981;
}
#view-kitchen .stat-card:nth-child(3) .stat-label::before { content: '🛎'; }
#view-kitchen .stat-card:nth-child(4) {
  /* Revenue — maroon → gold */
  --kpi-color: #6B1F2A; --kpi-color-2: #C9952A;
}
#view-kitchen .stat-card:nth-child(4) .stat-label::before { content: '💰'; }

/* ─────────────────────────────────────────────────────────────
   HOUSEKEEPING — Urgent / Pending / In Progress / Done Today
   ───────────────────────────────────────────────────────────── */
#view-housekeeping .stat-card:nth-child(1) {
  --kpi-color: #DC2626; --kpi-color-2: #F87171;
}
#view-housekeeping .stat-card:nth-child(1) .stat-label::before { content: '🚨'; }
#view-housekeeping .stat-card:nth-child(2) {
  --kpi-color: #B45309; --kpi-color-2: #F59E0B;
}
#view-housekeeping .stat-card:nth-child(2) .stat-label::before { content: '⏱'; }
#view-housekeeping .stat-card:nth-child(3) {
  --kpi-color: #1E40AF; --kpi-color-2: #60A5FA;
}
#view-housekeeping .stat-card:nth-child(3) .stat-label::before { content: '🧹'; }
#view-housekeeping .stat-card:nth-child(4) {
  --kpi-color: #059669; --kpi-color-2: #34D399;
}
#view-housekeeping .stat-card:nth-child(4) .stat-label::before { content: '✅'; }

/* ─────────────────────────────────────────────────────────────
   MINIBAR — Items / Stock Value / Low Stock / Out of Stock
   ───────────────────────────────────────────────────────────── */
#view-minibar .stat-card:nth-child(1) {
  --kpi-color: #4338CA; --kpi-color-2: #818CF8;
}
#view-minibar .stat-card:nth-child(1) .stat-label::before { content: '📦'; }
#view-minibar .stat-card:nth-child(2) {
  --kpi-color: #059669; --kpi-color-2: #C9952A;
}
#view-minibar .stat-card:nth-child(2) .stat-label::before { content: '💰'; }
#view-minibar .stat-card:nth-child(3) {
  --kpi-color: #B45309; --kpi-color-2: #F59E0B;
}
#view-minibar .stat-card:nth-child(3) .stat-label::before { content: '⚠️'; }
#view-minibar .stat-card:nth-child(4) {
  --kpi-color: #DC2626; --kpi-color-2: #F87171;
}
#view-minibar .stat-card:nth-child(4) .stat-label::before { content: '🚫'; }

/* ─────────────────────────────────────────────────────────────
   OTA / BOOKINGS — Arriving / Pending / Confirmed / Revenue / Commission
   ───────────────────────────────────────────────────────────── */
#view-ota .ota-card:nth-child(1) {
  --kpi-color: #1E40AF; --kpi-color-2: #60A5FA;
}
#view-ota .ota-card:nth-child(1) .ota-card-label::before { content: '🛬'; }
#view-ota .ota-card:nth-child(2) {
  --kpi-color: #B45309; --kpi-color-2: #F59E0B;
}
#view-ota .ota-card:nth-child(2) .ota-card-label::before { content: '⏳'; }
#view-ota .ota-card:nth-child(3) {
  --kpi-color: #059669; --kpi-color-2: #34D399;
}
#view-ota .ota-card:nth-child(3) .ota-card-label::before { content: '✅'; }
#view-ota .ota-card:nth-child(4),
#view-ota .ota-card.ota-card-revenue {
  --kpi-color: #6B1F2A; --kpi-color-2: #C9952A;
}
#view-ota .ota-card:nth-child(4) .ota-card-label::before,
#view-ota .ota-card.ota-card-revenue .ota-card-label::before { content: '💎'; }
#view-ota .ota-card:nth-child(5),
#view-ota .ota-card.ota-card-commission {
  --kpi-color: #BE185D; --kpi-color-2: #EC4899;
}
#view-ota .ota-card:nth-child(5) .ota-card-label::before,
#view-ota .ota-card.ota-card-commission .ota-card-label::before { content: '💸'; }

/* OTA "Bookings by Source" mini-list — give it the report vibe */
#view-ota .ota-source-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  background: rgba(255,255,255,0.6) !important;
  border: 1px solid rgba(15,23,66,0.06) !important;
  border-radius: 12px !important;
  margin-bottom: 8px !important;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
#view-ota .ota-source-row:hover {
  transform: translateX(2px);
  box-shadow: 0 4px 12px -4px rgba(15,23,66,0.10);
  border-color: rgba(107,31,42,0.20) !important;
}
#view-ota .ota-source-count {
  margin-left: auto;
  font-size: .82rem;
  color: var(--ink-500, #4F5BB5);
  font-variant-numeric: tabular-nums;
}
#view-ota .ota-source-rev {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: .92rem;
  background: linear-gradient(135deg, #6B1F2A, #C9952A);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
  min-width: 90px;
  text-align: right;
}

/* ─────────────────────────────────────────────────────────────
   ADMIN → AUDIT TRAIL — premium event-log presentation
   The markup is hardcoded inline-styled, but specificity wins.
   ───────────────────────────────────────────────────────────── */
#admin-panel-audit > div {
  max-width: none !important;
}
/* The filter bar at the top */
#admin-panel-audit > div > div:first-child {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.85), rgba(255,255,255,0.65)) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(15,23,66,0.06) !important;
  border-radius: 16px !important;
  box-shadow: 0 2px 10px -4px rgba(15,23,66,0.08) !important;
  padding: 14px 16px !important;
}
#admin-panel-audit input[type="text"],
#admin-panel-audit input[type="date"] {
  border: 1.5px solid rgba(15,23,66,0.10) !important;
  border-radius: 10px !important;
  padding: 8px 12px !important;
  font-size: .85rem !important;
  font-family: 'Sora', sans-serif !important;
  color: #161B45 !important;
  background: #fff !important;
  transition: border-color .15s ease, box-shadow .15s ease;
}
#admin-panel-audit input[type="text"]:focus,
#admin-panel-audit input[type="date"]:focus {
  border-color: #4338CA !important;
  box-shadow: 0 0 0 3px rgba(67,56,202,0.1) !important;
  outline: none;
}
#admin-panel-audit label {
  font-size: .65rem !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #4338CA !important;
  margin-bottom: 4px;
}

/* Audit table container */
#admin-panel-audit > div > div:nth-child(2) {
  background: rgba(255,255,255,0.85) !important;
  border: 1px solid rgba(15,23,66,0.06) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow:
    0 1px 3px rgba(15,23,66,0.04),
    0 12px 32px -16px rgba(15,23,66,0.12) !important;
}
/* Header row of the audit card */
#admin-panel-audit > div > div:nth-child(2) > div:first-child {
  background: linear-gradient(180deg, #FAF9FC, #F0EEF6) !important;
  border-bottom: 2px solid rgba(67,56,202,0.15) !important;
}
#admin-panel-audit > div > div:nth-child(2) > div:first-child h3 {
  background: linear-gradient(135deg, #1E1B4B, #4338CA) !important;
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent !important;
  -webkit-text-fill-color: transparent;
  font-weight: 800 !important;
  font-size: 1rem !important;
}

/* Audit table rows — same hover wash, same alternating row tint */
#admin-panel-audit table thead th {
  background: linear-gradient(180deg, #FAF9FC, #F0EEF6) !important;
  color: #4338CA !important;
  font-weight: 700 !important;
  font-size: .68rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 12px 14px !important;
  border-bottom: 2px solid rgba(67,56,202,0.12) !important;
}
#admin-panel-audit table tbody tr:nth-child(even) td {
  background: rgba(67,56,202,0.025) !important;
}
#admin-panel-audit table tbody tr:hover td {
  background: linear-gradient(90deg, rgba(67,56,202,0.06), rgba(99,102,241,0.03)) !important;
}
#admin-panel-audit table tbody td {
  padding: 12px 14px !important;
  border-bottom: 1px solid rgba(15,23,66,0.05) !important;
}

/* Pagination buttons */
#admin-panel-audit button.btn-primary {
  background: linear-gradient(135deg, #1E1B4B, #4338CA) !important;
  border: none !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 8px 16px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 12px -4px rgba(67,56,202,0.4);
  transition: transform .15s ease, box-shadow .15s ease;
}
#admin-panel-audit button.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -6px rgba(67,56,202,0.5);
}
#admin-panel-audit button.btn-secondary {
  border: 1.5px solid rgba(67,56,202,0.20) !important;
  color: #4338CA !important;
  border-radius: 10px !important;
  padding: 8px 14px !important;
}
#admin-panel-audit button.btn-secondary:hover {
  background: #4338CA !important;
  color: #fff !important;
}
