:root{
  --bg:#0a0a0e;
  --surface:#15151d;
  --surface-2:#1c1c26;
  --surface-hover:#24242f;
  --border:#2a2a36;
  --border-soft:#23232e;
  --text:#edeef2;
  --text-dim:#9698ab;
  --text-faint:#5b5d6e;
  --accent-a:#f5a623;
  --accent-a-soft:rgba(245,166,35,0.14);
  --accent-b:#36c5d6;
  --accent-b-soft:rgba(54,197,214,0.14);
  --accent-mix:#a78bfa;
  --accent-mix-soft:rgba(167,139,250,0.14);
  --danger:#ef4d5f;
  --danger-soft:rgba(239,77,95,0.14);
  --success:#36d399;
  --success-soft:rgba(54,211,153,0.14);
  --radius:12px;
  --radius-sm:8px;
  --font-ui:'Inter', system-ui, sans-serif;
  --font-mono:'JetBrains Mono', 'SFMono-Regular', monospace;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body.app-root{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
}
button{ font-family:inherit; }
svg{ display:block; }

/* ================= Login ================= */
.login-screen{
  min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px;
  background:radial-gradient(circle at 50% 0%, #14141d 0%, #0a0a0e 65%);
}
.login-card{
  width:100%; max-width:380px; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:32px 28px; text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,0.4);
}
.login-mark{
  width:48px; height:48px; border-radius:50%; background:var(--accent-a-soft); color:var(--accent-a);
  display:flex; align-items:center; justify-content:center; margin:0 auto 16px;
}
.login-card h1{ font-size:1.4rem; margin:0 0 6px; letter-spacing:0.02em; font-weight:700; }
.login-sub{ color:var(--text-dim); font-size:0.875rem; margin:0 0 22px; }
.login-waveform{
  display:flex; gap:4px; align-items:flex-end; height:30px; justify-content:center; margin-bottom:18px;
}
.login-waveform span{
  width:4px; background:var(--accent-a); border-radius:2px; opacity:0.55; display:block;
  animation:wave 1.4s ease-in-out infinite;
}
@keyframes wave{ 0%,100%{ transform:scaleY(0.25); } 50%{ transform:scaleY(1); } }
.login-card form{ display:flex; flex-direction:column; gap:14px; text-align:left; }
.login-card label{ display:flex; flex-direction:column; gap:6px; font-size:0.8rem; color:var(--text-dim); }
.login-card input{
  background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:10px 12px; color:var(--text); font-size:0.95rem; font-family:var(--font-mono);
}
.login-card input:focus{ outline:none; border-color:var(--accent-a); }
.login-error{
  display:flex; align-items:center; gap:6px; color:var(--danger); font-size:0.8rem;
  background:var(--danger-soft); padding:8px 10px; border-radius:var(--radius-sm);
}
.login-submit{
  margin-top:6px; background:var(--accent-a); color:#1a1306; border:none;
  border-radius:var(--radius-sm); padding:11px; font-weight:700; font-size:0.9rem;
  cursor:pointer; transition:filter 0.15s; font-family:inherit;
}
.login-submit:hover{ filter:brightness(1.08); }
.login-submit:disabled{ opacity:0.6; cursor:default; }
.login-guest-btn{
  background:transparent; border:1px solid var(--border); color:var(--text-dim);
  border-radius:var(--radius-sm); padding:10px; font-size:0.82rem; cursor:pointer;
  transition:all 0.15s; font-family:inherit;
}
.login-guest-btn:hover{ color:var(--text); border-color:var(--text-faint); background:var(--surface-2); }

/* ================= Shell ================= */
.app-shell{
  max-width:1280px; margin:0 auto; padding:16px;
  display:flex; flex-direction:column; gap:16px; min-height:100vh;
}
.app-header{
  display:flex; align-items:center; justify-content:space-between; padding:4px 4px 0;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:700; font-size:1.05rem; letter-spacing:0.02em;
}
.brand svg{ color:var(--accent-a); }
.header-actions{ display:flex; gap:10px; align-items:center; }
.badge{
  background:var(--danger); color:#fff; font-size:0.7rem; font-weight:700;
  border-radius:999px; padding:1px 6px; margin-left:6px; min-width:16px;
  text-align:center; display:inline-block;
}

/* ================= Layout ================= */
.layout{ display:grid; grid-template-columns:1fr 320px; gap:16px; align-items:start; }
@media(max-width:880px){ .layout{ grid-template-columns:1fr; } }

/* ================= Generic buttons ================= */
.icon-btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:var(--radius-sm);
  background:var(--surface-2); border:1px solid var(--border);
  color:var(--text-dim); cursor:pointer; transition:all 0.15s; flex-shrink:0;
}
.icon-btn:hover{ color:var(--text); background:var(--surface-hover); }
.icon-btn-danger:hover{ color:var(--danger); border-color:var(--danger-soft); }
.ghost-btn{
  display:inline-flex; align-items:center; gap:6px; background:transparent;
  border:1px solid var(--border); color:var(--text-dim); border-radius:var(--radius-sm);
  padding:7px 12px; font-size:0.8rem; cursor:pointer; transition:all 0.15s; white-space:nowrap;
}
.ghost-btn:hover{ color:var(--text); border-color:var(--text-faint); background:var(--surface-2); }
.primary-btn{
  display:inline-flex; align-items:center; gap:6px; background:var(--accent-a);
  color:#1a1306; border:none; border-radius:var(--radius-sm); padding:8px 14px;
  font-size:0.8rem; font-weight:700; cursor:pointer; transition:filter 0.15s; white-space:nowrap;
}
.primary-btn:hover{ filter:brightness(1.08); }
.primary-btn:disabled{ background:var(--surface-2); color:var(--text-faint); cursor:not-allowed; filter:none; }
.today-btn{
  background:var(--surface-2); border:1px solid var(--border); color:var(--text-dim);
  border-radius:var(--radius-sm); padding:7px 12px; font-size:0.8rem; cursor:pointer;
  font-family:inherit;
}
.today-btn:hover{ color:var(--text); }

/* ================= Calendar ================= */
.calendar-panel{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:16px;
}
.cal-header{
  display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.cal-header h2{
  flex:1; text-align:center; font-size:1.05rem; font-weight:700; margin:0; letter-spacing:0.02em;
}
.cal-weekdays{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:6px; }
.cal-weekdays div{
  text-align:center; font-size:0.68rem; color:var(--text-faint);
  text-transform:uppercase; letter-spacing:0.08em; padding-bottom:4px;
}
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-cell{
  background:var(--surface-2); border:1px solid var(--border-soft); border-radius:var(--radius-sm);
  min-height:90px; padding:6px; display:flex; flex-direction:column; gap:4px;
  text-align:left; cursor:pointer; color:var(--text);
  transition:border-color 0.15s, background 0.15s; width:100%;
}
.cal-cell:hover{ border-color:var(--text-faint); background:var(--surface-hover); }
.cal-cell-muted{ opacity:0.38; pointer-events:none; }
.cal-cell-today{ border-color:var(--accent-a); box-shadow:inset 0 0 0 1px var(--accent-a); }
.cal-cell-past{ opacity:0.5; }
.cal-date-row{ display:flex; align-items:center; justify-content:space-between; }
.cal-date-num{ font-size:0.8rem; font-weight:700; font-family:var(--font-mono); }
.today-dot{
  width:7px; height:7px; border-radius:50%; background:var(--accent-a);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(245,166,35,0.55); }
  50%{ box-shadow:0 0 0 4px rgba(245,166,35,0); }
}
.cal-bookings{ display:flex; flex-direction:column; gap:3px; overflow:hidden; }
.cal-pill{
  display:flex; align-items:center; gap:4px; background:var(--pill-soft);
  border-left:2px solid var(--pill-color); border-radius:4px;
  padding:2px 5px; font-size:0.64rem; line-height:1.3; overflow:hidden; white-space:nowrap;
}
.cal-pill-room{ font-weight:800; color:var(--pill-color); font-family:var(--font-mono); }
.cal-pill-text{ color:var(--text-dim); overflow:hidden; text-overflow:ellipsis; }
.cal-more{ font-size:0.6rem; color:var(--text-faint); padding-left:4px; }
@media(max-width:620px){
  .cal-cell{ min-height:60px; }
  .cal-pill-text{ display:none; }
  .cal-pill{ justify-content:center; }
  .cal-weekdays div{ font-size:0.6rem; }
}

/* ================= Day drawer ================= */
.drawer-backdrop{
  position:fixed; inset:0; background:rgba(5,5,8,0.6);
  display:flex; justify-content:flex-end; z-index:60; backdrop-filter:blur(2px);
}
.drawer{
  width:min(480px,100%); background:var(--surface); border-left:1px solid var(--border);
  height:100%; overflow-y:auto; display:flex; flex-direction:column;
}
.drawer-header{
  display:flex; align-items:flex-start; justify-content:space-between; padding:18px 20px;
  border-bottom:1px solid var(--border-soft); position:sticky; top:0; background:var(--surface); z-index:1;
}
.drawer-date-label{ font-size:1.05rem; font-weight:700; }
.today-tag{
  display:inline-block; margin-top:6px; font-size:0.7rem; color:var(--accent-a);
  background:var(--accent-a-soft); padding:2px 8px; border-radius:999px; font-weight:600;
}
.drawer-body{ padding:16px 20px 32px; display:flex; flex-direction:column; gap:24px; }
.room-section-header{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:10px; gap:8px; flex-wrap:wrap;
}
.room-badge{
  font-size:0.75rem; font-weight:800; padding:4px 11px; border-radius:999px; letter-spacing:0.02em;
}
.empty-note{ color:var(--text-faint); font-size:0.8rem; padding:8px 0 14px; }

/* ================= Booking card ================= */
.booking-card{
  background:var(--surface-2); border:1px solid var(--border-soft); border-radius:var(--radius-sm);
  padding:12px; display:flex; flex-direction:column; gap:9px; margin-bottom:10px;
}
.booking-top{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.booking-time{
  display:flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:0.85rem; font-weight:600;
}
.booking-actions{ display:flex; gap:6px; }
.booking-main{
  display:flex; flex-wrap:wrap; gap:10px 14px; align-items:center;
  font-size:0.8rem; color:var(--text-dim);
}
.session-type-tag{
  background:var(--surface-hover); border:1px solid var(--border); padding:2px 9px;
  border-radius:999px; font-size:0.68rem; text-transform:uppercase;
  letter-spacing:0.06em; color:var(--text); font-weight:600;
}
.booking-client, .booking-rate{ display:flex; align-items:center; gap:5px; }

/* ================= Debrief ================= */
.debrief-toggle{
  display:flex; align-items:center; gap:6px; background:none; border:none;
  color:var(--text-dim); font-size:0.78rem; cursor:pointer; padding:4px 0;
}
.debrief-toggle:hover{ color:var(--text); }
.ok-icon{ color:var(--success); }
.warn-icon{ color:var(--accent-a); }
.debrief-form{
  display:flex; flex-direction:column; gap:10px; background:var(--surface);
  border:1px solid var(--border-soft); border-radius:var(--radius-sm); padding:12px; margin-top:4px;
}
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media(max-width:480px){ .field-row{ grid-template-columns:1fr; } }
.field-row label, .field-full{
  display:flex; flex-direction:column; gap:5px; font-size:0.72rem; color:var(--text-dim);
}
.debrief-form input, .debrief-form textarea,
.form-grid input, .form-grid select, .form-grid textarea{
  background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:8px 10px; color:var(--text); font-size:0.85rem; font-family:inherit; resize:vertical; width:100%;
}
.debrief-form input:focus, .debrief-form textarea:focus,
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus{
  outline:none; border-color:var(--accent-a);
}
.form-error{
  color:var(--danger); font-size:0.78rem;
  background:var(--danger-soft); padding:8px 10px; border-radius:var(--radius-sm);
}
.debrief-form-actions{ display:flex; justify-content:flex-end; gap:8px; }
.booking-invoice-row{ display:flex; justify-content:flex-end; align-items:center; gap:8px; flex-wrap:wrap; }
.invoice-status-inline{ font-size:0.65rem; }

/* ================= Modals ================= */
.modal-backdrop{
  position:fixed; inset:0; background:rgba(5,5,8,0.65); display:flex;
  align-items:center; justify-content:center; z-index:70; padding:16px; backdrop-filter:blur(2px);
}
.modal{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  max-width:520px; width:100%; max-height:90vh; overflow-y:auto; padding:20px;
}
.modal h3{ margin:0 0 16px; font-size:1.05rem; }
.form-grid{ display:flex; flex-direction:column; gap:12px; }
.form-grid label{ display:flex; flex-direction:column; gap:5px; font-size:0.75rem; color:var(--text-dim); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media(max-width:480px){ .form-row{ grid-template-columns:1fr; } }
.room-toggle{ display:flex; gap:8px; }
.room-toggle-btn{
  flex:1; padding:10px; border-radius:var(--radius-sm); border:1px solid var(--border);
  background:var(--surface-2); color:var(--text-dim); cursor:pointer;
  font-weight:700; font-size:0.85rem; transition:all 0.15s; font-family:inherit;
}
.room-toggle-btn.active-a{ border-color:var(--accent-a); color:var(--accent-a); background:var(--accent-a-soft); }
.room-toggle-btn.active-b{ border-color:var(--accent-b); color:var(--accent-b); background:var(--accent-b-soft); }
.modal-actions{ display:flex; justify-content:flex-end; gap:8px; margin-top:6px; }

/* ================= Invoice modal / printable invoice ================= */
.invoice-modal{ max-width:640px; }
.modal-header{
  display:flex; align-items:center; justify-content:space-between; margin-bottom:16px;
  flex-wrap:wrap; gap:10px;
}
.modal-header-actions{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.invoice-print-area{ background:#fff; color:#1a1a1f; border-radius:8px; padding:28px; }
.invoice-doc-header{
  display:flex; justify-content:space-between; gap:20px;
  border-bottom:2px solid #1a1a1f; padding-bottom:16px; margin-bottom:16px; flex-wrap:wrap;
}
.invoice-from-name{ font-weight:800; font-size:1.05rem; }
.invoice-from-line{ font-size:0.82rem; color:#555; }
.invoice-meta{ text-align:right; }
.invoice-title{ font-size:1.4rem; font-weight:800; letter-spacing:0.1em; margin-bottom:8px; }
.invoice-meta-row{
  display:flex; justify-content:flex-end; gap:14px;
  font-size:0.8rem; color:#444; font-family:var(--font-mono);
}
.invoice-meta-row span:first-child{ color:#888; }
.invoice-status-line{ margin-top:8px; }
.invoice-bill-to{ margin-bottom:16px; }
.invoice-section-label{
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.1em; color:#888; margin-bottom:4px;
}
.invoice-table{ width:100%; border-collapse:collapse; margin-bottom:20px; font-size:0.85rem; }
.invoice-table th{
  text-align:left; border-bottom:2px solid #1a1a1f; padding:8px 4px;
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.08em; color:#666;
}
.invoice-table td{ padding:10px 4px; border-bottom:1px solid #ddd; vertical-align:top; }
.invoice-table th:not(:first-child),
.invoice-table td:not(:first-child){ text-align:right; white-space:nowrap; }
.invoice-songs-label{ font-size:0.72rem; color:#888; margin-top:6px; }
.invoice-songs{ margin:4px 0 0; padding-left:18px; font-size:0.82rem; }
.invoice-table tfoot td{
  border-bottom:none; border-top:2px solid #1a1a1f;
  font-weight:800; padding-top:12px; font-size:0.95rem;
}
.invoice-footer{ font-size:0.82rem; color:#444; line-height:1.7; }
.invoice-thanks{ margin-top:8px; font-weight:700; color:#1a1a1f; }
.invoice-print-area .status-unpaid{ background:#fde2e4; color:#c0273c; }
.invoice-print-area .status-overdue{ background:#c0273c; color:#fff; }
.invoice-print-area .status-paid{ background:#d6f5e8; color:#1f9d6f; }

/* ================= Status tags ================= */
.status-tag{
  font-size:0.64rem; font-weight:800; text-transform:uppercase;
  letter-spacing:0.06em; padding:3px 9px; border-radius:999px; display:inline-block;
}
.status-unpaid{ background:var(--danger-soft); color:var(--danger); }
.status-overdue{ background:var(--danger); color:#fff; }
.status-paid{ background:var(--success-soft); color:var(--success); }

/* ================= Invoice sidebar ================= */
.invoice-sidebar{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:16px; display:flex; flex-direction:column; gap:12px;
}
.sidebar-header{ display:flex; align-items:center; justify-content:space-between; }
.sidebar-header h3{ margin:0; font-size:0.95rem; }
.sidebar-list{ display:flex; flex-direction:column; gap:8px; }
.invoice-row{
  display:flex; flex-direction:column; gap:5px; background:var(--surface-2);
  border:1px solid var(--border-soft); border-radius:var(--radius-sm);
  padding:10px 12px; text-align:left; cursor:pointer; color:var(--text);
  transition:all 0.15s; width:100%;
}
.invoice-row:hover{ border-color:var(--text-faint); background:var(--surface-hover); }
.invoice-row-main{
  display:flex; justify-content:space-between; align-items:center;
  gap:8px; font-size:0.85rem; font-weight:700;
}
.invoice-amount{ font-family:var(--font-mono); color:var(--accent-a); }
.invoice-row-sub{
  display:flex; justify-content:space-between; align-items:center;
  font-size:0.72rem; color:var(--text-dim);
}
.sidebar-paid-toggle{
  border-top:1px solid var(--border-soft); padding-top:10px;
  display:flex; flex-direction:column; gap:8px;
}
.sidebar-backdrop{ position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:45; }
@media(min-width:881px){ .sidebar-backdrop{ display:none !important; } }

/* ================= Responsive helpers ================= */
.mobile-only{ display:none; }
@media(max-width:880px){
  .mobile-only{ display:inline-flex; }
  .invoice-sidebar{
    position:fixed; top:0; right:0; bottom:0; width:min(360px,90vw); border-radius:0;
    transform:translateX(100%); transition:transform 0.25s ease; z-index:50;
    box-shadow:-10px 0 30px rgba(0,0,0,0.5); overflow-y:auto;
  }
  .invoice-sidebar.mobile-open{ transform:translateX(0); }
}

/* ================= Print ================= */
@media print{
  body *{ visibility:hidden; }
  .invoice-print-area, .invoice-print-area *{ visibility:visible; }
  .invoice-print-area{ position:absolute; left:0; top:0; width:100%; margin:0; }
  .no-print{ display:none !important; }
}

/* ================= Tab navigation ================= */
.app-nav{
  display:flex; gap:6px; padding:0 4px;
  border-bottom:1px solid var(--border); margin-bottom:4px; flex-wrap:wrap;
}
.nav-tab{
  display:inline-flex; align-items:center; gap:7px; padding:9px 14px;
  background:transparent; border:none; border-bottom:2px solid transparent;
  color:var(--text-dim); font-size:0.82rem; font-weight:600; cursor:pointer;
  transition:all 0.15s; margin-bottom:-1px; white-space:nowrap; font-family:inherit;
}
.nav-tab:hover{ color:var(--text); }
.nav-tab-active{ color:var(--accent-a); border-bottom-color:var(--accent-a); }

/* ================= Main content area (non-calendar tabs) ================= */
.main-content-area{ width:100%; }
.tab-content{ display:flex; flex-direction:column; gap:20px; }
.tab-content-header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.tab-content-header h2{ display:flex; align-items:center; gap:10px; font-size:1.1rem; margin:0; }

/* ================= Mix & Master tab ================= */
.mix-section{ display:flex; flex-direction:column; gap:12px; }
.mix-section-title{
  font-size:0.82rem; text-transform:uppercase; letter-spacing:0.08em;
  color:var(--text-faint); margin:0; padding-bottom:8px; border-bottom:1px solid var(--border-soft);
}
.mix-job-list{ display:flex; flex-direction:column; gap:12px; }
.mix-job-card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:14px 16px; display:flex; flex-direction:column; gap:12px;
}
.mix-job-header{
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.mix-job-billing{ font-weight:700; font-size:0.95rem; }
.mix-job-artist{
  font-size:0.78rem; color:var(--text-dim); margin-top:3px;
  display:flex; align-items:center; gap:5px;
}
.mix-job-actions{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.mix-job-total{ font-family:var(--font-mono); font-size:1rem; font-weight:700; color:var(--accent-mix); }
.mix-lines-table{ width:100%; border-collapse:collapse; font-size:0.78rem; }
.mix-lines-table th{
  text-align:left; color:var(--text-faint); font-size:0.65rem;
  text-transform:uppercase; letter-spacing:0.06em; padding:4px 6px;
  border-bottom:1px solid var(--border-soft);
}
.mix-lines-table td{
  padding:6px 6px; border-bottom:1px solid var(--border-soft);
  color:var(--text-dim); vertical-align:top;
}
.mix-lines-table tr:last-child td{ border-bottom:none; }
.mix-drive-info{
  font-size:0.75rem; color:var(--text-faint); display:flex; align-items:center; gap:5px;
}

/* Mix modal */
.mix-modal{ max-width:680px; }
.mix-line-row{
  background:var(--surface-2); border:1px solid var(--border-soft);
  border-radius:var(--radius-sm); padding:10px; margin-bottom:8px;
}
.mix-line-fields{
  display:grid; grid-template-columns:1fr 1fr 1.5fr 0.6fr 0.6fr auto;
  gap:8px; align-items:start;
}
.mix-line-fields label{
  display:flex; flex-direction:column; gap:4px; font-size:0.7rem; color:var(--text-dim);
}
.mix-line-fields input{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:7px 9px; color:var(--text); font-size:0.82rem; font-family:inherit; width:100%;
}
.mix-line-fields input:focus{ outline:none; border-color:var(--accent-mix); }
@media(max-width:680px){ .mix-line-fields{ grid-template-columns:1fr 1fr; } }

/* ================= Tax tab ================= */
.tax-disclaimer{
  background:var(--surface-2); border:1px solid var(--border);
  border-left:3px solid var(--accent-a); border-radius:var(--radius-sm); padding:12px 16px;
}
.tax-rate-row{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  font-size:0.85rem; font-weight:600;
}
.tax-rate-input-wrap{ display:flex; align-items:center; gap:6px; }
.tax-rate-input{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:6px 10px; color:var(--text); font-size:0.9rem; font-family:var(--font-mono);
  width:70px; text-align:right;
}
.tax-rate-input:focus{ outline:none; border-color:var(--accent-a); }
.tax-year-nav{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.tax-year-display{
  font-size:1.2rem; font-weight:800; font-family:var(--font-mono);
  min-width:60px; text-align:center;
}
.tax-quarterly-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
@media(max-width:700px){ .tax-quarterly-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:440px){ .tax-quarterly-grid{ grid-template-columns:1fr; } }
.tax-quarter-card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:14px; display:flex; flex-direction:column; gap:6px;
}
.tax-q-label{ font-weight:800; font-size:1rem; font-family:var(--font-mono); }
.tax-q-months{ font-size:0.72rem; color:var(--text-faint); font-family:var(--font-ui); font-weight:400; }
.tax-q-income{ font-size:0.8rem; color:var(--text-dim); }
.tax-q-owed{ font-size:0.85rem; }
.tax-highlight{ color:var(--accent-a); }
.tax-q-due{ font-size:0.72rem; color:var(--text-faint); margin-top:4px; }
.tax-year-summary{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:16px; display:flex; flex-direction:column; gap:10px;
}
.tax-summary-row{
  display:flex; justify-content:space-between; align-items:center; font-size:0.9rem;
}
.tax-all-years{ display:flex; flex-direction:column; gap:8px; }
.tax-year-row{
  display:flex; align-items:center; gap:16px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:10px 14px; font-size:0.85rem; flex-wrap:wrap;
}
.tax-year-label{ font-weight:800; font-family:var(--font-mono); min-width:50px; }
.tax-links{ display:flex; flex-direction:column; gap:8px; padding-top:4px; }
.tax-links h3{
  font-size:0.82rem; color:var(--text-faint); text-transform:uppercase;
  letter-spacing:0.08em; margin:0 0 4px;
}
.tax-link-btn{
  display:inline-flex; align-items:center; gap:7px; padding:9px 14px;
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm);
  color:var(--text-dim); font-size:0.82rem; text-decoration:none;
  transition:all 0.15s; cursor:pointer; width:fit-content;
}
.tax-link-btn:hover{ color:var(--text); border-color:var(--text-faint); background:var(--surface-2); }

/* ================= History tab ================= */
.history-controls{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.history-search-wrap{
  display:flex; align-items:center; gap:8px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:8px 12px; flex:1; min-width:200px; color:var(--text-faint);
}
.history-search{
  background:transparent; border:none; color:var(--text);
  font-family:inherit; font-size:0.85rem; flex:1; outline:none;
}
.history-search::placeholder{ color:var(--text-faint); }
.history-sort-select{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:8px 12px; color:var(--text); font-family:inherit; font-size:0.82rem; cursor:pointer;
}
.history-list{ display:flex; flex-direction:column; gap:10px; }
.history-row{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:12px 16px;
  display:flex; flex-direction:column; gap:6px;
}
.history-row-header{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.history-date{
  font-family:var(--font-mono); font-size:0.78rem; color:var(--text-faint); min-width:90px;
}
.history-client{ display:flex; align-items:center; gap:5px; font-size:0.82rem; color:var(--text-dim); }
.history-amount{ font-family:var(--font-mono); font-size:0.85rem; color:var(--accent-a); margin-left:auto; }
.history-songs{ display:flex; align-items:center; gap:6px; font-size:0.78rem; color:var(--text-dim); }
.history-drives{
  display:flex; align-items:center; gap:6px;
  font-size:0.72rem; color:var(--text-faint); font-family:var(--font-mono);
}
.history-notes{
  font-size:0.78rem; color:var(--text-faint); line-height:1.5;
  border-top:1px solid var(--border-soft); padding-top:6px; margin-top:2px;
}

/* ================= Requests tab ================= */
.request-note{
  font-size:0.82rem; color:var(--text-dim); background:var(--surface-2);
  border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px 14px;
  line-height:1.6;
}

/* ================= Receipt modal ================= */
.receipt-modal{ max-width:560px; }
.receipt-note{ font-size:0.75rem; color:var(--text-faint); text-align:center; margin-top:4px; }

/* ================= Guest shell ================= */
.guest-shell{
  max-width:1100px; margin:0 auto; padding:16px;
  display:flex; flex-direction:column; gap:16px; min-height:100vh;
}
.guest-header{
  display:flex; align-items:center; justify-content:space-between; padding:4px 4px 0;
}
.guest-body{ display:flex; flex-direction:column; gap:0; }
.guest-calendar-panel{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px;
}
.guest-cal-intro{ margin-bottom:24px; }
.guest-cal-intro h2{ font-size:1.2rem; margin:0 0 6px; }
.guest-cal-intro p{ font-size:0.85rem; color:var(--text-dim); margin:0 0 14px; }
.avail-legend{ display:flex; gap:8px; flex-wrap:wrap; }

/* Availability labels on calendar cells */
.avail-label{
  font-size:0.58rem; font-weight:700; text-transform:uppercase;
  letter-spacing:0.06em; padding:2px 6px; border-radius:4px; display:inline-block;
}
.avail-open{    background:rgba(54,211,153,0.18); color:var(--success); }
.avail-partial{ background:rgba(245,166,35,0.18); color:var(--accent-a); }
.avail-closed{  background:rgba(239,77,95,0.18);  color:var(--danger);  }
.avail-muted{   background:transparent; color:var(--text-faint); display:none; }

/* Guest calendar cell */
.guest-cal-cell{ cursor:pointer; }
.guest-cal-cell.cal-cell-muted{ pointer-events:none; }
.guest-cal-cell.cal-cell-past{ opacity:0.45; pointer-events:none; }

/* Room A/B dots on guest calendar */
.guest-room-dots{
  display:flex; gap:3px; margin-top:2px; flex-wrap:wrap;
}
.guest-room-dot{
  font-size:0.6rem; font-weight:800; font-family:var(--font-mono);
  padding:1px 5px; border-radius:4px; display:inline-flex; align-items:center;
}
.guest-room-open{  background:rgba(54,211,153,0.18); color:var(--success); }
.guest-room-closed{ background:rgba(239,77,95,0.18);  color:var(--danger);  }

/* Guest day modal */
.guest-day-modal{ max-width:500px; }
.guest-room-section{ margin-bottom:16px; }
.guest-room-header{
  font-weight:800; font-size:0.85rem; text-transform:uppercase;
  letter-spacing:0.08em; margin-bottom:8px;
}
.guest-slot{
  display:flex; align-items:center; gap:8px; font-size:0.82rem;
  padding:7px 10px; border-radius:var(--radius-sm); margin-bottom:4px;
}
.guest-slot-open{   background:rgba(54,211,153,0.1);  color:var(--success); border:1px solid rgba(54,211,153,0.2); }
.guest-slot-blocked{ background:rgba(239,77,95,0.08); color:var(--danger);  border:1px solid rgba(239,77,95,0.15); }