/* Wake Up — brand stylesheet */
:root, [data-theme="dark"]{
  --dark:   #201A11;
  --dark2:  #2C2418;
  --dark3:  #3A3022;
  --cream:  #E8DFD0;
  --cream2: #F2EDE4;
  --gold:   #D4BE8F;
  --gold2:  #E0CCA0;
  --mocha:  #8B7355;
  --mocha2: #6A5640;
  --border-rgb: 200,180,138;
  --border-alpha: 0.10;
  --border-alpha-strong: 0.28;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.22);
  --shadow:    0 14px 42px rgba(0,0,0,0.42);
  --shadow-hover: 0 18px 52px rgba(0,0,0,0.52);
  --glow-gold: 0 0 0 3px rgba(212,190,143,0.18);
  --modal-scrim: rgba(10,7,3,0.72);
  --danger: #e8a89a;
  --success: #9fd6a0;
}
[data-theme="light"]{
  --dark:   #F8F4EB;   /* page bg */
  --dark2:  #FFFFFF;   /* card bg */
  --dark3:  #F1EADB;   /* emphasis / tr even */
  --cream:  #2C2418;   /* primary text */
  --cream2: #1F1A10;
  --gold:   #8B6B3A;   /* accent gold (darker for contrast) */
  --gold2:  #A3823E;
  --mocha:  #6B5A42;   /* muted text */
  --mocha2: #8A7860;
  --border-rgb: 60,50,30;
  --border-alpha: 0.08;
  --border-alpha-strong: 0.20;
  --shadow-sm: 0 1px 3px rgba(44,36,24,0.06);
  --shadow:    0 10px 30px rgba(44,36,24,0.12);
  --shadow-hover: 0 18px 42px rgba(44,36,24,0.18);
  --glow-gold: 0 0 0 3px rgba(139,107,58,0.15);
  --modal-scrim: rgba(44,36,24,0.35);
}
:root{
  --radius: 16px;
  --border: 1px solid rgba(var(--border-rgb), var(--border-alpha));
  --border-strong: 1px solid rgba(var(--border-rgb), var(--border-alpha-strong));
  --font-display: 'Grand Hotel', cursive;  /* logo / brand only */
  --font-strong:  'DM Sans', system-ui, -apple-system, sans-serif; /* numbers, titles */
  --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:var(--font-body);color:var(--cream);background:var(--dark)}
body{
  min-height:100vh;font-weight:400;line-height:1.5;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  background:
    radial-gradient(ellipse at top left, rgba(212,190,143,0.06) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(139,115,85,0.05) 0%, transparent 50%),
    var(--dark);
  background-attachment:fixed;
}
a{color:var(--gold);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold2)}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--gold);color:var(--dark)}

/* Scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:rgba(var(--border-rgb),0.25);border-radius:6px;border:2px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:rgba(var(--border-rgb),0.45);background-clip:padding-box;border:2px solid transparent}

/* Content fade-in (applied by router via .content animates when innerHTML swaps) */
@keyframes fadeInUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.content > *{animation:fadeInUp .22s ease-out both}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 20px;border-radius:10px;border:1px solid transparent;
  font-weight:600;font-size:14px;letter-spacing:.2px;
  transition:transform .08s ease, background .2s, border-color .2s, box-shadow .2s, color .15s;
  outline:none;
}
.btn:focus-visible{box-shadow:var(--glow-gold)}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  color:var(--dark);border-color:var(--gold);
  box-shadow:0 4px 14px -2px rgba(212,190,143,0.35);
}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 6px 18px -2px rgba(212,190,143,0.45)}
.btn-secondary{background:transparent;color:var(--gold);border-color:rgba(var(--border-rgb),0.35)}
.btn-secondary:hover{border-color:var(--gold);background:rgba(var(--border-rgb),0.06)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(var(--border-rgb),0.18)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);background:rgba(var(--border-rgb),0.05)}
.shift-tab.active{background:var(--gold);color:var(--dark);border-color:var(--gold);font-weight:600}
.shift-tab.active:hover{background:var(--gold2);color:var(--dark)}
.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(232,168,154,0.35)}
.btn-danger:hover{background:rgba(232,168,154,0.08);border-color:var(--danger)}
.btn-block{width:100%}
.btn-sm{padding:7px 14px;font-size:13px}

/* Icon buttons */
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:8px;
  background:transparent;color:var(--cream);
  border:1px solid rgba(var(--border-rgb),var(--border-alpha-strong));
  font-size:15px;line-height:1;
  transition:background .15s, border-color .15s, color .15s, transform .08s;
}
.icon-btn:hover{background:rgba(var(--border-rgb),0.08);border-color:var(--gold);color:var(--gold)}
.icon-btn:active{transform:translateY(1px)}
.icon-btn.primary{background:var(--gold);color:var(--dark);border-color:var(--gold);font-size:18px;font-weight:600}
.icon-btn.primary:hover{background:var(--gold);filter:brightness(1.08)}
.icon-btn.danger{color:var(--danger);border-color:rgba(232,168,154,0.35)}
.icon-btn.danger:hover{background:rgba(232,168,154,0.08);color:var(--danger);border-color:var(--danger)}
td.actions{white-space:nowrap;display:flex;gap:6px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--mocha)}

/* Sidebar bottom action row (theme / settings / logout) */
.side-actions{display:flex;gap:6px;justify-content:space-between;margin-top:4px}
.side-actions .icon-btn{flex:1;width:auto;height:36px;font-size:16px}

/* ---------- Inputs ---------- */
input, select, textarea{
  width:100%;padding:11px 14px;border-radius:10px;
  background:var(--dark2);color:var(--cream);
  border:1px solid rgba(var(--border-rgb),0.18);
  font-family:inherit;font-size:14px;font-weight:400;
  transition:border-color .15s, background .15s, box-shadow .15s;
  outline:none;
}
input:hover, select:hover, textarea:hover{border-color:rgba(var(--border-rgb),0.32)}
input:focus, select:focus, textarea:focus{
  border-color:var(--gold);background:var(--dark3);box-shadow:var(--glow-gold);
}
input[readonly], input:disabled, select:disabled{opacity:.7;cursor:not-allowed}
label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--mocha);font-weight:400}
label > span{color:var(--mocha);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:500}

/* ---------- Login page ---------- */
.login-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 20%, #3a3022 0%, var(--dark) 60%);
  padding:24px;
}
.login-card{
  width:100%;max-width:420px;
  background:var(--dark2);border:var(--border);
  border-radius:var(--radius);padding:36px 32px;
  box-shadow:var(--shadow);text-align:center;
}
.logo-mark{display:flex;justify-content:center;margin-bottom:8px}
.brand-title{
  font-family:var(--font-display);font-weight:400;
  font-size:48px;color:var(--cream);margin:0;letter-spacing:.5px;
}
.brand-sub{
  color:var(--gold);margin:4px 0 28px;font-size:13px;
  letter-spacing:2px;text-transform:uppercase;font-weight:400;
}
.login-card form{display:flex;flex-direction:column;gap:14px;text-align:left}
.login-card .btn-primary{margin-top:6px}
.tagline{
  margin-top:24px;color:var(--mocha);font-size:13px;
  font-style:italic;letter-spacing:.3px;
}
.error-msg{
  color:#e8a89a;font-size:13px;margin:6px 0 0;text-align:center;
  padding:10px;border-radius:8px;background:rgba(232,168,154,0.08);
  border:1px solid rgba(232,168,154,0.25);
}

/* ---------- App layout ---------- */
.app-page{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg,var(--dark2) 0%,var(--dark) 100%);
  border-right:var(--border);
  display:flex;flex-direction:column;padding:20px 14px;
  position:sticky;top:0;height:100vh;
}
.side-logo{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;border-bottom:var(--border);margin-bottom:10px}
.side-brand .brand-name{font-family:var(--font-display);font-size:26px;color:var(--cream);line-height:1}
.side-brand .brand-tag{color:var(--gold);font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-top:2px}

.side-nav{display:flex;flex-direction:column;gap:3px;margin-top:4px;flex:1}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:10px;
  color:var(--cream);font-size:14px;font-weight:500;
  position:relative;
  transition:background .18s ease, color .18s ease, padding .18s ease;
}
.nav-item[hidden]{display:none !important}
.nav-item .ico{color:var(--gold);font-size:14px;width:18px;text-align:center;opacity:.75;transition:opacity .18s, transform .18s}
.nav-item:hover{background:rgba(var(--border-rgb),0.06);color:var(--cream2);padding-left:18px}
.nav-item:hover .ico{opacity:1;transform:scale(1.1)}
.nav-item.active{
  background:linear-gradient(90deg,rgba(212,190,143,0.18),rgba(212,190,143,0.04));
  color:var(--cream);font-weight:600;
  box-shadow:inset 3px 0 0 var(--gold);
}
.nav-item.active .ico{opacity:1;color:var(--gold)}

.side-foot{margin-top:8px;padding-top:14px;border-top:var(--border);display:flex;flex-direction:column;gap:10px}

/* User badge floating top-right */
.user-badge{
  position:fixed;top:18px;right:22px;z-index:20;
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;
  padding:10px 14px 8px;border-radius:14px;
  background:var(--dark2);border:var(--border-strong);box-shadow:var(--shadow-sm);
  font-size:13px;
}
.user-badge-top{display:flex;align-items:center;gap:10px}
.user-badge-name{color:var(--cream);font-weight:600;letter-spacing:.2px}
.user-badge-logout{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:1px solid rgba(212,123,106,0.35);color:#d49b80;
  padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
}
.user-badge-logout:hover{background:rgba(212,123,106,0.12);border-color:rgba(212,123,106,0.6);color:#d47a6a}
.user-badge-logout svg{flex-shrink:0}
.role-badge{
  display:inline-flex;align-items:center;
  font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-weight:600;
  padding:3px 9px;border-radius:999px;
  background:rgba(200,180,138,0.12);color:var(--gold);border:1px solid rgba(200,180,138,0.25);
}
.role-badge.owner{background:var(--gold);color:var(--dark);border-color:var(--gold)}

/* Shift badge in top-right user bar */
.shift-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-weight:600;
  padding:3px 9px;border-radius:999px;
}
.shift-badge.morning{background:rgba(255,210,120,0.18);color:#f2d898;border:1px solid rgba(255,210,120,0.30)}
.shift-badge.afternoon{background:rgba(140,170,230,0.18);color:#8ab4f8;border:1px solid rgba(140,170,230,0.30)}

/* Settings / permissions */
.perm-user-list{display:flex;flex-direction:column;gap:16px}
.perm-user-card{padding:18px 22px}
.perm-user-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.perm-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px;
}
.perm-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  background:rgba(var(--border-rgb),0.04);border:1px solid rgba(var(--border-rgb),0.12);
  cursor:pointer;transition:border-color .15s, background .15s;
  font-size:13px;color:var(--cream);font-weight:400;text-transform:none;letter-spacing:0;
}
.perm-item:hover{border-color:rgba(var(--border-rgb),0.28)}
.perm-item:has(input:checked){border-color:var(--gold);background:rgba(212,190,143,0.08)}
.perm-item input{width:auto;margin:0;accent-color:var(--gold)}
@media (max-width:768px){
  .user-badge{top:10px;right:10px;padding:8px 10px 6px}
  .user-badge-name{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .user-badge-logout span{display:none}
  .user-badge-logout{padding:4px 8px}
}
.today{color:var(--mocha);font-size:12px;text-align:center;letter-spacing:.5px}
.now-time{
  color:var(--gold);text-align:center;
  font-family:var(--font-strong);font-size:18px;font-weight:600;
  font-variant-numeric:tabular-nums;letter-spacing:.5px;
  margin-top:2px;
}

/* ---------- Content ---------- */
.content{
  padding:clamp(20px,2.2vw,44px) clamp(24px,2.6vw,56px);
  width:100%;
  padding-right:max(clamp(24px,2.6vw,56px), 220px);
}
@media (max-width:900px){.content{padding-right:clamp(24px,2.6vw,56px)}}
.view-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:28px;gap:16px;flex-wrap:wrap;
  padding-bottom:18px;border-bottom:var(--border);
}
.view-title{font-family:var(--font-strong);font-size:32px;color:var(--cream);font-weight:700;letter-spacing:-0.025em;margin:0;line-height:1.1}
.view-sub{color:var(--mocha);font-size:13px;letter-spacing:.3px;margin-top:4px}

.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.toolbar input[type=month], .toolbar select{width:auto;min-width:140px}

/* Segmented control (Month / Year toggle in analytics) */
.seg-group{
  display:inline-flex;border:1px solid rgba(var(--border-rgb),0.20);border-radius:10px;
  background:rgba(var(--border-rgb),0.04);padding:2px;gap:2px;
}
.seg-group .seg{
  padding:6px 14px;border-radius:8px;background:transparent;color:var(--mocha);
  border:none;font-size:13px;font-weight:600;letter-spacing:.2px;
  transition:background .15s, color .15s;
}
.seg-group .seg:hover{color:var(--cream)}
.seg-group .seg.active{background:var(--gold);color:var(--dark);box-shadow:0 1px 4px rgba(0,0,0,0.15)}

/* Cards & grids */
.card{
  background:var(--dark2);border-radius:var(--radius);
  border:var(--border);padding:22px;
  box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:rgba(var(--border-rgb),var(--border-alpha-strong))}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.kpi{
  padding:20px 22px;position:relative;overflow:hidden;
}
.kpi::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,rgba(var(--border-rgb),0.4),transparent);
}
.kpi.gold::before{background:linear-gradient(180deg,var(--gold),transparent)}
.kpi.gold{
  background:linear-gradient(135deg,var(--dark2) 0%,var(--dark2) 60%,rgba(212,190,143,0.08) 100%);
}
.kpi .label{color:var(--mocha);font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;font-weight:600}
.kpi .value{font-family:var(--font-strong);font-size:30px;color:var(--cream);line-height:1.1;font-weight:700;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.kpi.big .value{font-size:56px;background:linear-gradient(135deg,var(--gold2),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.kpi .sub{color:var(--mocha);font-size:12px;margin-top:8px;font-weight:400}
.kpi.gold .value{color:var(--gold)}

.section{margin-bottom:28px}
.section-title{
  display:flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--gold);margin:0 0 14px;font-weight:600;
}
.section-title::before{content:'';width:14px;height:1.5px;background:var(--gold);border-radius:1px;opacity:.7}
.section-subtitle{
  font-size:11px;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--mocha);margin:0 0 10px;font-weight:600;
}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.grid-2{grid-template-columns:1fr}}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:var(--border);background:var(--dark2);box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{
  background:var(--dark3);color:var(--gold);
  text-align:left;padding:14px 16px;
  font-size:10px;letter-spacing:1.8px;text-transform:uppercase;font-weight:600;
  position:sticky;top:0;z-index:1;
  border-bottom:1px solid rgba(var(--border-rgb),var(--border-alpha-strong));
}
tbody td{padding:13px 16px;border-top:1px solid rgba(var(--border-rgb),0.06);color:var(--cream)}
tbody tr{transition:background .15s, box-shadow .15s}
tbody tr:nth-child(even){background:rgba(var(--border-rgb),0.025)}
tbody tr:hover{background:rgba(212,190,143,0.06);box-shadow:inset 3px 0 0 var(--gold)}
.amount{font-variant-numeric:tabular-nums;font-weight:500}
.amount.pos{color:var(--success)}
.amount.neg{color:var(--danger)}

/* Per-shift breakdown grid (dashboard) */
.shift-grid-wrap{margin-bottom:6px}
.shift-grid{font-size:12.5px;table-layout:fixed;min-width:1100px}
.shift-grid col.col-date{width:54px}
.shift-grid col.col-shift{width:48px}
.shift-grid col.col-name{width:120px}
.shift-grid col.col-status{width:110px}
.shift-grid col.col-notes{width:160px}
.shift-grid col.col-actions{width:80px}
.shift-grid td.shift-cell{text-align:center}
.shift-grid td.notes-cell{white-space:normal;overflow:hidden;text-overflow:ellipsis;max-width:160px;font-size:11.5px;color:var(--mocha)}
.shift-grid td.actions{text-align:center;white-space:nowrap}
.shift-grid.sales-history{min-width:1180px}
.shift-grid .shift-ico{display:inline-block;font-size:16px;line-height:1}
.shift-grid .shift-ico.morning{color:#f2d898}
.shift-grid .shift-ico.afternoon{color:#000;filter:grayscale(1) brightness(0)}
.shift-grid .shift-ico.fullday{font-size:13px;letter-spacing:1px;color:var(--gold)}
.shift-grid col.col-num{width:96px}
.shift-grid col.col-total{width:108px;background:rgba(212,190,143,0.05)}
.shift-grid col.col-total-user{background:rgba(159,214,160,0.06)}
.shift-grid col.col-total-peer{background:rgba(212,190,143,0.08)}
.shift-grid thead th{padding:10px 10px;font-size:10px;letter-spacing:1.2px;line-height:1.2;vertical-align:bottom;white-space:nowrap}
.shift-grid thead th .th-sub{display:block;margin-top:4px;font-size:9px;letter-spacing:.4px;text-transform:none;color:var(--mocha);font-weight:500}
.shift-grid thead th .th-sub.pos{color:var(--success)}
.shift-grid thead th .th-sub.neg{color:var(--danger)}
.shift-grid thead th.amount{text-align:right}
.shift-grid thead th.col-total-user-h{border-left:2px solid rgba(159,214,160,0.30);color:var(--success)}
.shift-grid thead th.col-total-peer-h{border-left:2px solid rgba(212,190,143,0.30);color:var(--gold)}
.shift-grid tbody td{padding:8px 10px;font-size:12.5px;white-space:nowrap}
.shift-grid tbody td.amount{text-align:right}
.shift-grid td.col-total-user-c{border-left:2px solid rgba(159,214,160,0.20);background:rgba(159,214,160,0.04)}
.shift-grid td.col-total-peer-c{border-left:2px solid rgba(212,190,143,0.20);background:rgba(212,190,143,0.05)}
.shift-grid tbody tr.clickable{cursor:pointer}
.shift-grid tbody tr.clickable:hover{background:rgba(212,190,143,0.08)}
.shift-grid tfoot td{padding:11px 10px;background:rgba(var(--border-rgb),0.10);border-top:2px solid rgba(212,190,143,0.30);font-weight:600}
.shift-grid tfoot td.month-total-label{text-align:right;color:var(--mocha);text-transform:uppercase;letter-spacing:1.4px;font-size:11px}
.shift-grid .nowrap{white-space:nowrap}

/* Pills */
.pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:999px;
  font-size:11px;letter-spacing:.5px;font-weight:600;line-height:1.2;
  background:rgba(var(--border-rgb),0.10);color:var(--cream);border:1px solid rgba(var(--border-rgb),0.22);
  text-transform:capitalize;
}
.pill.morning{background:linear-gradient(135deg,rgba(255,210,120,0.18),rgba(255,210,120,0.06));color:#f2d898;border-color:rgba(255,210,120,0.30)}
.pill.morning::before{content:'☀';font-size:11px}
.pill.afternoon{background:linear-gradient(135deg,rgba(180,130,90,0.22),rgba(180,130,90,0.06));color:#d6a67a;border-color:rgba(180,130,90,0.35)}
.pill.afternoon::before{content:'☽';font-size:11px}
.pill.fullday{background:linear-gradient(135deg,rgba(212,190,143,0.24),rgba(180,130,90,0.08));color:var(--gold);border-color:rgba(212,190,143,0.38)}
.pill.fullday::before{content:'●';font-size:8px}
.pill.pos{background:rgba(159,214,160,0.14);color:var(--success);border-color:rgba(159,214,160,0.30)}
.pill.cash{background:rgba(159,214,160,0.10);color:var(--success);border-color:rgba(159,214,160,0.25)}
.pill.card{background:rgba(143,176,222,0.10);color:#a9c4e8;border-color:rgba(143,176,222,0.25)}
.pill.transfer{background:rgba(212,190,143,0.10);color:var(--gold);border-color:rgba(212,190,143,0.25)}

/* Forms in panel */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.form-grid.two{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.form-grid.three{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.form-actions{display:flex;gap:10px;margin-top:14px;justify-content:flex-end}

/* Stepped form groups */
.shift-form{display:flex;flex-direction:column;gap:18px}
.form-group{
  padding:16px 18px;border-radius:12px;
  background:rgba(var(--border-rgb),0.035);
  border:1px solid rgba(var(--border-rgb),0.10);
}
.form-group-title{
  display:flex;align-items:center;gap:10px;
  color:var(--gold);font-size:11px;letter-spacing:1.8px;text-transform:uppercase;
  font-weight:600;margin-bottom:12px;
}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:var(--gold);color:var(--dark);
  font-size:11px;font-weight:700;letter-spacing:0;
}

/* Summary panels inside forms (read-only computed values) */
.form-summary{
  display:flex;flex-direction:column;gap:6px;margin-top:12px;
  padding:12px 14px;border-radius:10px;
  background:var(--dark2);border:1px solid rgba(var(--border-rgb),0.12);
}
.summary-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.summary-row .summary-label{color:var(--mocha);letter-spacing:.3px}
.summary-row .summary-value{
  color:var(--cream);font-weight:600;font-variant-numeric:tabular-nums;
  font-family:var(--font-strong);
}
.summary-row.accent .summary-value{color:var(--gold);font-size:16px}
.summary-row.total{
  padding-top:8px;border-top:1px dashed rgba(var(--border-rgb),0.18);margin-top:2px;
}
.summary-row.total .summary-value{font-size:18px;color:var(--cream);letter-spacing:-0.01em}

.empty{
  padding:48px 24px;text-align:center;color:var(--mocha);
  font-style:italic;font-size:14px;
}

/* Charts */
.chart-wrap{position:relative;height:180px;margin-bottom:8px}
.chart{width:100%;height:100%;display:block}
.chart-cash{fill:var(--gold)}
.chart-card{fill:var(--mocha)}
.chart-x{position:relative;height:18px;color:var(--mocha);font-size:10px;margin-top:4px}
.chart-x span{position:absolute;transform:translateX(-50%);letter-spacing:.5px}
.chart-legend{display:flex;gap:14px;align-items:center;font-size:12px;color:var(--mocha);flex-wrap:wrap}
.chart-legend .legend-dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
.chart-legend .legend-sub{margin-left:auto;font-style:italic}
.chart-legend .legend-delta{font-weight:600;font-variant-numeric:tabular-nums}
.chart-legend .legend-delta.pos{color:var(--success)}
.chart-legend .legend-delta.neg{color:var(--danger)}

/* Chart summary chips (Total · Avg · Best day) */
.chart-summary{
  display:flex;gap:18px;flex-wrap:wrap;
  padding:10px 14px;margin-top:10px;border-radius:10px;
  background:rgba(var(--border-rgb),0.05);border:1px solid rgba(var(--border-rgb),0.10);
}
.cs-stat{display:flex;flex-direction:column;gap:2px;min-width:90px}
.cs-label{color:var(--mocha);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
.cs-val{color:var(--cream);font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;font-family:var(--font-strong)}
.cs-sub{color:var(--mocha);font-weight:500;font-size:11px;letter-spacing:.5px}

/* Donut percentage in legend */
.legend-row .legend-pct{
  font-size:10px;font-weight:500;color:var(--mocha);letter-spacing:.5px;
  padding:2px 6px;border-radius:4px;background:rgba(var(--border-rgb),0.08);margin-left:6px;
}

/* Donut hover highlight (slices) */
.donut .donut-slice{transition:opacity .15s, stroke-width .15s;cursor:pointer}
.donut:hover .donut-slice{opacity:.45}
.donut .donut-slice:hover{opacity:1;stroke-width:22}

/* Bar chart hover (Daily revenue, etc.) */
.chart .bar-grp{transition:filter .12s;cursor:pointer}
.chart .bar-grp:hover{filter:brightness(1.18)}

/* Trend chart value chips overlay */
.trend-chart-wrap{position:relative}
.trend-chips{position:absolute;inset:0;pointer-events:none}
.trend-chip{
  position:absolute;transform:translate(-50%, -100%);
  font-size:10px;font-weight:600;color:var(--cream);
  background:rgba(var(--border-rgb),0.10);border:1px solid rgba(var(--border-rgb),0.18);
  padding:1px 6px;border-radius:6px;
  font-variant-numeric:tabular-nums;white-space:nowrap;letter-spacing:.2px;
  backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
}

/* Daily revenue chart — value-on-bar labels (overlaid HTML chips so the SVG's
   non-uniform stretching doesn't distort the text). */
.rev-chart-wrap{position:relative}
.rev-chart-wrap .chart{height:calc(100% - 18px)}
.rev-chips{position:absolute;left:0;right:0;top:0;bottom:18px;pointer-events:none}
.rev-chip{
  position:absolute;transform:translate(-50%, -2px);
  font-size:9px;font-weight:600;color:var(--cream);
  font-variant-numeric:tabular-nums;letter-spacing:.2px;white-space:nowrap;
  text-shadow:0 1px 2px rgba(0,0,0,0.55);
}

/* Top expenses ranked rows */
.hbar-row-ranked{grid-template-columns:24px minmax(0,1.6fr) minmax(0,2fr) auto;gap:12px}
.hbar-rank{
  display:flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;
  background:rgba(212,190,143,0.10);color:var(--gold);
  font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;
  border:1px solid rgba(212,190,143,0.20);
}
.hbar-name{color:var(--cream);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbar-sub{color:var(--mocha);font-size:11px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.pnl-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px 16px;font-size:13px;align-items:center}
.pnl-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid rgba(200,180,138,0.15);border-radius:8px;background:rgba(200,180,138,0.04)}
.pnl-item .legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.pnl-item .pnl-name{color:var(--mocha);text-transform:uppercase;letter-spacing:.5px;font-size:11px}
.pnl-item .pnl-val{margin-left:auto;color:var(--cream);font-weight:600;font-variant-numeric:tabular-nums}
.pnl-item .pnl-val.pos{color:#9bc7a3}
.pnl-item .pnl-val.neg{color:#d49b80}
.pnl-peak{grid-column:1/-1;color:var(--mocha);font-style:italic;font-size:12px;text-align:right}

.pnl-chart-wrap{cursor:crosshair}
/* Tooltip background is always dark (overlays the chart). Text colors are
   hard-coded so they stay legible in both light and dark themes — using
   --cream / --mocha here would invert in light theme and disappear. */
.pnl-tooltip{
  position:absolute;min-width:180px;background:rgba(15,12,8,0.96);border:1px solid rgba(200,180,138,0.35);
  border-radius:8px;padding:10px 12px;font-size:12px;color:#E8DFD0;
  box-shadow:0 8px 24px rgba(0,0,0,0.45);pointer-events:none;z-index:5;
}
.pnl-tooltip[hidden]{display:none}
.pnl-tooltip .tip-day{font-weight:600;color:#D4BE8F;margin-bottom:6px;font-size:11px;text-transform:uppercase;letter-spacing:1px}
.pnl-tooltip .tip-row{display:flex;align-items:center;gap:8px;padding:2px 0;font-variant-numeric:tabular-nums;color:#E8DFD0}
.pnl-tooltip .tip-dot{display:inline-block;width:9px;height:9px;border-radius:2px;flex-shrink:0}
.pnl-tooltip .tip-name{flex:1;color:#a59886;text-transform:uppercase;letter-spacing:.5px;font-size:10px}
.pnl-tooltip .tip-val{font-weight:600;color:#E8DFD0}
.pnl-tooltip .tip-val.pos{color:#9bc7a3}
.pnl-tooltip .tip-val.neg{color:#d49b80}

.donut-wrap{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.donut{flex-shrink:0}
.donut-center{fill:var(--mocha);font-size:10px;letter-spacing:1px;text-transform:uppercase}
.donut-value{fill:var(--cream);font-size:14px;font-weight:600}
.donut-legend{flex:1;min-width:180px;display:flex;flex-direction:column;gap:6px;font-size:13px}
.legend-row{display:flex;align-items:center;gap:8px}
.legend-row .legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.legend-row .legend-name{flex:1;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.legend-row .legend-val{color:var(--mocha);font-variant-numeric:tabular-nums}

.hbar-list{display:flex;flex-direction:column;gap:10px}
.hbar-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr) auto;gap:10px;align-items:center;font-size:13px}
.hbar-label{color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbar-track{height:8px;background:rgba(var(--border-rgb),var(--border-alpha));border-radius:4px;overflow:hidden}
.hbar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--mocha));border-radius:4px}

/* Day-off pills on the employee detail panel. Click to toggle on/off.
   Bordered pill with subtle highlight when "today" matches a configured day. */
.dayoff-row{display:flex;flex-wrap:wrap;gap:6px}
.dayoff-pill{
  appearance:none;cursor:pointer;
  font:inherit;font-size:12px;font-weight:600;letter-spacing:.5px;
  padding:6px 12px;border-radius:18px;
  background:rgba(var(--border-rgb),0.06);
  color:var(--mocha);
  border:1px solid rgba(var(--border-rgb),0.18);
  transition:background .15s, color .15s, border-color .15s, transform .08s;
}
.dayoff-pill:hover{background:rgba(var(--border-rgb),0.12);color:var(--cream)}
.dayoff-pill:active{transform:translateY(1px)}
.dayoff-pill.on{
  background:rgba(212,190,143,0.18);
  color:var(--gold);
  border-color:rgba(212,190,143,0.50);
}
.dayoff-pill.is-today{
  outline:2px solid rgba(159,214,160,0.30);outline-offset:1px;
}
.dayoff-pill.on.is-today{
  background:rgba(159,214,160,0.18);
  color:#9bc7a3;
  border-color:rgba(159,214,160,0.50);
}
.dayoff-today-mark{font-weight:400;font-size:9px;opacity:0.75;margin-left:2px;letter-spacing:.4px}

/* Expenses-by-category horizontal bar chart on the dashboard.
   Sized to visually pair with the Daily revenue bar chart above it. */
.catbar-list{display:flex;flex-direction:column;gap:14px;padding:4px 2px}
.catbar-row{
  display:grid;grid-template-columns:minmax(120px,1.4fr) minmax(0,5fr) minmax(120px,auto);
  gap:14px;align-items:center;font-size:13px;
}
.catbar-name{color:var(--cream);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.catbar-track{
  height:14px;background:rgba(var(--border-rgb),var(--border-alpha));
  border-radius:7px;overflow:hidden;position:relative;
}
.catbar-fill{height:100%;border-radius:7px;transition:width .25s ease}
.catbar-val{color:var(--cream);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}
.catbar-val .catbar-share{color:var(--mocha);font-size:11px;margin-left:6px}
.hbar-val{color:var(--mocha);font-variant-numeric:tabular-nums;white-space:nowrap}

.pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;font-size:13px}
.pager .pager-label{color:var(--mocha);font-variant-numeric:tabular-nums}
.pager button[disabled]{opacity:0.4;cursor:not-allowed}

.line-table input, .line-table select{width:100%;margin:0}
.line-table td{padding:6px 4px}
.line-table tfoot td{font-weight:600;color:var(--cream)}

.group-row{background:rgba(var(--border-rgb),0.04)}
.group-row td{font-weight:500}
.group-detail td{background:rgba(var(--border-rgb),0.03)}
table.nested{width:100%;border-collapse:collapse;font-size:13px}
table.nested thead th{color:var(--mocha);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:500;padding:8px 10px;border-bottom:var(--border)}
table.nested tbody td{padding:6px 10px;border-bottom:var(--border)}
table.nested tbody tr:last-child td{border-bottom:none}

/* Inline/compact fields (used in Step 1) */
.inline-fields{display:flex;flex-wrap:wrap;gap:12px}
label.tight{max-width:220px;flex:0 0 auto}
label.tight > span{font-size:10px;letter-spacing:.8px}
label.tight input, label.tight select{padding:8px 12px;font-size:13px}
.form-group.compact{padding:12px 16px}

.sub-label{color:var(--mocha);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.sub-label .sub-hint{text-transform:none;letter-spacing:.3px;color:var(--mocha);font-weight:400;font-size:11px;margin-left:6px;opacity:.85}

/* Card-transaction rows */
.card-tx-list{display:flex;flex-direction:column;gap:8px}
.card-tx-row{display:grid;grid-template-columns:minmax(180px,220px) 1fr 32px;gap:8px;align-items:center}
.card-tx-row select, .card-tx-row input{margin:0}

/* Employee card grid (cashflow form) */
.emp-check-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:10px;
}
.emp-card{
  border:1px solid rgba(var(--border-rgb),0.15);border-radius:14px;
  background:var(--dark2);overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.emp-card:hover{border-color:rgba(var(--border-rgb),0.30)}
.emp-card.emp-off{opacity:.55}
.emp-card.emp-off .emp-avatar{filter:grayscale(.6)}
.emp-card.active{
  border-color:var(--gold);
  box-shadow:0 0 0 1px rgba(212,190,143,0.15), var(--shadow-sm);
}
.emp-card-head{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
}
.emp-avatar{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-strong);font-weight:700;font-size:15px;
  color:var(--dark);background:linear-gradient(135deg,var(--gold2),var(--gold));
  letter-spacing:.5px;
}
.emp-card.active .emp-avatar{box-shadow:0 0 0 2px var(--dark2), 0 0 0 4px var(--gold)}
.emp-card-info{flex:1;min-width:0}
.emp-card-name{color:var(--cream);font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.emp-card-role{color:var(--mocha);font-size:11px;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}

/* Toggle switch */
.emp-toggle{display:flex;align-items:center;cursor:pointer;flex-shrink:0;font-size:0}
.emp-toggle input{position:absolute;opacity:0;width:0;height:0}
.emp-toggle-track{
  width:44px;height:24px;border-radius:12px;
  background:rgba(var(--border-rgb),0.22);
  display:flex;align-items:center;padding:2px;
  transition:background .2s;
}
.emp-toggle input:checked + .emp-toggle-track{background:var(--gold)}
.emp-toggle-thumb{
  width:20px;height:20px;border-radius:10px;
  background:var(--cream);box-shadow:0 1px 4px rgba(0,0,0,0.25);
  transition:transform .18s ease;
}
.emp-toggle input:checked + .emp-toggle-track .emp-toggle-thumb{transform:translateX(20px)}

/* Expandable detail panel */
.emp-card-details{
  padding:12px 16px 14px;
  border-top:1px solid rgba(var(--border-rgb),0.12);
  background:rgba(var(--border-rgb),0.03);
  animation:fadeInUp .18s ease-out both;
}
.emp-detail-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px}
.emp-detail-grid label.tight{min-width:0;flex:1 1 100px}

/* Extra-time pill */
.emp-extra-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;color:var(--mocha);font-weight:500;cursor:pointer;
  padding:7px 12px;border-radius:999px;
  background:rgba(var(--border-rgb),0.08);border:1px solid rgba(var(--border-rgb),0.15);
  transition:background .15s, border-color .15s, color .15s;
  text-transform:none;letter-spacing:0;
}
.emp-extra-pill:hover{border-color:rgba(var(--border-rgb),0.30)}
.emp-extra-pill:has(input:checked){color:var(--gold);background:rgba(212,190,143,0.12);border-color:rgba(212,190,143,0.30)}
.emp-extra-pill input{width:auto;margin:0}
.emp-extra-pill span{text-transform:none;letter-spacing:0;font-size:12px}

/* Employee agenda */
.agenda-table{font-size:13px}
.agenda-date{font-weight:700;font-family:var(--font-strong);font-size:16px;width:40px;color:var(--cream)}
.agenda-day{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--mocha);width:40px}
.agenda-day.weekend{color:var(--gold)}
.agenda-off td{opacity:.4}
.agenda-off-label{font-style:italic;color:var(--mocha);font-size:12px}
.agenda-worked td{border-left:3px solid var(--gold) !important}

/* Supplier-detail / clickable rows */
.row-link{color:var(--cream);transition:color .15s}
.row-link:hover{color:var(--gold)}
.detail-chip-row{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;
}
.detail-chip{
  display:flex;flex-direction:column;gap:2px;
  padding:10px 14px;border-radius:10px;
  background:var(--dark2);border:var(--border);
  min-width:140px;
}
.detail-chip-label{
  color:var(--mocha);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;
}
.detail-chip span:last-child{color:var(--cream);font-size:14px;font-weight:500}

/* Toast */
.toast{
  position:fixed;bottom:28px;right:28px;
  background:var(--dark3);color:var(--cream);
  padding:14px 22px;border-radius:12px;border:var(--border-strong);
  box-shadow:var(--shadow);font-size:14px;font-weight:500;
  z-index:100;opacity:0;transform:translateY(10px);
  transition:opacity .22s, transform .22s;
  border-left:3px solid var(--gold);
}
.toast.show{opacity:1;transform:translateY(0)}
.toast.error{border-left-color:var(--danger)}
.toast.success{border-left-color:var(--success)}

/* Loader */
.loader{padding:60px;text-align:center;color:var(--mocha)}

/* Modal */
@keyframes modalScrimIn{from{opacity:0}to{opacity:1}}
@keyframes modalPopIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-back{
  position:fixed;inset:0;background:var(--modal-scrim);
  display:flex;align-items:center;justify-content:center;z-index:50;padding:24px;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  animation:modalScrimIn .18s ease-out;
}
.modal{
  background:linear-gradient(180deg,var(--dark2) 0%,var(--dark) 220%);
  border-radius:var(--radius);border:var(--border-strong);
  padding:28px;max-width:560px;width:100%;box-shadow:var(--shadow-hover);
  animation:modalPopIn .22s ease-out;
}
.modal h3{margin:0 0 14px;font-family:var(--font-strong);color:var(--cream);font-size:22px;font-weight:700;letter-spacing:-0.02em}

/* Mobile: collapse sidebar to bottom tab bar */
@media (max-width:768px){
  .app-page{grid-template-columns:1fr;display:block}
  .sidebar{
    position:fixed;left:0;right:0;bottom:0;top:auto;height:auto;
    flex-direction:row;padding:6px 4px;border-right:none;border-top:var(--border);
    z-index:30;background:var(--dark2);
  }
  .side-logo,.side-foot{display:none}
  .side-nav{
    flex-direction:row;flex:1;gap:0;margin:0;
    overflow-x:auto;overflow-y:hidden;
    scrollbar-width:none;-ms-overflow-style:none;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    padding:0 4px;
  }
  .side-nav::-webkit-scrollbar{display:none}
  .nav-item{
    flex:0 0 auto;min-width:64px;
    flex-direction:column;gap:2px;
    border-left:none;border-top:3px solid transparent;
    font-size:11px;padding:6px 8px;
    scroll-snap-align:start;
    text-align:center;
  }
  .nav-item.active{border-left:none;border-top-color:var(--gold);background:transparent}
  .nav-item .ico{font-size:18px}
  /* Subtle hint that there's more to scroll: fade out the right edge */
  .sidebar::after{
    content:'';position:absolute;right:0;top:0;bottom:0;width:24px;
    background:linear-gradient(90deg,transparent,var(--dark2));
    pointer-events:none;
  }
  .content{padding:18px 14px 96px}
  .view-title{font-size:28px}
}

/* Quick-pick chips (used for recent suppliers in expenses) */
.chip{
  padding:8px 14px;border-radius:999px;
  border:1px solid rgba(200,180,138,0.25);
  background:transparent;color:var(--cream);
  font-size:13px;font-weight:500;cursor:pointer;
  transition:all .15s;font-family:inherit;
}
.chip:hover{border-color:var(--gold);background:rgba(200,180,138,0.06)}
.chip.active{background:var(--gold);color:var(--dark);border-color:var(--gold)}

/* Card-tx row: hide select until International is added */
.card-tx-row.simple .tx-type{display:none}

/* Compact spacing for the cashflow shift form */
.shift-form{gap:12px}
.shift-form .form-group{padding:12px 14px}
.shift-form .inline-fields{gap:10px}
.shift-form .form-summary{margin-top:8px}
.shift-form .form-actions{margin-top:8px}
.shift-form .emp-check-grid{gap:8px}
.shift-form .emp-card-head{padding:10px 12px;gap:10px}
.shift-form .emp-card-details{padding:10px 12px 12px}
.shift-form .emp-detail-grid{gap:10px;margin-bottom:8px}
.shift-form .emp-avatar{width:36px;height:36px;font-size:13px}

/* Compact spacing for the expenses entry form */
#expForm .inline-fields{gap:10px}
#expForm .form-grid{gap:10px}
#expForm .form-actions{margin-top:8px}
#expForm .table-wrap{margin-top:10px !important}
#expForm thead th{padding:10px 12px}
#expForm tbody td{padding:8px 10px}

/* Analytics: stacked bars (revenue vs expenses+payroll) */
.bar-legend{
  display:flex;gap:18px;align-items:center;font-size:12px;color:var(--mocha);margin-bottom:10px;flex-wrap:wrap;
}
.bar-legend .dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
.bar-legend .dot.rev{background:linear-gradient(135deg,var(--gold2),var(--gold))}
.bar-legend .dot.cost{background:rgba(180,130,90,0.55)}
.bar-list{display:flex;flex-direction:column;gap:6px}
.bar-row{display:grid;grid-template-columns:96px 1fr 110px;align-items:center;gap:10px}
.bar-label{font-size:12px;color:var(--cream);font-weight:500}
.bar-track{
  position:relative;height:22px;border-radius:8px;
  background:rgba(var(--border-rgb),0.06);overflow:hidden;
  display:flex;align-items:center;
}
.bar-fill{height:100%;border-radius:8px;transition:width .25s ease}
.bar-fill.rev{
  background:linear-gradient(90deg,rgba(212,190,143,0.85),rgba(212,190,143,0.55));
  position:absolute;left:0;top:0;bottom:0;
}
.bar-fill.cost{
  background:linear-gradient(90deg,rgba(180,130,90,0.6),rgba(180,130,90,0.35));
  position:absolute;left:0;top:0;bottom:0;mix-blend-mode:multiply;
  border-left:1px dashed rgba(255,255,255,0.10);
}
.bar-value{
  font-variant-numeric:tabular-nums;font-weight:600;font-size:13px;text-align:right;
}

/* Footer total row in history tables */
tfoot .total-row td{
  background:rgba(212,190,143,0.06);
  border-top:2px solid rgba(212,190,143,0.35);
  padding:14px 16px;
  font-size:14px;
}
tfoot .total-row strong{color:var(--gold);font-size:16px;letter-spacing:-0.01em}

/* Responsive: stack form rows + grow inputs at narrow widths */
@media (max-width:640px){
  .inline-fields{flex-direction:column;gap:10px}
  .inline-fields > label{width:100%}
  .form-grid{grid-template-columns:1fr !important}
  .line-table thead{display:none}
  .line-table, .line-table tbody, .line-table tr, .line-table td{display:block;width:100%}
  .line-table tr{
    border:var(--border);border-radius:12px;padding:10px;margin-bottom:10px;
  }
  .line-table td{padding:6px 0;border:none}
  .line-table td::before{
    content:attr(data-label);display:block;
    font-size:11px;color:var(--mocha);text-transform:uppercase;letter-spacing:0.6px;
    margin-bottom:4px;
  }
  .emp-card-head .emp-card-info .emp-card-role{display:none}
  .emp-avatar{width:32px;height:32px;font-size:13px}
  .chip{padding:10px 16px;font-size:14px}
  .pin-key, .btn{min-height:44px}
  input[type=text], input[type=number], input[type=date], input[type=time], select{
    font-size:16px; /* prevents iOS auto-zoom */
  }
}

/* Maintenance mode banner (owner only) */
.maintenance-bar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:linear-gradient(90deg,#b45309,#d97706);
  color:#fff;font-family:var(--font-strong);font-weight:600;
  padding:10px 14px;text-align:center;font-size:13px;letter-spacing:0.01em;
  box-shadow:0 2px 10px rgba(0,0,0,0.25);
}
.maintenance-bar a{color:#fff;text-decoration:underline;margin-left:6px}
body:has(.maintenance-bar) .app-page{padding-top:38px}
