/* LaneBooker Admin Demo — vendored styles inspired by apps/admin/style.css */
:root {
  --bg: #f4f6f9;
  --surface: #ffffff;
  --border: #e2e6ed;
  --text: #1a1d23;
  --text-muted: #6b7280;
  --primary: #7C3AED;
  --primary-hover: #6d28d9;
  --success: #16a34a;
  --success-light: #dcfce7;
  --danger: #dc2626;
  --danger-light: #fee2e2;
  --available: #22c55e;
  --online: #3b82f6;
  --staff: #f59e0b;
  --blocked: #ef4444;
  --rocknbowl: #a855f7;
  --radius: 8px;
  --radius-lg: 12px;
  --shadow: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 25px rgba(0,0,0,0.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* DEMO BANNER */
.demo-banner{background:linear-gradient(90deg,#7C3AED,#a855f7);color:#fff;text-align:center;padding:.6rem 1rem;font-size:.85rem;font-weight:500;position:sticky;top:0;z-index:200}
.demo-banner a{color:#fff;font-weight:700;margin-left:.5rem;text-decoration:underline}
.demo-banner-emoji{margin-right:.25rem}

/* TOP BAR */
.top-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:38px;z-index:100;box-shadow:var(--shadow)}
.top-bar-left{display:flex;align-items:center;gap:1.25rem}
.logo{display:flex;align-items:center;gap:.5rem}
.logo-icon{font-size:1.75rem}
.logo h1{font-size:1.35rem;font-weight:800;letter-spacing:-.5px;display:flex;gap:.5rem;align-items:center}
.demo-tag{background:var(--primary);color:#fff;font-size:.65rem;padding:.2rem .5rem;border-radius:4px;letter-spacing:1px;font-weight:700}
.brand-sep{color:var(--border);font-weight:400;font-size:1.25rem;margin:0 .25rem}
.tenant-name{font-size:1rem;font-weight:600;color:var(--text-muted)}
.top-bar-center{display:flex;gap:.25rem}
.tab-btn{background:transparent;border:none;padding:.55rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:all .15s}
.tab-btn:hover{background:var(--bg);color:var(--text)}
.tab-btn.active{background:var(--primary);color:#fff}
.top-bar-right{display:flex;gap:.5rem;align-items:center}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1rem;border:none;border-radius:var(--radius);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover)}
.btn-outline{background:var(--surface);color:var(--text);border:1px solid var(--border)}
.btn-outline:hover{background:var(--bg)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}

/* TAB PANELS */
.tab-panel{display:none}
.tab-panel.active{display:block}

/* SCHEDULE LAYOUT */
.app-layout{display:flex;height:calc(100vh - 56px - 38px - 56px);overflow:hidden}
.summary-sidebar{width:280px;min-width:280px;background:var(--surface);border-right:1px solid var(--border);padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}
.summary-date{font-size:1.1rem;font-weight:700;color:var(--primary)}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.summary-card{background:var(--bg);border-radius:var(--radius);padding:.75rem;text-align:center}
.summary-value{font-size:1.4rem;font-weight:800}
.summary-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.15rem}
.upcoming-section h3,.legend-section h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.5rem}
.upcoming-list{display:flex;flex-direction:column;gap:.5rem}
.upcoming-item{background:var(--bg);border-radius:var(--radius);padding:.6rem .75rem;display:flex;justify-content:space-between;font-size:.8rem}
.upcoming-item .up-name{font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upcoming-item .up-time{color:var(--text-muted);font-size:.75rem}
.legend-grid{display:flex;flex-direction:column;gap:.35rem}
.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted)}
.legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.legend-dot.available{background:var(--available)}
.legend-dot.online{background:var(--online)}
.legend-dot.staff{background:var(--staff)}
.legend-dot.blocked{background:var(--blocked)}
.legend-dot.rocknbowl{background:var(--rocknbowl)}

.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}
.date-nav{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border)}
.date-input{font-family:inherit;font-size:.95rem;font-weight:600;padding:.45rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer}

.schedule-wrapper{flex:1;overflow:auto;padding:1rem 1rem 2rem}
.schedule-grid{display:grid;grid-template-columns:140px repeat(14,minmax(74px,1fr));gap:0;min-width:1300px}
.grid-section-label{grid-column:1 / -1;background:#f3f4f6;border:1px solid var(--border);border-left:3px solid var(--primary);padding:.45rem .85rem;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);position:sticky;left:0}
.lane-type-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.65rem;font-weight:800;color:#fff;margin-right:.4rem;flex-shrink:0}
.lane-type-badge.five{background:#22c55e}
.lane-type-badge.ten{background:#3b82f6}
.lane-type-badge.laser{background:#a855f7}
.lane-type-badge.golf{background:#f97316}
.grid-lane-label{justify-content:flex-start !important;gap:.25rem;padding:.5rem .6rem !important}
.grid-header{background:var(--surface);border:1px solid var(--border);padding:.5rem .4rem;font-size:.7rem;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);position:sticky;top:0;z-index:10}
.grid-header.corner{background:var(--bg);border-color:transparent}
.grid-lane-label{background:var(--surface);border:1px solid var(--border);padding:.5rem .4rem;font-size:.78rem;font-weight:600;display:flex;align-items:center;justify-content:center;text-align:center;position:sticky;left:0;z-index:5}
.grid-cell{border:1px solid var(--border);min-height:42px;background:var(--surface);cursor:pointer;transition:background .15s;position:relative;font-size:.7rem;padding:.2rem}
.grid-cell:hover{background:var(--bg)}
.grid-cell.booked{cursor:pointer;color:#fff;font-weight:600;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;line-height:1.2}
.grid-cell.booked.online{background:var(--online)}
.grid-cell.booked.staff{background:var(--staff)}
.grid-cell.booked.blocked{background:var(--blocked)}
.grid-cell.booked.rocknbowl{background:var(--rocknbowl)}
.grid-cell.booked.cancelled{background:#9ca3af;opacity:.6;text-decoration:line-through}
.grid-cell.booked .cell-name{font-size:.7rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}
.grid-cell.booked .cell-meta{font-size:.65rem;opacity:.9}

/* REPORTS */
.reports-header{padding:1.5rem 2rem 1rem}
.reports-header h2{font-size:1.5rem;font-weight:800;margin-bottom:.25rem}
.reports-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}
.range-tabs{display:flex;gap:.25rem;margin-top:.75rem}
.range-btn,.setup-subtab{background:var(--surface);border:1px solid var(--border);padding:.45rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:var(--radius)}
.range-btn.active,.setup-subtab.active{background:var(--primary);color:#fff;border-color:var(--primary)}

.report-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:0 2rem 1rem}
.rpt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow)}
.rpt-card.highlight-green{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}
.rpt-card-value{font-size:1.75rem;font-weight:800;color:var(--text)}
.rpt-card-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}
.rpt-card-change{font-size:.75rem;font-weight:600;margin-top:.4rem}
.rpt-card-change.positive{color:var(--success)}
.rpt-card-change.neutral{color:var(--text-muted)}
.rpt-card-change.negative{color:var(--danger)}

.report-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:0 2rem 1rem}
@media(max-width:900px){.report-row{grid-template-columns:1fr}.app-layout{flex-direction:column;height:auto}.summary-sidebar{width:100%;min-width:0}}
.report-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow)}
.report-panel.report-full{margin:0 2rem 1rem}
.report-panel-title{font-size:1rem;font-weight:700;margin-bottom:1rem}

.vbar-chart{display:flex;align-items:flex-end;justify-content:space-around;gap:.5rem;height:180px;padding:.5rem 0}
.vbar-col{display:flex;flex-direction:column;align-items:center;gap:.4rem;flex:1}
.vbar-bar-wrapper{height:140px;width:100%;display:flex;align-items:flex-end;justify-content:center}
.vbar-bar{width:60%;background:linear-gradient(180deg,var(--primary),#a855f7);border-radius:4px 4px 0 0;position:relative;min-height:4px;transition:height .3s}
.vbar-bar::after{content:attr(data-val);position:absolute;top:-1.2rem;left:50%;transform:translateX(-50%);font-size:.7rem;font-weight:600;color:var(--text-muted);white-space:nowrap}
.vbar-label{font-size:.75rem;color:var(--text-muted);font-weight:600}

.hbar-chart{display:flex;flex-direction:column;gap:.6rem}
.hbar-row{display:grid;grid-template-columns:140px 1fr 60px;gap:.5rem;align-items:center;font-size:.8rem}
.hbar-label{color:var(--text-muted);font-weight:600;font-size:.78rem}
.hbar-track{height:18px;background:var(--bg);border-radius:4px;overflow:hidden}
.hbar-fill{height:100%;border-radius:4px;transition:width .3s}
.hbar-value{text-align:right;font-weight:700;font-size:.8rem}

.heatmap-wrapper{overflow-x:auto}
.heatmap-grid{display:grid;grid-template-columns:80px repeat(13,1fr);gap:2px;min-width:700px}
.heatmap-cell{aspect-ratio:1.4;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#fff;font-weight:600}
.heatmap-cell.label{background:transparent;color:var(--text-muted);font-size:.7rem;justify-content:flex-end;padding-right:.4rem}
.heatmap-cell.head{background:transparent;color:var(--text-muted);font-size:.65rem}

/* MONTH NAV */
.month-nav{display:flex;align-items:center;gap:1rem;margin-bottom:.25rem}
.month-nav h2{font-size:1.5rem;font-weight:800;margin:0}
.month-arrow{background:var(--surface);border:1px solid var(--border);width:32px;height:32px;border-radius:var(--radius);font-size:.85rem;font-weight:700;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.month-arrow:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* DONUT */
.donut-wrap{display:flex;align-items:center;justify-content:center;min-height:220px}
.donut-chart-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:center;width:100%}
.donut{width:170px;height:170px;border-radius:50%;position:relative;flex-shrink:0}
.donut-hole{position:absolute;inset:22%;background:var(--surface);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-total{font-size:1.05rem;font-weight:800;color:var(--text)}
.donut-total-lbl{font-size:.65rem;font-weight:700;color:var(--text-muted);letter-spacing:1px;margin-top:.1rem}
.donut-legend{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:180px}
.donut-legend-row{display:grid;grid-template-columns:14px 1fr auto auto;gap:.55rem;align-items:center;font-size:.85rem}
.donut-legend-row .legend-dot{width:12px;height:12px;border-radius:3px}
.donut-legend-label{font-weight:600;color:var(--text)}
.donut-legend-pct{color:var(--text-muted);font-weight:600;font-size:.78rem}
.donut-legend-val{font-weight:700;color:var(--text);font-size:.82rem}

/* STACKED WEEKLY */
.stacked-chart{display:flex;flex-direction:column;gap:.65rem;margin-top:.25rem}
.stacked-row{display:grid;grid-template-columns:90px 1fr 36px;gap:.6rem;align-items:center;font-size:.78rem}
.stacked-label{color:var(--text-muted);font-weight:600;font-size:.78rem}
.stacked-track{display:flex;height:22px;background:var(--bg);border-radius:4px;overflow:hidden}
.stacked-seg{display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;font-weight:700;transition:width .3s}
.stacked-total{text-align:right;font-weight:700;font-size:.8rem}
.stacked-legend{display:flex;gap:1rem;margin-top:.75rem;font-size:.78rem;color:var(--text-muted)}
.stacked-legend .legend-item{display:flex;align-items:center;gap:.4rem}

.chart-footnote{font-size:.72rem;color:var(--text-muted);margin-top:.75rem;font-style:italic;text-align:center}

/* SUPPORT */
.hours-tracker{display:flex;flex-direction:column;gap:1rem}
.hours-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.hours-stat{text-align:center;padding:.75rem;background:var(--bg);border-radius:var(--radius)}
.hours-stat-value{font-size:1.5rem;font-weight:800}
.hours-stat-value.used{color:var(--staff)}
.hours-stat-value.remaining{color:var(--success)}
.hours-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.2rem}
.hours-bar-track{height:14px;background:var(--bg);border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.hours-bar-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--staff));border-radius:8px}

.support-form{display:flex;flex-direction:column;gap:.75rem}
.form-group{display:flex;flex-direction:column;gap:.3rem}
.form-group label{font-size:.78rem;font-weight:600;color:var(--text-muted)}
.form-group input,.form-group textarea,.form-group select{font-family:inherit;font-size:.9rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}

.ticket-list{display:flex;flex-direction:column;gap:.6rem;max-height:500px;overflow-y:auto}
.ticket-item{background:var(--bg);border-radius:var(--radius);padding:.75rem 1rem}
.ticket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}
.ticket-num{font-size:.75rem;color:var(--text-muted);font-weight:700}
.ticket-status{font-size:.7rem;padding:.2rem .55rem;border-radius:99px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.ticket-status.completed{background:var(--success-light);color:var(--success)}
.ticket-status.in-progress{background:#fef3c7;color:#92400e}
.ticket-status.open{background:#dbeafe;color:#1e40af}
.ticket-subject{font-size:.9rem;font-weight:600}
.ticket-meta{font-size:.72rem;color:var(--text-muted);margin-top:.2rem}

/* CUSTOMERS */
.cust-toolbar{display:flex;gap:.75rem;padding:0 2rem 1rem;align-items:center}
.cust-search-input{flex:1;padding:.6rem .9rem;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:.9rem;background:var(--surface)}
.cust-filter-select{padding:.55rem .9rem;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:.9rem;background:var(--surface);font-weight:600}
.cust-table-wrapper{margin:0 2rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow-x:auto;box-shadow:var(--shadow)}
.cust-table{width:100%;border-collapse:collapse;font-size:.85rem}
.cust-table th{background:var(--bg);text-align:left;padding:.75rem 1rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:700;border-bottom:1px solid var(--border)}
.cust-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border)}
.cust-table tr.cust-row{cursor:pointer}
.cust-table tr.cust-row:hover{background:var(--bg)}
.cust-table tr.expanded-detail td{background:#f9fafb;padding:1rem}
.member-badge{background:var(--success-light);color:var(--success);font-size:.7rem;padding:.2rem .55rem;border-radius:99px;font-weight:700}

/* SETUP */
.setup-section{display:none}
.setup-section.active{display:block}
.setup-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:300;align-items:center;justify-content:center;display:none;padding:2rem}
.modal-overlay.show{display:flex}
.modal{background:var(--surface);border-radius:var(--radius-lg);max-width:820px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden}
.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.modal-header h2{font-size:1.15rem;font-weight:700}
.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);line-height:1}
.modal-body{padding:1.5rem;overflow-y:auto;flex:1}
.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}
.detail-row{display:grid;grid-template-columns:120px 1fr;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.9rem}
.detail-row:last-child{border-bottom:none}
.detail-row .lbl{font-weight:600;color:var(--text-muted)}
.demo-btn{position:relative}
.demo-btn::after{content:"Demo — read only";position:absolute;bottom:-2.2rem;left:50%;transform:translateX(-50%);background:var(--text);color:#fff;padding:.3rem .55rem;border-radius:4px;font-size:.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s}
.demo-btn:hover::after{opacity:1}

/* TOAST */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(120%);background:var(--text);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:400;transition:transform .3s}
.toast.show{transform:translateX(-50%) translateY(0)}

/* HEATMAP LEGEND */
.heatmap-legend-bar{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:.75rem;font-size:.72rem;color:var(--text-muted);font-weight:600}
.heatmap-gradient{width:120px;height:12px;border-radius:3px;background:linear-gradient(to right,#f0fdf4,#22c55e,#15803d)}

/* REPORTS TABLES */
.rpt-table{width:100%;border-collapse:collapse;font-size:.85rem}
.rpt-table th{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border);padding:.5rem .75rem;text-align:left}
.rpt-table td{padding:.55rem .75rem;border-bottom:1px solid var(--border);font-weight:500}
.rpt-table tbody tr:hover{background:var(--bg)}
.rpt-table td:last-child,.rpt-table th:last-child{text-align:right;font-variant-numeric:tabular-nums}
.rpt-table td:first-child{font-weight:700;color:var(--text-muted);width:30px}
.comparison-table td:first-child{font-weight:700;color:var(--text);width:auto}
.comparison-table td{font-variant-numeric:tabular-nums}
.change-positive{color:var(--success) !important;font-weight:700 !important}
.change-negative{color:var(--danger) !important;font-weight:700 !important}
.change-neutral{color:var(--text-muted) !important;font-weight:600 !important}

/* CALLOUTS */
.rpt-callout{border-radius:var(--radius);padding:.75rem 1rem;font-size:.82rem;line-height:1.5;margin-top:.75rem}
.rpt-callout.neutral{background:var(--bg);border-left:3px solid var(--border);color:var(--text-muted)}

/* ADD BOOKING MODAL FORM */
.modal-section{border:none;padding:0 0 1.25rem;margin:0 0 1rem;border-bottom:1px solid var(--border)}
.modal-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}
.modal-section legend{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:0;margin-bottom:.85rem;display:block;width:100%}
.form-row{display:grid;gap:.85rem;margin-bottom:.85rem}
.form-row:last-child{margin-bottom:0}
.form-row-2{grid-template-columns:1fr 1fr}
.form-row-3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:640px){.form-row-2,.form-row-3{grid-template-columns:1fr}}
.form-group label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.3rem}
.form-group input,.form-group select,.form-group textarea{width:100%;font-family:inherit;font-size:.9rem;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,0.12)}

/* Lane picker pills */
.lane-picker{display:flex;flex-wrap:wrap;gap:.4rem;padding:.45rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);min-height:42px;align-items:center}
.lane-picker-empty{font-size:.78rem;color:var(--text-muted);padding:.25rem .5rem}
.lane-pill{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.78rem;font-weight:600;padding:.4rem .75rem;border-radius:99px;cursor:pointer;transition:all .15s}
.lane-pill:hover{border-color:var(--primary);color:var(--primary)}
.lane-pill.selected{background:var(--primary);border-color:var(--primary);color:#fff}

/* Add-ons grid */
.addons-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .85rem}
@media(max-width:640px){.addons-grid{grid-template-columns:1fr}}
.addon-row{display:grid;grid-template-columns:auto 1fr 60px auto;gap:.5rem;align-items:center;padding:.5rem .65rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:.82rem;transition:border-color .15s}
.addon-row:hover{border-color:var(--primary)}
.addon-check{margin:0;width:16px;height:16px;cursor:pointer}
.addon-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.addon-qty{width:60px;font-family:inherit;font-size:.8rem;padding:.3rem .4rem;border:1px solid var(--border);border-radius:4px;background:var(--bg);text-align:center}
.addon-price{font-size:.78rem;font-weight:700;color:var(--text-muted);white-space:nowrap}

.packages-empty{font-size:.85rem;color:var(--text-muted);padding:.85rem;background:var(--bg);border-radius:var(--radius);text-align:center;font-style:italic}

/* Sticky footer for add-booking form */
.modal-footer{position:sticky;bottom:0;background:var(--surface)}

/* ============================================
   VENUE TAB
   ============================================ */
.venue-card{margin-bottom:1.25rem}
.venue-section-title{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.venue-save-btn{padding:.45rem 1rem;font-size:.85rem}
.venue-desc{font-size:.88rem;color:var(--text-muted);margin:0 0 1rem}
.venue-grid{display:grid;gap:1rem;margin-bottom:1rem}
.venue-grid-3{grid-template-columns:repeat(3,1fr)}
.venue-grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:760px){.venue-grid-3,.venue-grid-2{grid-template-columns:1fr}}
.venue-field{display:flex;flex-direction:column;gap:.35rem}
.venue-label{font-size:.7rem;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase}
.venue-input{width:100%;padding:.55rem .7rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-family:inherit;background:var(--surface);color:var(--text)}
.venue-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.15)}
.venue-help{font-size:.75rem;color:var(--text-muted);margin-top:.2rem;line-height:1.4}
.venue-divider{height:1px;background:var(--border);margin:1rem 0}
.venue-prefs-label{font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:.6rem}
.venue-check{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text);padding:.3rem 0;cursor:pointer}
.venue-check input{width:16px;height:16px;accent-color:#7c3aed;cursor:pointer}

/* Theme swatches */
.theme-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:.75rem}
@media(max-width:900px){.theme-swatches{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.theme-swatches{grid-template-columns:repeat(2,1fr)}}
.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:.55rem;padding:.85rem .5rem;border:2px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;transition:all .15s ease}
.theme-swatch:hover{border-color:#a78bfa}
.theme-swatch.selected{border-color:#7c3aed;box-shadow:0 0 0 3px rgba(124,58,237,.18)}
.theme-dot{width:34px;height:34px;border-radius:50%;border:2px solid rgba(0,0,0,.06)}
.theme-dot.dark{border-color:rgba(255,255,255,.15)}
.theme-name{font-size:.78rem;font-weight:600;color:var(--text);text-align:center}

/* Venue logo + header preview */
.venue-logo-field{margin-top:.5rem}
.venue-logo-actions{display:flex;align-items:center;gap:.45rem;margin-bottom:.4rem}
.venue-link{color:#7c3aed;text-decoration:none;font-size:.85rem;font-weight:500;cursor:pointer}
.venue-link:hover{text-decoration:underline}
.venue-link-sep{color:var(--text-muted);font-size:.85rem}
.venue-header-preview{padding:.6rem;background:var(--bg);border:1px dashed var(--border);border-radius:8px;display:flex;align-items:center}
.venue-pill{display:inline-flex;align-items:center;padding:.35rem .85rem;background:#7c3aed;color:#fff;border-radius:999px;font-size:.85rem;font-weight:600}
