:root {
  --red:      #8C1C13;
  --red-dark: #5C130D;
  --red-mid:  #6E160F;
  --red-lite: #A52020;
  --brick:    #4A0F0B;
  --cream:    #F4EDE0;
  --ivory:    #FAF8F4;
  --parch:    #E8E0D2;
  --tan:      #B8AE9E;
  --charcoal: #18100A;
  --slate:    #5A4D3E;
  --muted:    #9A9080;
  --green:    #2D6A4F;
  --green-lt: #D1FAE5;
  --gold:     #B8860B;
  --gold-lt:  #FEF3C7;
  --steel:    #1D3557;
  --steel-lt: #DBEAFE;
  --amber:    #C4955A;
  --amber-lt: #FDE68A;
  --danger:   #C45A5A;
  --danger-lt:#FEE2E2;
  --espresso: #2C1F14;

  --font-d: 'Cormorant Garamond', Georgia, serif;
  --font-b: 'DM Sans', sans-serif;
  --font-m: 'IBM Plex Mono', monospace;

  --shadow-sm: 0 1px 4px rgba(24,16,10,0.06);
  --shadow:    0 4px 16px rgba(24,16,10,0.08);
  --shadow-lg: 0 8px 32px rgba(24,16,10,0.12);
  --radius: 10px;
}

/* ── DARK MODE ── */
body.dark-mode {
  --cream:    #18100A;
  --ivory:    #1E150E;
  --parch:    #2A1F16;
  --tan:      #5A4D3E;
  --charcoal: #F4EDE0;
  --slate:    #B8AE9E;
  --muted:    #6A6050;
  --green-lt: #052e16;
  --gold-lt:  #1c1400;
  --steel-lt: #0a1628;
  --amber-lt: #1c1000;
  --danger-lt:#1c0808;
  background: #18100A;
  color: #F4EDE0;
}
body.dark-mode .card{background:#1E150E;border-color:#2A1F16;}
body.dark-mode .modal{background:#1E150E;}
body.dark-mode .modal-body{background:#1E150E;}
body.dark-mode .form-input,body.dark-mode .form-select{background:#2A1F16;border-color:#3D3025;color:#F4EDE0;}
body.dark-mode .form-input:focus,body.dark-mode .form-select:focus{border-color:var(--red);}
body.dark-mode .data-table thead tr{background:#2A1F16;}
body.dark-mode .data-table tbody tr:hover{background:#2A1F16;}
body.dark-mode .stat-card{background:#1E150E;border-color:#2A1F16;}
body.dark-mode .search-bar{background:#1E150E;border-color:#2A1F16;}
body.dark-mode .search-bar input{background:transparent;color:#F4EDE0;}
body.dark-mode .btn-ghost{color:var(--slate);}
body.dark-mode .btn-ghost:hover{background:#2A1F16;}
body.dark-mode .page-header{border-color:#2A1F16;}
body.dark-mode .badge-tan{background:#2A1F16;color:var(--slate);}
body.dark-mode .slideout-body{background:#1E150E;}
body.dark-mode .quadrant{background:#1E150E;border-color:#2A1F16;}
body.dark-mode .q-stars{background:#1c1800;}
body.dark-mode .q-plow{background:#0a1c0a;}
body.dark-mode .q-puzzle{background:#0a0f1c;}
body.dark-mode .q-dogs{background:#1c0a0a;}
body.dark-mode .q-item{background:#2A1F16;}
body.dark-mode .sidebar-item.active{background:var(--parch);}
body.dark-mode .toast{background:#F4EDE0;color:#1E150E;}
body.dark-mode .toast.error{background:#991b1b;color:#fff;}
body.dark-mode .topbar-icon-btn:hover{background:rgba(244,237,224,0.1);}
body.dark-mode .modal-header{border-color:#2A1F16;}
body.dark-mode .modal-footer{border-color:#2A1F16;background:#1E150E;}
body.dark-mode .data-table tbody td{border-color:#2A1F16;}
body.dark-mode .nav-btn.active{background:rgba(244,237,224,0.12);}
body.dark-mode select option{background:#1E150E;color:#F4EDE0;}

*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font-b);background:var(--cream);color:var(--charcoal);font-size:14px;line-height:1.6;min-height:100vh;}

/* ── TOPBAR ── */
.topbar{
  background:#1E150E;
  color:#F4EDE0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  height:56px;
  position:sticky;top:0;z-index:100;
  box-shadow:0 2px 12px rgba(0,0,0,0.25);
  border-bottom:1px solid rgba(244,237,224,0.04);
}
.topbar-brand{display:flex;align-items:center;gap:12px;}
.topbar-element{
  width:32px;height:36px;background:#8C1C13;border-radius:6px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:inset 0 0 0 1.5px rgba(244,237,224,0.25);
}
.topbar-element span{
  font-family:var(--font-d);font-size:18px;font-weight:700;color:#F4EDE0;
}
.topbar-logo{
  font-family:var(--font-d);font-size:20px;font-weight:400;color:#F4EDE0;letter-spacing:4px;
}
.topbar-rule{width:60px;height:2px;background:#8C1C13;margin-top:2px;}
.topbar-tag{font-size:9px;color:var(--muted);letter-spacing:2.5px;text-transform:uppercase;font-family:var(--font-m);}
.topbar-nav{display:flex;gap:4px;}
.nav-btn{
  background:none;border:none;color:rgba(244,237,224,0.55);
  padding:8px 16px;border-radius:6px;cursor:pointer;
  font-family:var(--font-b);font-size:13px;font-weight:500;
  transition:all .15s;
}
.nav-btn:hover{background:rgba(244,237,224,0.06);color:#F4EDE0;}
.nav-btn.active{background:rgba(244,237,224,0.10);color:#F4EDE0;}
.topbar-right{display:flex;align-items:center;gap:8px;}
.location-badge{
  background:rgba(244,237,224,0.08);
  border:1px solid rgba(244,237,224,0.12);
  color:rgba(244,237,224,0.65);
  padding:4px 12px;border-radius:20px;
  font-size:11px;letter-spacing:0.5px;
}

/* ── TOPBAR ICON BUTTONS ── */
.topbar-icon-btn{
  background:none;border:none;color:rgba(244,237,224,0.6);
  padding:8px;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.topbar-icon-btn:hover{background:rgba(244,237,224,0.08);color:#F4EDE0;}

/* ── OVERFLOW MENU ── */
.topbar-overflow{position:relative;}
.overflow-menu{
  display:none;position:absolute;top:calc(100% + 8px);right:0;
  background:var(--ivory);border:1px solid var(--parch);
  border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,0.12);
  min-width:220px;padding:6px;z-index:999;
}
.overflow-menu.open{display:block;}
.overflow-item{
  display:flex;align-items:center;gap:10px;width:100%;
  background:none;border:none;padding:10px 14px;border-radius:7px;
  cursor:pointer;font-family:var(--font-b);font-size:13px;
  color:var(--slate);transition:background .12s;text-align:left;
}
.overflow-item:hover{background:var(--parch);}
.overflow-item svg{flex-shrink:0;color:var(--muted);}
.overflow-divider{height:1px;background:var(--parch);margin:4px 8px;}
body.dark-mode .overflow-menu{background:var(--dark-card);border-color:var(--dark-border);}
body.dark-mode .overflow-item{color:var(--dark-text);}
body.dark-mode .overflow-item:hover{background:rgba(244,237,224,0.05);}
body.dark-mode .overflow-divider{background:var(--dark-border);}

/* ── HELP TABS ── */
.help-tab{
  background:none;border:none;border-bottom:2px solid transparent;
  padding:10px 14px;cursor:pointer;font-family:var(--font-b);
  font-size:12px;font-weight:500;color:var(--muted);
  transition:all .12s;white-space:nowrap;
}
.help-tab:hover{color:var(--slate);}
.help-tab.active{color:var(--red);border-bottom-color:var(--red);font-weight:600;}
.help-panel{display:none;}
.help-panel.active{display:block;}

/* ── TOOLTIP SYSTEM ── */
[data-tooltip]{position:relative;}
[data-tooltip]::after{
  content:attr(data-tooltip);
  position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--espresso);color:#F4EDE0;
  padding:6px 12px;border-radius:6px;
  font-family:var(--font-b);font-size:11px;font-weight:400;
  line-height:1.4;white-space:nowrap;max-width:260px;white-space:normal;text-align:center;
  opacity:0;pointer-events:none;transition:opacity .15s;z-index:1000;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
}
[data-tooltip]::before{
  content:'';position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--espresso);
  opacity:0;pointer-events:none;transition:opacity .15s;z-index:1000;
}
[data-tooltip]:hover::after,[data-tooltip]:hover::before{opacity:1;}
/* Tooltip position variants */
[data-tooltip-pos="bottom"]::after{bottom:auto;top:calc(100% + 8px);}
[data-tooltip-pos="bottom"]::before{bottom:auto;top:calc(100% + 4px);border-top-color:transparent;border-bottom-color:var(--espresso);}
[data-tooltip-pos="right"]::after{bottom:auto;left:calc(100% + 8px);top:50%;transform:translateY(-50%);}
[data-tooltip-pos="right"]::before{bottom:auto;left:calc(100% + 4px);top:50%;transform:translateY(-50%);border-top-color:transparent;border-right-color:var(--espresso);}
/* Right-aligned tooltips (for topbar items near right edge) */
.topbar-right [data-tooltip]::after{left:auto;right:0;transform:none;}
.topbar-right [data-tooltip]::before{left:auto;right:12px;transform:none;}
/* Nav button tooltips below */
.nav-btn[data-tooltip]::after{bottom:auto;top:calc(100% + 8px);}
.nav-btn[data-tooltip]::before{bottom:auto;top:calc(100% + 4px);border-top-color:transparent;border-bottom-color:var(--espresso);}

/* ── SIDEBAR FOOTER ── */
.sidebar-footer{
  border-top:1px solid var(--parch);
  padding:8px 12px;margin-top:auto;
}
.sidebar-footer-top{
  display:flex;flex-direction:column;gap:1px;
}
.sidebar-footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:4px;padding-top:4px;
}
.sidebar-footer-btn{
  display:flex;align-items:center;gap:8px;
  background:none;border:none;padding:6px 8px;border-radius:6px;
  cursor:pointer;font-family:var(--font-b);font-size:12px;
  color:var(--muted);transition:all .12s;width:100%;text-align:left;
}
.sidebar-footer-btn:hover{background:var(--parch);color:var(--slate);}
.sidebar-version{
  font-family:var(--font-m);font-size:10px;letter-spacing:1px;
  color:var(--muted);opacity:0.5;padding:0 8px;
}
body.dark-mode .sidebar-footer{border-top-color:var(--dark-border);}
body.dark-mode .sidebar-footer-btn{color:var(--dark-muted);}
body.dark-mode .sidebar-footer-btn:hover{background:rgba(244,237,224,0.05);color:var(--dark-text);}
.sidebar.collapsed .sidebar-footer-btn .nav-label{display:none;}
.sidebar.collapsed .sidebar-version{display:none;}
.sidebar.collapsed .sidebar-footer-bottom{justify-content:center;}
.sidebar-content{flex:1;overflow-y:auto;padding-bottom:8px;}

/* Sidebar item tooltips - only show when collapsed */
.sidebar-item[data-tooltip]::after,.sidebar-item[data-tooltip]::before{display:none;}
.sidebar.collapsed .sidebar-item[data-tooltip]::after{
  display:block;bottom:auto;top:50%;left:calc(100% + 12px);
  transform:translateY(-50%);white-space:nowrap;
}
.sidebar.collapsed .sidebar-item[data-tooltip]::before{
  display:block;bottom:auto;top:50%;left:calc(100% + 6px);
  transform:translateY(-50%);border-top-color:transparent;border-right-color:var(--espresso);
}
.sidebar-footer-btn[data-tooltip]::after,.sidebar-footer-btn[data-tooltip]::before{display:none;}
.sidebar.collapsed .sidebar-footer-btn[data-tooltip]::after{
  display:block;bottom:auto;top:50%;left:calc(100% + 12px);
  transform:translateY(-50%);white-space:nowrap;
}
.sidebar.collapsed .sidebar-footer-btn[data-tooltip]::before{
  display:block;bottom:auto;top:50%;left:calc(100% + 6px);
  transform:translateY(-50%);border-top-color:transparent;border-right-color:var(--espresso);
}

/* ── LAYOUT ── */
.app{display:flex;height:calc(100vh - 56px);}
.sidebar{
  width:220px;flex-shrink:0;
  background:var(--ivory);
  border-right:1px solid var(--parch);
  padding:16px 0 0 0;
  overflow-y:auto;
  transition:width .2s ease;
  position:relative;
  display:flex;flex-direction:column;
}
.sidebar.collapsed{width:52px;}
.sidebar.collapsed .sidebar-label{display:none;}
.sidebar.collapsed .sidebar-item span.nav-label{display:none;}
.sidebar.collapsed .sidebar-item{padding:9px;justify-content:center;}
.sidebar.collapsed .sidebar-item .nav-icon{margin:0;}
.sidebar-collapse-btn{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  background:var(--parch);border:1px solid var(--cream);border-radius:6px;
  padding:5px 8px;cursor:pointer;font-size:11px;color:var(--muted);
  transition:all .15s;white-space:nowrap;
}
.sidebar-collapse-btn:hover{background:var(--cream);color:var(--charcoal);}
.sidebar-section{margin-bottom:8px;}
.sidebar-label{
  font-size:9px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold);font-weight:600;font-family:var(--font-m);
  padding:8px 20px 4px;
}
.sidebar-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 20px;cursor:pointer;
  font-size:13px;font-weight:500;color:var(--slate);
  border-left:3px solid transparent;
  transition:all .15s;
}
.sidebar-item:hover{background:var(--parch);color:var(--charcoal);}
.sidebar-item.active{
  background:rgba(140,28,19,0.06);color:var(--red);
  border-left-color:var(--red);font-weight:600;
}
.sidebar-icon{font-size:15px;width:20px;text-align:center;}
.sidebar-count{
  margin-left:auto;
  background:var(--red);color:#fff;
  font-size:10px;font-weight:700;
  padding:2px 6px;border-radius:10px;
  font-family:var(--font-m);
}

.main{flex:1;overflow-y:auto;padding:28px 32px;}

/* ── PANELS ── */
.panel{display:none;}
.panel.active{display:block;}

/* ── PAGE HEADERS ── */
.page-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:28px;
}
.page-title{font-family:var(--font-d);font-size:28px;font-weight:300;color:var(--charcoal);line-height:1.1;}
.page-title span{font-style:italic;color:var(--red);}
.page-sub{font-size:13px;color:var(--muted);margin-top:4px;}
.page-actions{display:flex;gap:8px;align-items:center;}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:8px;
  font-family:var(--font-b);font-size:13px;font-weight:600;
  cursor:pointer;border:none;transition:all .15s;
  text-decoration:none;
}
.btn-primary{background:var(--red);color:var(--cream);}
.btn-primary:hover{background:var(--red-mid);}
.btn-secondary{background:var(--cream);color:var(--charcoal);border:1px solid var(--parch);}
.btn-secondary:hover{background:var(--tan);color:var(--charcoal);}
.btn-ghost{background:none;color:var(--muted);border:none;}
.btn-ghost:hover{border-color:var(--tan);color:var(--slate);}
.btn-danger{background:var(--danger-lt);color:var(--danger);}
.btn-danger:hover{background:#FCA5A5;}
.btn-sm{padding:5px 12px;font-size:12px;}
.btn-icon{padding:7px;border-radius:6px;}

/* ── STAT CARDS ── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.stat-card{
  background:var(--ivory);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow-sm);
  border-bottom:3px solid var(--parch);
  position:relative;overflow:hidden;
}
.stat-card.red{border-bottom-color:var(--red);}
.stat-card.green{border-bottom-color:var(--green);}
.stat-card.gold{border-bottom-color:var(--gold);}
.stat-card.steel{border-bottom-color:var(--steel);}
.stat-num{font-family:var(--font-d);font-size:32px;font-weight:300;line-height:1;color:var(--charcoal);}
.stat-num.red{color:var(--red);}
.stat-num.green{color:var(--green);}
.stat-num.gold{color:var(--gold);}
.stat-num.steel{color:var(--steel);}
.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px;font-family:var(--font-m);}
.stat-delta{font-size:12px;margin-top:8px;font-weight:600;}
.stat-delta.up{color:var(--green);}
.stat-delta.down{color:var(--danger);}

/* ── TABLES ── */
.card{
  background:var(--ivory);border-radius:var(--radius);
  border:1px solid var(--parch);
  box-shadow:var(--shadow);overflow:hidden;
  margin-bottom:20px;
}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid var(--parch);
}
.card-title{font-family:var(--font-d);font-size:17px;font-weight:500;color:var(--charcoal);}
.card-body{padding:0;}
.table-scroll{overflow-x:auto;overflow-y:auto;max-height:520px;}

table.data-table{width:100%;border-collapse:collapse;}
table.data-table thead tr{background:#1E150E;}
table.data-table thead th{
  padding:10px 16px;text-align:left;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  color:#F4EDE0;font-weight:600;font-family:var(--font-m);
  position:sticky;top:0;z-index:2;background:#1E150E;
}
table.data-table tbody tr{border-bottom:1px solid var(--parch);transition:background .1s;}
table.data-table tbody tr:last-child{border-bottom:none;}
table.data-table tbody tr:hover{background:rgba(140,28,19,0.03);}
table.data-table tbody tr.selected-row{background:rgba(140,28,19,0.05);}
table.data-table tbody tr.selected-row:hover{background:rgba(140,28,19,0.08);}
.sortable-th{cursor:pointer;user-select:none;}
.sortable-th:hover{background:rgba(0,0,0,0.06);}
.sort-arrow{font-size:10px;opacity:0.5;margin-left:2px;}
.sort-arrow.active{opacity:1;color:var(--red);}
.sortable-th.sort-active{color:var(--red-dark);}
table.data-table tbody td{padding:11px 16px;color:var(--slate);vertical-align:middle;}
.td-name{font-weight:600;color:var(--charcoal);}
.td-code{font-family:var(--font-m);font-size:11px;color:var(--muted);}
.td-num{font-family:var(--font-m);font-size:13px;}
.td-actions{display:flex;gap:6px;}

/* ── BADGES ── */
.badge{
  display:inline-block;padding:2px 9px;border-radius:12px;
  font-size:10px;font-weight:700;letter-spacing:0.3px;
  font-family:var(--font-m);
}
.badge-red{background:var(--danger-lt);color:var(--danger);}
.badge-green{background:var(--green-lt);color:var(--green);}
.badge-gold{background:var(--gold-lt);color:#92400E;}
.badge-steel{background:var(--steel-lt);color:var(--steel);}
.badge-tan{background:var(--parch);color:var(--slate);}
.badge-amber{background:var(--amber-lt);color:#92400E;}

.badge-amber{background:var(--amber-lt);color:#92400E;}

/* ── COST INDICATOR ── */
.cost-bar-wrap{display:flex;align-items:center;gap:8px;}
.cost-bar{height:6px;border-radius:3px;background:var(--parch);flex:1;overflow:hidden;}
.cost-bar-fill{height:100%;border-radius:3px;transition:width .3s;}
.cost-bar-fill.good{background:var(--green);}
.cost-bar-fill.warn{background:var(--gold);}
.cost-bar-fill.bad{background:var(--danger);}

/* ── MODALS ── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(44,32,24,0.50);
  z-index:200;align-items:center;justify-content:center;
}
.modal-overlay.open{display:flex;}
.modal{
  background:var(--ivory);border-radius:12px;
  width:560px;max-width:95vw;max-height:90vh;
  overflow-y:auto;
  box-shadow:var(--shadow-lg);
  animation:slideUp .2s ease;
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0;}to{transform:translateY(0);opacity:1;}}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--parch);
  position:sticky;top:0;background:var(--ivory);z-index:1;
}
.modal-title{font-family:var(--font-d);font-size:20px;font-weight:400;color:var(--charcoal);}
.modal-close{
  background:none;border:none;font-size:20px;cursor:pointer;
  color:var(--muted);width:32px;height:32px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
}
.modal-close:hover{background:var(--parch);}
.modal-body{padding:24px;}
.modal-footer{
  padding:16px 24px;border-top:1px solid var(--parch);
  display:flex;justify-content:flex-end;gap:10px;
}

/* ── FORMS ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.form-row.three{grid-template-columns:1fr 1fr 1fr;}
.form-row.single{grid-template-columns:1fr;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{font-size:11px;font-weight:600;color:var(--slate);letter-spacing:0.5px;text-transform:uppercase;}
.form-input,.form-select,.form-textarea{
  background:var(--cream);border:1.5px solid var(--parch);
  border-radius:7px;padding:9px 12px;
  font-family:var(--font-b);font-size:13px;color:var(--charcoal);
  transition:border .15s;
  outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--red);}
.form-textarea{resize:vertical;min-height:80px;}
.form-hint{font-size:11px;color:var(--muted);}

/* ── RECIPE BUILDER ── */
.recipe-ingredient-row{
  display:grid;grid-template-columns:20px 1fr 100px 80px 80px 32px;
  gap:8px;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--parch);
  transition:background .15s;
}
.recipe-ingredient-row:last-child{border-bottom:none;}
.recipe-ingredient-row.drag-over{background:var(--cream);border-top:2px solid var(--red);}
.recipe-ingredient-row.dragging{opacity:0.4;}
.drag-handle{
  cursor:grab;color:var(--tan);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  user-select:none;
}
.drag-handle:active{cursor:grabbing;}
.recipe-totals{
  background:var(--red-dark);color:#fff;
  border-radius:0 0 var(--radius) var(--radius);
  padding:14px 20px;
  display:flex;justify-content:space-between;align-items:center;
}
.recipe-totals-label{font-size:12px;color:rgba(255,255,255,0.65);}
.recipe-totals-num{font-family:var(--font-d);font-size:22px;font-weight:300;}
.recipe-totals-pct{
  font-size:11px;font-family:var(--font-m);
  padding:3px 10px;border-radius:12px;margin-top:2px;display:inline-block;
}

/* ── MENU ENGINEERING QUADRANT ── */
.quadrant-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3px;background:var(--parch);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.quadrant{
  padding:20px;min-height:200px;
  display:flex;flex-direction:column;
}
.q-stars{background:#FFFBEB;}
.q-plow{background:#F0FDF4;}
.q-puzzle{background:#EFF6FF;}
.q-dogs{background:#FEF2F2;}
.q-label{
  font-family:var(--font-d);font-size:15px;font-weight:700;margin-bottom:4px;
}
.q-stars .q-label{color:#92400E;}
.q-plow .q-label{color:var(--green);}
.q-puzzle .q-label{color:var(--steel);}
.q-dogs .q-label{color:var(--danger);}
.q-desc{font-size:11px;color:var(--muted);margin-bottom:12px;}
.q-items{display:flex;flex-direction:column;gap:6px;flex:1;}
.q-item{
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(255,255,255,0.70);border-radius:6px;
  padding:7px 10px;font-size:12px;
}
.q-item-name{font-weight:600;color:var(--charcoal);}
.q-item-stats{display:flex;gap:8px;font-family:var(--font-m);font-size:11px;color:var(--muted);}
.q-axis{
  display:flex;justify-content:space-between;
  font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;
  padding:8px 0 0;margin-top:auto;
}

/* ── SEARCH ── */
.search-bar{
  display:flex;align-items:center;gap:8px;
  background:var(--cream);border:1.5px solid var(--parch);
  border-radius:7px;padding:7px 12px;
  margin-bottom:16px;
}
.search-bar input{
  background:none;border:none;outline:none;
  font-family:var(--font-b);font-size:13px;color:var(--charcoal);flex:1;
}
.search-icon{color:var(--tan);font-size:14px;}

/* ── EMPTY STATE ── */
.empty-state{
  text-align:center;padding:60px 20px;color:var(--muted);
}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:0.5;}
.empty-text{font-size:15px;font-family:var(--font-d);}
.empty-sub{font-size:13px;margin-top:6px;}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:24px;right:24px;
  background:var(--charcoal);color:#fff;
  padding:12px 20px;border-radius:8px;
  font-size:13px;font-weight:500;
  box-shadow:var(--shadow-lg);
  z-index:999;
  transform:translateY(80px);opacity:0;
  transition:all .25s ease;
  display:flex;align-items:center;gap:8px;
}
.toast.show{transform:translateY(0);opacity:1;}
.toast.success{background:var(--green);}
.toast.error{background:var(--danger);}
.toast.info{background:var(--steel);}
kbd{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--parch);border:1px solid var(--tan);
  border-radius:4px;padding:2px 7px;
  font-size:11px;font-family:var(--font-m);font-weight:600;
  color:var(--charcoal);min-width:24px;
  box-shadow:0 1px 2px rgba(0,0,0,.08);
}

/* ── COMPASS SPECIFICS ── */
.compass-controls{
  display:flex;gap:12px;align-items:center;
  background:var(--ivory);border-radius:var(--radius);
  padding:16px 20px;margin-bottom:20px;
  box-shadow:var(--shadow-sm);
  flex-wrap:wrap;
}
.compass-control{display:flex;flex-direction:column;gap:4px;}
.compass-control label{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}

/* ── SLIDEOUT ── */
.slideout-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(44,32,24,0.35);z-index:150;
}
.slideout-overlay.open{display:block;}
.slideout{
  position:fixed;top:0;right:-600px;width:580px;height:100vh;
  background:var(--ivory);box-shadow:-8px 0 40px rgba(44,32,24,0.18);
  z-index:160;display:flex;flex-direction:column;
  transition:right .28s cubic-bezier(.4,0,.2,1);
}
.slideout.open{right:0;}
.slideout-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--parch);
  background:var(--red-dark);color:#fff;
  flex-shrink:0;
}
.slideout-header .modal-title{color:#fff;}
.slideout-body{flex:1;overflow-y:auto;padding:24px;}

/* ── TOOLTIPS ── */
[data-tip]{position:relative;}
[data-tip]:hover::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:var(--charcoal);color:#fff;font-size:11px;font-weight:500;white-space:nowrap;
  padding:4px 8px;border-radius:5px;pointer-events:none;z-index:200;
  font-family:var(--font-b);
}
[data-tip]:hover::before{
  content:'';position:absolute;bottom:calc(100% + 1px);left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--charcoal);pointer-events:none;z-index:200;
}

/* ── SEARCH ── */
.search-group-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:700;padding:8px 0 4px;margin-top:4px;}
.search-result-item{
  display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:7px;cursor:pointer;
  transition:background .1s;
}
.search-result-item:hover{background:var(--cream);}
.search-result-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.search-result-name{font-size:13px;font-weight:600;color:var(--charcoal);}
.search-result-meta{font-size:11px;color:var(--muted);margin-top:1px;}
.search-empty{text-align:center;padding:28px;color:var(--muted);font-size:13px;}
.search-shortcut{display:inline-block;background:var(--parch);border:1px solid var(--tan);border-radius:4px;padding:1px 6px;font-family:var(--font-m);font-size:10px;color:var(--slate);}

/* ── BENCHMARK BARS ── */
.bench-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.bench-label{font-size:12px;font-weight:600;color:var(--slate);width:120px;flex-shrink:0;}
.bench-bar-wrap{flex:1;height:10px;background:var(--parch);border-radius:5px;position:relative;overflow:visible;}
.bench-bar-fill{height:100%;border-radius:5px;transition:width .4s ease;}
.bench-target-line{position:absolute;top:-4px;width:2px;height:18px;background:var(--charcoal);border-radius:1px;}
.bench-values{font-size:11px;font-family:var(--font-m);color:var(--muted);width:90px;text-align:right;flex-shrink:0;}

/* ── CATEGORY CARD ── */
.cat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.cat-card-name{font-family:var(--font-d);font-size:18px;font-weight:400;color:var(--charcoal);}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--tan);border-radius:3px;}

/* ── TOOLTIP ── */
[data-tip]{position:relative;}
[data-tip]:hover::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:var(--charcoal);color:#fff;
  font-size:11px;padding:4px 10px;border-radius:5px;
  white-space:nowrap;z-index:50;pointer-events:none;
}

.divider{border:none;border-top:1px solid var(--parch);margin:20px 0;}

/* ── INGREDIENT COST TAG ── */
.cost-tag{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-m);font-size:12px;
  background:var(--parch);color:var(--slate);
  padding:2px 8px;border-radius:4px;
}
.cost-tag.highlight{background:var(--gold-lt);color:#92400E;}

/* ── MOBILE RESPONSIVE ── */
@media (max-width: 768px) {
  #sidebar-toggle { display:flex !important; }
  .topbar-tag { display:none; }
  .topbar-nav .nav-btn { padding:6px 10px; font-size:11px; }
  .location-badge { display:none; }

  .sidebar {
    position:fixed;
    left:-240px;
    top:56px;
    height:calc(100vh - 56px);
    z-index:200;
    transition:left .25s ease;
    box-shadow:4px 0 20px rgba(0,0,0,.12);
  }
  .sidebar.mobile-open {
    left:0;
  }
  .sidebar-overlay {
    display:none;
    position:fixed;inset:0;top:56px;
    background:rgba(0,0,0,.35);
    z-index:199;
  }
  .sidebar-overlay.active { display:block; }

  .content-area { margin-left:0 !important; width:100%; }
  .app { flex-direction:column; }

  .stat-row { grid-template-columns:repeat(2,1fr) !important; }
  .page-header { flex-direction:column; align-items:flex-start; gap:10px; }
  .page-actions { width:100%; flex-wrap:wrap; }

  .modal { width:95vw !important; max-width:95vw !important; margin:16px; }
  .form-row { flex-direction:column; }
  .form-row > .form-group { width:100% !important; }

  [style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns:1fr 1.6fr"] {
    grid-template-columns:1fr !important;
  }
  [style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns:1fr !important;
  }
  [style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:repeat(2,1fr) !important;
  }
  [style*="grid-template-columns:repeat(5,1fr)"] {
    grid-template-columns:repeat(3,1fr) !important;
  }
  .slideout { width:100vw !important; }

  /* Horizontal scroll for data tables */
  .data-table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .data-table thead, .data-table tbody { min-width:600px; }

  /* Engineering matrix stacks vertically */
  .quadrant-grid { grid-template-columns:1fr !important; }

  /* Topbar buttons */
  .topbar-right { gap:4px; }
  .topbar-icon-btn { padding:6px; }
  /* Hide tooltips on mobile - use touch instead */
  [data-tooltip]::after,[data-tooltip]::before{display:none !important;}

  /* Print buttons hide on mobile */
  [onclick*="print"] { display:none !important; }
}
