/* Homestead Commander — v2 */
:root {
  --bark:       #3d2b1a;
  --bark-lt:    #5c3d24;
  --oak:        #7a5c38;
  --oak-lt:     #a07848;
  --forest:     #2d4a2a;
  --forest-lt:  #3d6438;
  --sage:       #6a8a58;
  --fern:       #4a6a3a;
  --cream:      #f4efe4;
  --parchment:  #e8dfc8;
  --earth:      #8a7058;
  --clay:       #b8926a;
  --clay-lt:    #d4b08a;
  --moss:       #4a5a38;
  --stone:      #7a7868;
  --gold-h:     #c4a044;
  --gold-dim:   #8a6e2a;
  --surface-0:  #1e1a14;
  --surface-1:  #28221a;
  --surface-2:  #332a20;
  --surface-3:  #3e3228;
  --border:     rgba(92,61,36,.4);
  --border-lt:  rgba(120,90,55,.25);
  --text-pri:   #e8dfc8;
  --text-sec:   #b8a888;
  --text-muted: #7a6a52;
  --radius:     5px;
  --transition: 200ms ease;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:   'DM Sans',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--surface-0);color:var(--text-pri);line-height:1.6;min-height:100vh;}
.container{max-width:1280px;margin:0 auto;padding:0 24px;}

/* ─── TYPOGRAPHY ──────────────────────────────────────────── */
h1,h2,h3{font-family:var(--font-display);font-weight:400;}
h1{font-size:clamp(1.6rem,4vw,2.4rem);}
h2{font-size:1.5rem;}
h3{font-size:1.15rem;}
a{color:var(--clay);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--clay-lt);}

/* ─── NAV ─────────────────────────────────────────────────── */
.site-nav{background:var(--surface-1);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:24px;}
.nav-logo{font-family:var(--font-display);font-size:1.2rem;color:var(--text-pri);letter-spacing:.04em;}
.nav-logo span{color:var(--gold-h);}
.nav-links{display:flex;list-style:none;gap:28px;}
.nav-links a{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-sec);}
.nav-links a:hover,.nav-links a.active{color:var(--clay-lt);}
.nav-actions{display:flex;align-items:center;gap:12px;}
.nav-role{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-h);padding:3px 10px;border:1px solid var(--gold-dim);border-radius:var(--radius);}
.nav-logout{font-size:.72rem;color:var(--text-muted);border:1px solid var(--border);padding:5px 12px;border-radius:var(--radius);background:none;cursor:pointer;}
.nav-logout:hover{color:var(--text-sec);border-color:var(--border-lt);}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-sec);border-radius:1px;}

/* ─── LOGIN PAGE ──────────────────────────────────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
    background:var(--surface-0);
    background-image:radial-gradient(ellipse at 30% 20%, rgba(61,100,56,.12) 0%, transparent 60%),
                     radial-gradient(ellipse at 70% 80%, rgba(92,61,36,.15) 0%, transparent 60%);}
.login-card{background:var(--surface-1);border:1px solid var(--border);border-radius:8px;padding:48px 44px;width:100%;max-width:420px;}
.login-eyebrow{font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-h);margin-bottom:8px;}
.login-title{font-family:var(--font-display);font-size:2rem;font-weight:400;color:var(--text-pri);margin-bottom:4px;}
.login-sub{font-size:.82rem;color:var(--text-muted);margin-bottom:36px;}
.login-divider{width:48px;height:2px;background:var(--gold-dim);margin:16px 0 32px;}

/* ─── FORMS ───────────────────────────────────────────────── */
.form-group{margin-bottom:20px;}
.form-label{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-sec);margin-bottom:7px;}
.form-input{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius);padding:11px 14px;font-size:.92rem;color:var(--text-pri);font-family:var(--font-body);transition:border-color var(--transition);}
.form-input:focus{outline:none;border-color:var(--oak);}
.form-input::placeholder{color:var(--text-muted);}
.form-select{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius);padding:11px 14px;font-size:.92rem;color:var(--text-pri);font-family:var(--font-body);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a6a52' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;}
.form-select:focus{outline:none;border-color:var(--oak);}
.form-error{font-size:.78rem;color:#c47a5a;margin-top:5px;}
textarea.form-input{resize:vertical;min-height:80px;}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;text-decoration:none;transition:all var(--transition);}
.btn-primary{background:var(--oak);color:var(--cream);}
.btn-primary:hover{background:var(--oak-lt);color:var(--cream);}
.btn-forest{background:var(--forest);color:var(--cream);}
.btn-forest:hover{background:var(--forest-lt);color:var(--cream);}
.btn-ghost{background:transparent;color:var(--text-sec);border:1px solid var(--border);}
.btn-ghost:hover{border-color:var(--border-lt);color:var(--text-pri);}
.btn-danger{background:transparent;color:#c47a5a;border:1px solid #4a2a2a;}
.btn-danger:hover{background:#3a1a1a;color:#d48a6a;}
.btn-sm{padding:6px 14px;font-size:.68rem;}
.btn-full{width:100%;justify-content:center;}
.btn-wallet{width:100%;justify-content:center;background:var(--surface-2);color:var(--text-pri);border:1px solid var(--border-lt);font-size:.82rem;padding:13px 20px;}
.btn-wallet:hover{background:var(--surface-3);border-color:var(--oak);color:var(--cream);}
.btn-wallet:disabled{opacity:.6;cursor:not-allowed;}
.login-or{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--text-muted);font-size:.72rem;letter-spacing:.06em;}
.login-or::before,.login-or::after{content:'';flex:1;height:1px;background:var(--border);}

/* ─── CARDS ───────────────────────────────────────────────── */
.card{background:var(--surface-1);border:1px solid var(--border);border-radius:8px;padding:24px;}
.card-sm{padding:16px 20px;}
.card-title{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-h);margin-bottom:8px;}
.card-value{font-family:var(--font-display);font-size:2.2rem;color:var(--clay-lt);font-weight:400;line-height:1;margin-bottom:4px;}
.card-sub{font-size:.78rem;color:var(--text-muted);}

/* ─── STAT GRID ───────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:28px;}

/* ─── ALERTS ──────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--radius);font-size:.85rem;margin-bottom:20px;}
.alert-success{background:#1a2a18;border:1px solid #4a7a44;color:#7aab6a;}
.alert-error{background:#2a1a18;border:1px solid #7a4a44;color:#ab7a6a;}

/* ─── BUDGET TABLE ────────────────────────────────────────── */
.budget-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.budget-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:900px;}
.budget-table thead th{padding:8px 10px;text-align:right;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-h);font-weight:500;border-bottom:2px solid var(--border);white-space:nowrap;}
.budget-table thead th:first-child{text-align:left;}
.budget-table .group-header td{background:var(--surface-2);padding:8px 10px;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);font-weight:600;border-top:2px solid var(--border);}
.budget-table .cat-row td{padding:9px 10px;border-bottom:1px solid rgba(92,61,36,.15);vertical-align:middle;}
.budget-table .cat-row td:first-child{color:var(--text-sec);}
.budget-table .cat-row td:not(:first-child){text-align:right;font-family:'Courier New',monospace;font-size:.8rem;color:var(--text-pri);}
.budget-table .cat-row td.zero{color:var(--text-muted);}
.budget-table .cat-row:hover td{background:rgba(92,61,36,.06);}
.budget-table .group-total td{padding:7px 10px;border-top:1px solid var(--border);border-bottom:2px solid var(--border);}
.budget-table .group-total td:first-child{font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--clay);font-weight:600;}
.budget-table .group-total td:not(:first-child){text-align:right;font-family:'Courier New',monospace;font-size:.82rem;color:var(--clay-lt);font-weight:600;}
.budget-table .grand-total td{padding:10px 10px;background:var(--surface-2);border-top:2px solid var(--oak);}
.budget-table .grand-total td:first-child{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-h);font-weight:700;}
.budget-table .grand-total td:not(:first-child){text-align:right;font-family:'Courier New',monospace;font-size:.88rem;color:var(--gold-h);font-weight:700;}
.budget-table .avg-col{color:var(--clay) !important;background:rgba(61,43,26,.2);}
.budget-table .income-header td{color:var(--sage);border-top-color:var(--forest);}
.budget-table .income-row td:first-child{color:var(--sage) !important;opacity:.85;}
.budget-table .income-total td:first-child{color:var(--sage) !important;}
.budget-table .income-total td:not(:first-child){color:var(--sage) !important;}
.budget-table .net-row td:first-child{color:var(--cream) !important;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;}

/* ─── MONTH HIGHLIGHT ─────────────────────────────────────── */
.budget-table .current-month{background:rgba(92,61,36,.15);color:var(--clay-lt) !important;}

/* ─── ENTRY FORM ──────────────────────────────────────────── */
.entry-wrap{max-width:600px;}
.entry-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.entry-amount-row{display:flex;align-items:center;gap:0;}
.amount-prefix{background:var(--surface-2);border:1px solid var(--border);border-right:none;border-radius:var(--radius) 0 0 var(--radius);padding:11px 12px;color:var(--text-muted);font-size:.92rem;}
.entry-amount-row .form-input{border-radius:0 var(--radius) var(--radius) 0;}

/* ─── TREND CHART ─────────────────────────────────────────── */
.trend-chart{display:flex;gap:4px;align-items:flex-end;height:64px;margin-top:8px;}
.trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;justify-content:flex-end;}
.trend-bar{width:100%;border-radius:2px 2px 0 0;min-height:2px;background:var(--oak);transition:height var(--transition);}
.trend-bar.current{background:var(--gold-h);}
.trend-label{font-size:.55rem;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;}

/* ─── DONUT / PIE (CSS only) ──────────────────────────────── */
.group-bars{display:flex;flex-direction:column;gap:8px;margin-top:8px;}
.group-bar-row{display:flex;align-items:center;gap:8px;}
.group-bar-label{font-size:.72rem;color:var(--text-sec);width:120px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.group-bar-track{flex:1;height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;}
.group-bar-fill{height:100%;border-radius:3px;background:var(--oak);transition:width .3s ease;}
.group-bar-amt{font-size:.72rem;color:var(--clay-lt);font-family:'Courier New',monospace;width:72px;text-align:right;flex-shrink:0;}

/* ─── ADMIN TABLE ─────────────────────────────────────────── */
.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:680px;}
.admin-table th{padding:8px 12px;text-align:left;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-h);border-bottom:2px solid var(--border);}
.admin-table td{padding:12px;border-bottom:1px solid var(--border-lt);vertical-align:middle;}
.admin-table tr:hover td{background:rgba(92,61,36,.04);}

/* ─── BADGES ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:3px;}
.badge-gold{background:rgba(196,160,68,.1);color:var(--gold-h);border:1px solid rgba(196,160,68,.3);}
.badge-forest{background:rgba(45,74,42,.3);color:var(--sage);border:1px solid rgba(106,138,88,.3);}
.badge-muted{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border);}
.badge-clay{background:rgba(184,146,106,.1);color:var(--clay-lt);border:1px solid rgba(184,146,106,.3);}
.badge-inactive{background:rgba(42,26,20,.5);color:#6a4a3a;border:1px solid #3a2520;}

/* ─── PERMISSIONS GRID ────────────────────────────────────── */
.perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin:12px 0;}
.perm-label{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;}
.perm-label input[type=checkbox]{accent-color:var(--oak);width:14px;height:14px;flex-shrink:0;}
.perm-text{font-size:.72rem;color:var(--text-sec);}
.perm-group{font-size:.58rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);}

/* ─── PAGE HEADER ─────────────────────────────────────────── */
.page-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--border);}
.page-title{font-family:var(--font-display);font-size:1.8rem;font-weight:400;color:var(--text-pri);}
.page-eyebrow{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;}
.back-link{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);}
.back-link:hover{color:var(--text-sec);}

/* ─── RESPONSIVE ──────────────────────────────────────────── */
/* ── Hamburger ────────────────────────────────────────────── */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:8px;flex-shrink:0;}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-sec);border-radius:1px;transition:background var(--transition);}
.nav-hamburger:hover span{background:var(--clay-lt);}

/* ── Mobile drawer ────────────────────────────────────────── */
.hc-nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;}
.hc-nav-backdrop.open{display:block;}
.hc-nav-drawer{position:fixed;top:0;right:0;width:min(280px,85vw);height:100vh;background:var(--surface-1);border-left:1px solid var(--border);z-index:210;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto;}
.hc-nav-drawer.open{transform:translateX(0);}
body.nav-open{overflow:hidden;}
.hc-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);flex-shrink:0;}
.hc-drawer-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.1rem;line-height:1;padding:4px 6px;}
.hc-drawer-close:hover{color:var(--text-pri);}
.hc-drawer-identity{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);}
.hc-drawer-avatar{width:36px;height:36px;border-radius:50%;background:var(--surface-3);border:1px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1rem;color:var(--gold-h);flex-shrink:0;}
.hc-drawer-name{font-size:.88rem;color:var(--cream);font-weight:500;}
.hc-drawer-role{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-h);margin-top:2px;}
.hc-drawer-links{list-style:none;padding:6px 0;flex:1;}
.hc-drawer-links li a{display:block;padding:13px 20px;font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-sec);text-decoration:none;border-bottom:1px solid rgba(92,61,36,.15);}
.hc-drawer-links li:last-child a{border-bottom:none;}
.hc-drawer-links li a:hover,.hc-drawer-links li a.hc-active{color:var(--clay-lt);background:rgba(92,61,36,.08);}
.hc-drawer-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0;}
.hc-drawer-signout{width:100%;background:none;border:1px solid var(--border);color:var(--text-muted);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:9px;border-radius:var(--radius);cursor:pointer;font-family:var(--font-body);transition:all var(--transition);}
.hc-drawer-signout:hover{border-color:#7a4a44;color:#c47a5a;}

@media(max-width:960px){
  .nav-links{display:none;}
  .nav-actions{display:none;}
  .nav-hamburger{display:flex;}
}
@media(max-width:768px){
  .entry-grid{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .login-card{padding:36px 28px;}
  .budget-table-wrap{margin:0 -24px;padding:0 24px;}
}
@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr;}
}

/* ── Credit tracker ───────────────────────────────────────── */
.credit-table { width:100%;border-collapse:collapse; }
.credit-table th { background:rgba(255,255,255,.04);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:10px 14px;text-align:left;white-space:nowrap; }
.credit-table td { padding:11px 14px;border-top:1px solid var(--border);font-size:.83rem;vertical-align:middle; }
.credit-table tfoot td { background:rgba(0,0,0,.15);font-size:.82rem; }
.credit-table tr:hover td { background:rgba(255,255,255,.02); }
.credit-badge { display:inline-block;padding:1px 7px;border-radius:99px;font-size:.66rem;font-weight:700;margin-left:4px; }
.credit-badge-apr { background:rgba(180,80,60,.2);color:var(--clay-lt); }
/* transaction type pills */
.tx-type-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s;}
.tx-type-charge{background:rgba(180,80,60,.08);color:var(--clay-lt);border-color:rgba(180,80,60,.2);}
.tx-type-payment{background:rgba(90,140,100,.08);color:var(--sage);border-color:rgba(90,140,100,.2);}
.tx-type-fee{background:rgba(160,120,60,.08);color:var(--gold-h);border-color:rgba(160,120,60,.2);}
.tx-type-interest{background:rgba(120,80,160,.08);color:#a080d0;border-color:rgba(120,80,160,.2);}
.tx-type-refund{background:rgba(60,120,160,.08);color:#70a8c8;border-color:rgba(60,120,160,.2);}
.tx-type-active.tx-type-charge{background:rgba(180,80,60,.22);color:var(--clay-lt);border-color:var(--clay);}
.tx-type-active.tx-type-payment{background:rgba(90,140,100,.22);color:var(--sage);border-color:var(--sage);}
.tx-type-active.tx-type-fee{background:rgba(160,120,60,.22);color:var(--gold-h);border-color:var(--gold-h);}
.tx-type-active.tx-type-interest{background:rgba(120,80,160,.22);color:#a080d0;border-color:#a080d0;}
.tx-type-active.tx-type-refund{background:rgba(60,120,160,.22);color:#70a8c8;border-color:#70a8c8;}
/* field helpers for credit form */
.field-label{display:block;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;}
.field-input{background:var(--surface-0);border:1px solid var(--border);color:var(--cream);padding:8px 10px;border-radius:var(--radius);font-size:.83rem;font-family:inherit;}
.field-input:focus{outline:none;border-color:var(--oak);}
.util-bar-wrap { height:4px;background:rgba(255,255,255,.08);border-radius:2px;width:60px;margin-bottom:2px; }
.util-bar { height:4px;border-radius:2px;transition:width .3s; }
.tbl-action { background:none;border:none;font-size:.75rem;color:var(--gold-h);cursor:pointer;font-family:inherit;padding:0 6px 0 0;text-decoration:none; }
.tbl-action:hover { text-decoration:underline; }
.form-optional { font-size:.68rem;color:var(--text-muted);text-transform:none;letter-spacing:0;font-weight:400; }

/* ── Quartermaster ────────────────────────────────────────── */
/* Location badges */
.qm-loc-badge { display:inline-block;padding:1px 8px;border-radius:99px;font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase; }
.qm-loc-pantry  { background:rgba(92,61,36,.3);color:var(--clay-lt); }
.qm-loc-fridge  { background:rgba(40,90,70,.3);color:var(--sage); }
.qm-loc-freezer { background:rgba(40,60,110,.3);color:#7aaad4; }
.qm-loc-freezer2 { background:rgba(30,80,100,.3);color:#79bcc4; }
.qm-loc-other   { background:rgba(80,80,80,.2);color:var(--text-muted); }

/* Low stock row tint */
.qm-low-stock-row td { background:rgba(120,50,30,.07) !important; }
.qm-stock-warn { color:var(--clay-lt);margin-left:5px;font-size:.82rem; }

/* Consume inline row */
.qm-consume-row { display:none; }
.qm-consume-row td { background:var(--surface-2);border-bottom:1px solid var(--border);padding:6px 10px !important; }

/* Pantry table overrides (fewer cols than summary) */
#pantry-table { min-width:680px; }
#pantry-table thead th { white-space:normal; }

/* Meal badge */
.qm-meal-badge { display:inline-block;padding:1px 7px;border-radius:3px;font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-right:4px; }
.qm-meal-breakfast { background:rgba(200,160,60,.18);color:#c8a040; }
.qm-meal-lunch     { background:rgba(60,140,80,.18);color:var(--sage); }
.qm-meal-dinner    { background:rgba(92,61,36,.3);color:var(--clay-lt); }
.qm-meal-snack     { background:rgba(100,60,130,.2);color:#b090d0; }
.qm-meal-other     { background:rgba(80,80,80,.2);color:var(--text-muted); }

/* Weekly meal grid */
.qm-week-wrap { overflow-x:auto;-webkit-overflow-scrolling:touch; }
.qm-week-grid { display:grid;grid-template-columns:repeat(7,1fr);gap:8px;min-width:700px; }
.qm-day-col { background:var(--surface-1);border:1px solid var(--border);border-radius:6px;padding:10px;min-height:160px;display:flex;flex-direction:column;gap:6px; }
.qm-day-today { border-color:var(--oak);background:rgba(92,61,36,.12); }
.qm-day-header { display:flex;align-items:baseline;gap:6px;margin-bottom:4px;padding-bottom:6px;border-bottom:1px solid var(--border); }
.qm-day-name { font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted); }
.qm-day-num { font-family:var(--font-display);font-size:1.3rem;color:var(--text-sec);line-height:1; }
.qm-today-num { color:var(--gold-h); }
.qm-meals-list { display:flex;flex-direction:column;gap:5px;flex:1; }
.qm-meal-entry { background:var(--surface-0);border:1px solid var(--border);border-radius:4px;padding:5px 7px;font-size:.78rem;position:relative; }
.qm-meal-name { display:block;color:var(--cream);margin-top:2px;font-size:.82rem; }
.qm-meal-servings { font-size:.68rem;color:var(--text-muted); }
.qm-meal-notes { display:block;font-size:.72rem;color:var(--text-muted);font-style:italic;margin-top:1px; }
.qm-meal-del { position:absolute;top:4px;right:5px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:0;line-height:1; }
.qm-meal-del:hover { color:#c47a5a; }
.qm-add-meal-btn { margin-top:auto;background:transparent;border:1px dashed var(--border);color:var(--text-muted);border-radius:4px;padding:4px;font-size:.72rem;cursor:pointer;width:100%;transition:all .15s; }
.qm-add-meal-btn:hover { border-color:var(--oak);color:var(--clay-lt); }
.qm-add-meal-form { border-top:1px solid var(--border);padding-top:8px;margin-top:4px; }

/* Shopping list */
.qm-shop-row { display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid rgba(92,61,36,.12); }
.qm-shop-row:last-child { border-bottom:none; }
.qm-shop-checked { opacity:.6; }
.qm-inactive-row td { opacity:.55; }
.qm-check-btn { width:20px;height:20px;border-radius:50%;border:2px solid var(--border);background:transparent;cursor:pointer;flex-shrink:0;transition:all .15s; }
.qm-check-btn:hover { border-color:var(--sage);background:rgba(80,120,80,.15); }
.qm-check-done { border-color:var(--sage);background:var(--sage); }
.qm-check-done::after { content:'✓';display:block;text-align:center;font-size:.65rem;color:var(--surface-1);line-height:16px;font-weight:700; }
.qm-restock-form { background:var(--surface-2);border-bottom:1px solid var(--border); }
