*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg-1:#fdf6ec;
  --bg-2:#fdebd0;
  --bg-3:#fdf0e0;
  --accent:#c47c2b;
  --accent-hover:#a8661f;
  --accent-soft:#fdebd0;
  --accent-glow:rgba(196,124,43,0.15);
  --text-main:#1a1a1a;
  --text-heading:#3d2b1f;
}
body{font-family:system-ui,sans-serif;color:var(--text-main);background:linear-gradient(145deg,var(--bg-1) 0%,var(--bg-2) 50%,var(--bg-3) 100%);min-height:100vh;font-size:15px;}
h1{font-size:20px;font-weight:500;color:var(--text-heading);}
h2{font-size:18px;font-weight:500;color:var(--text-heading);}
h3{font-size:15px;font-weight:500;color:var(--text-heading);}
.app{max-width:820px;margin:0 auto;padding:0.75rem;}
.nav{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:1.25rem;border-bottom:1px solid #e8d5be;padding-bottom:1rem;}
.nav-btn{flex:0 0 calc(25% - 8px);background:#fff8f0;border:1px solid #e0c9b0;border-radius:8px;padding:10px 6px;cursor:pointer;font-size:12px;color:#7a5c3e;transition:all 0.15s;text-align:center;line-height:1.3;min-height:44px;}
.nav-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.nav-btn:hover:not(.active){background:var(--accent-soft);border-color:#c8a87a;}
.card{background:#fffdf9;border:1px solid #e8d5be;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px rgba(180,130,80,0.08);}
input[type=text],select,textarea{width:100%;padding:11px 13px;border:1.5px solid #c8a87a;border-radius:8px;font-size:15px;background:#fff;color:#2c1d0e;font-family:inherit;}
input[type=text]:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
input[type=text]::placeholder,textarea::placeholder{color:#b09070;}
button{cursor:pointer;font-family:inherit;font-size:14px;}
.btn{padding:9px 14px;border-radius:8px;border:1px solid #d4b896;background:#fff8f0;color:#3d2b1f;}
.btn:hover{background:var(--accent-soft);border-color:#c8a87a;}
.btn:active{transform:scale(0.97);}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-primary:hover{background:var(--accent-hover);}
.btn-green{background:#2d8a4e;color:#fff;border-color:#2d8a4e;}
.btn-green:hover{background:#236e3e;}
.btn-sm{padding:7px 12px;font-size:13px;min-height:34px;border:1.5px solid #c8a87a;}
.btn-danger{color:#a32d2d;border-color:#e8b4b4;background:#fff5f5;}
.btn-danger:hover{background:#fcebeb;}
.btn-full{width:100%;padding:13px;font-size:15px;margin-bottom:1.25rem;}
.tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:13px;border:1px solid #e0c9b0;background:#fff8f0;color:#5c3d1e;}
.tag-remove{background:none;border:none;cursor:pointer;font-size:18px;line-height:1;color:#9a7a5a;padding:0;}
.stock-bar-wrap{width:80px;flex-shrink:0;}
.stock-bar-bg{height:6px;border-radius:3px;background:#eddfc8;width:100%;}
.stock-bar-fill{height:6px;border-radius:3px;transition:width 0.2s;}
.stock-label{font-size:11px;color:#9a7a5a;margin-top:2px;text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:3px;}
.stock-slider{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:5px;background:linear-gradient(to right,#A32D2D,#D85A30,#BA7517,#639922,#1D9E75);outline:none;cursor:pointer;touch-action:none;}
.stock-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:32px;height:32px;border-radius:50%;background:#fff;border:3px solid #2d8a4e;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.2);}
.stock-slider::-moz-range-thumb{width:32px;height:32px;border-radius:50%;background:#fff;border:3px solid #2d8a4e;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.2);}
.stock-slider::-moz-range-track{height:10px;border-radius:5px;background:linear-gradient(to right,#A32D2D,#D85A30,#BA7517,#639922,#1D9E75);}
.ing-row{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid #eddfc8;}
.ing-row:last-child{border-bottom:none;}
.ing-row-top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.ing-row-stock{display:flex;align-items:center;gap:10px;padding:2px 4px 2px 0;}
.ing-row-stock .stock-slider{flex:1;height:8px;}
.ing-row-stock .stock-slider::-webkit-slider-thumb{width:24px;height:24px;border-width:2px;}
.ing-row-stock .stock-slider::-moz-range-thumb{width:24px;height:24px;border-width:2px;}
.ing-row-stock .stock-slider::-moz-range-track{height:8px;}
.ing-row-stock-val{font-size:12px;color:#5c3d1e;font-weight:500;min-width:84px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;}
.ing-row-actions{display:flex;gap:6px;}
.shop-item{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid #eddfc8;}
.shop-item:last-child{border-bottom:none;}
.shop-item-top{display:flex;align-items:center;justify-content:space-between;}
.shop-item-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.recipe-card{background:#fffdf9;border:1px solid #e8d5be;border-radius:12px;padding:1rem;margin-bottom:10px;cursor:pointer;transition:border-color 0.15s;}
.recipe-card:hover{border-color:var(--accent);}
.recipe-card.close-match{border-left:3px solid var(--accent);}
.match-bar{height:6px;border-radius:3px;background:#eddfc8;margin:8px 0;}
.match-fill{height:6px;border-radius:3px;background:#1D9E75;}
.chip{display:inline-block;padding:4px 10px;border-radius:12px;font-size:13px;margin:3px;}
.chip-need{background:#FAEEDA;color:#633806;}
.chip-have{background:#EAF3DE;color:#27500A;}
.loader{text-align:center;padding:2rem;color:#9a7a5a;font-size:14px;}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;}
.add-row{display:flex;gap:8px;margin-bottom:1rem;}
.add-row input{flex:1;}
.empty{color:#9a7a5a;font-size:14px;text-align:center;padding:1.5rem;}
.tags-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.walmart-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:#0071CE;text-decoration:none;padding:7px 12px;border:1px solid #0071CE;border-radius:8px;white-space:nowrap;font-weight:500;background:#f0f7ff;}
.walmart-link:hover{background:#dceeff;}
.target-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:#CC0000;text-decoration:none;padding:7px 12px;border:1px solid #CC0000;border-radius:8px;white-space:nowrap;font-weight:500;background:#fff0f0;}
.target-link:hover{background:#ffdcdc;}
.amazon-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:#B45309;text-decoration:none;padding:7px 12px;border:1px solid #FF9900;border-radius:8px;white-space:nowrap;font-weight:500;background:#fff7e6;}
.amazon-link:hover{background:#ffe8bf;}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fdebd0;border:1px solid #e0c9b0;font-size:13px;font-weight:500;flex-shrink:0;color:#7a4f1e;}
.detail-step{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;}
.timer-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;background:#fdebd0;color:#7a4f1e;border:1px solid #e0c9b0;margin-top:4px;}
.ing-table{width:100%;font-size:13px;border-collapse:collapse;}
.ing-table td{padding:6px 4px;border-bottom:1px solid #eddfc8;}
.ing-table tr:last-child td{border-bottom:none;}
.ing-table td:last-child{text-align:right;color:#5c3d1e;font-weight:500;}
.mood-btn{padding:7px 14px;border-radius:20px;border:1.5px solid #e0c9b0;background:#fff8f0;color:#7a5c3e;font-size:13px;cursor:pointer;transition:all 0.15s;}
.mood-btn:hover{background:var(--accent-soft);border-color:#c8a87a;}
.mood-btn.selected{background:var(--accent);color:#fff;border-color:var(--accent);}
.result-count-btn{padding:6px 16px;border-radius:20px;border:1.5px solid #e0c9b0;background:#fff8f0;color:#7a5c3e;font-size:13px;cursor:pointer;transition:all 0.15s;}
.result-count-btn:hover{background:var(--accent-soft);}
.result-count-btn.selected{background:var(--accent);color:#fff;border-color:var(--accent);}
.search-wrap{position:relative;margin-bottom:10px;}
.search-wrap input{padding-left:36px;}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none;}
.error-box{background:#fff5f5;border:1.5px solid #e8b4b4;border-radius:8px;padding:12px;font-size:13px;color:#a32d2d;margin-top:8px;}
.error-box button{margin-top:8px;width:100%;padding:9px;font-size:13px;font-weight:500;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;}
.field-wrap{display:flex;flex-direction:column;gap:6px;}
.field-label{font-size:13px;font-weight:500;color:#5c3d1e;}
.field-hint{font-size:12px;color:#9a7a5a;}
.sug-item{padding:10px 14px;font-size:14px;cursor:pointer;color:#3d2b1f;border-bottom:1px solid #f0e0cc;}
.sug-item:last-child{border-bottom:none;}
.sug-item:hover,.sug-item.active{background:var(--accent-soft);}
.sync-bar{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:8px;font-size:12px;margin-bottom:1rem;border:1px solid #e0c9b0;background:#fff8f0;}
.sync-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background 0.3s;}
.scan-box{border:2px dashed #d4b896;border-radius:12px;padding:1.5rem;text-align:center;margin-bottom:1rem;background:#fffaf4;}
.scan-preview{width:100%;max-height:260px;object-fit:cover;border-radius:8px;margin-bottom:10px;display:none;}
.scan-result-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #eddfc8;}
.scan-result-item:last-child{border-bottom:none;}
.scan-result-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0;accent-color:var(--accent);}
.scan-result-item-ext{padding:10px 0;border-bottom:1px solid #eddfc8;}
.scan-result-item-ext:last-child{border-bottom:none;}
.scan-item-top{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.scan-item-top input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0;accent-color:var(--accent);}
.scan-item-name{flex:1;font-size:14px;font-weight:500;color:#3d2b1f;}
.scan-item-controls{display:flex;gap:8px;padding-left:26px;}
.scan-item-field{display:flex;flex-direction:column;gap:2px;flex:1;}
.scan-item-label{font-size:11px;color:#9a7a5a;font-weight:500;}
.scan-select{padding:6px 8px;border:1.5px solid #c8a87a;border-radius:6px;font-size:13px;background:#fff;color:#2c1d0e;font-family:inherit;}
.scan-select:focus{outline:none;border-color:var(--accent);}
.need-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #eddfc8;gap:8px;}
.need-row:last-child{border-bottom:none;}
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);background:#2d8a4e;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;z-index:999;opacity:0;transition:opacity 0.3s;pointer-events:none;white-space:nowrap;display:inline-flex;align-items:center;gap:8px;}
.toast-undo{background:rgba(255,255,255,0.22);border:1px solid rgba(255,255,255,0.4);color:#fff;padding:4px 12px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;margin-left:6px;font-family:inherit;transition:background 0.15s;}
.toast-undo:hover{background:rgba(255,255,255,0.35);}
#auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;}
.auth-card{background:#fffdf9;border:1px solid #e8d5be;border-radius:16px;padding:2rem;width:100%;max-width:400px;box-shadow:0 4px 20px rgba(180,130,80,0.12);}
.auth-card h1{text-align:center;margin-bottom:4px;}
.auth-card .subtitle{text-align:center;font-size:13px;color:#9a7a5a;margin-bottom:1.5rem;}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:1.25rem;}
.auth-tab{padding:10px;border-radius:8px;border:1px solid #e0c9b0;background:#fff8f0;color:#7a5c3e;font-size:14px;cursor:pointer;text-align:center;font-family:inherit;font-weight:500;}
.auth-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.auth-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.auth-field label{font-size:13px;font-weight:500;color:#5c3d1e;}
.auth-submit{width:100%;padding:13px;font-size:15px;font-weight:600;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-family:inherit;}
.auth-submit:hover{background:var(--accent-hover);}
.auth-submit:disabled{opacity:0.6;cursor:not-allowed;}
.auth-error{background:#fff5f5;border:1.5px solid #e8b4b4;border-radius:8px;padding:10px;font-size:13px;color:#a32d2d;margin-bottom:14px;display:none;}
.auth-success{background:#f0faf4;border:1.5px solid #9FE1CB;border-radius:8px;padding:10px;font-size:13px;color:#1D9E75;margin-bottom:14px;display:none;}
.auth-forgot{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;padding:0;margin-top:8px;text-align:center;display:block;width:100%;font-family:inherit;}
.user-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0.75rem;padding:8px 12px;border-radius:8px;background:#f0faf4;border:1px solid #9FE1CB;font-size:13px;color:#1D9E75;}
.user-bar button{background:none;border:1px solid #e0c9b0;border-radius:6px;padding:5px 12px;font-size:12px;color:#7a5c3e;cursor:pointer;font-family:inherit;}
.user-bar button:hover{background:var(--accent-soft);}
#modal-wrap,#detail-modal-wrap{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(60,30,10,0.5);z-index:100;align-items:flex-end;justify-content:center;padding:0;}
.modal-inner{background:#fffdf9;border:1px solid #e8d5be;border-radius:12px 12px 0 0;padding:1.5rem;width:100%;max-width:600px;max-height:92vh;overflow-y:auto;}
@media(min-width:500px){
  #modal-wrap,#detail-modal-wrap{align-items:center;padding:1rem;}
  .modal-inner{border-radius:12px;}
  .ing-row{flex-direction:row;align-items:center;}
  .ing-row-top{flex:1;}
  .ing-row-stock{flex:0 0 230px;padding:0;}
  .ing-row-actions{margin-left:auto;}
  .shop-item{flex-direction:row;align-items:center;}
  .shop-item-top{flex:1;}
  .shop-item-actions{margin-left:auto;}
  .btn-sm{padding:8px 16px;font-size:14px;}
}
@media(min-width:680px){
  .nav{gap:8px;}
  .nav-btn{padding:10px 8px;font-size:13px;min-height:0;}
}
.batch-item{display:flex;align-items:center;gap:8px;background:#fdf5eb;border:1px solid #e0c9b0;border-radius:8px;padding:8px 10px;font-size:13px;}
.batch-item .bi-name{font-weight:600;color:#5c3d1e;}
.batch-item .bi-cat{color:#9a7a5a;font-size:11px;}
.batch-item .bi-stock{margin-left:auto;font-size:11px;font-weight:500;}
.batch-item .bi-remove{background:none;border:none;color:#a32d2d;cursor:pointer;font-size:16px;padding:0 4px;line-height:1;}
.rating-wrap{display:flex;align-items:center;gap:4px;margin:8px 0;}
.rating-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid #e0c9b0;background:#fff8f0;color:#7a5c3e;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.15s;padding:0;display:flex;align-items:center;justify-content:center;}
.rating-btn:hover{background:var(--accent-soft);border-color:#c8a87a;}
.rating-btn.rated{background:var(--accent);color:#fff;border-color:var(--accent);}
.share-wrap{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.share-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 12px;border-radius:8px;border:1px solid #e0c9b0;background:#fff8f0;color:#5c3d1e;font-size:13px;cursor:pointer;font-family:inherit;transition:all 0.15s;}
.share-btn:hover{background:var(--accent-soft);border-color:#c8a87a;}
.quickadd-item{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;border-radius:20px;border:1.5px solid #e0c9b0;background:#fff8f0;color:#5c3d1e;font-size:13px;cursor:pointer;transition:all 0.15s;font-family:inherit;}
.quickadd-item:hover{background:var(--accent-soft);border-color:#c8a87a;}
.quickadd-item.in-pantry{background:#EAF3DE;border-color:#9FE1CB;color:#27500A;cursor:default;}
.quickadd-cat-section{margin-bottom:1rem;}
.filter-card{background:#fffdf9;border:1px solid #e8d5be;border-radius:12px;padding:12px 14px;margin-bottom:1rem;}
.filter-card summary{cursor:pointer;font-size:14px;font-weight:500;color:#3d2b1f;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:4px 0;}
.filter-card summary::-webkit-details-marker{display:none;}
.filter-card summary::after{content:'▾';font-size:12px;color:#9a7a5a;transition:transform 0.15s;flex-shrink:0;}
.filter-card[open] summary::after{transform:rotate(180deg);}
.f-summary{font-size:12px;color:#9a7a5a;font-weight:400;flex:1;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.filter-card[open] .f-summary{display:none;}
.f-row{margin-top:14px;}
.f-row-inline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;}
.f-label{font-size:12px;font-weight:500;color:#5c3d1e;margin-bottom:6px;display:block;}
.f-chips{display:flex;flex-wrap:wrap;gap:6px;}
.f-chip{padding:6px 12px;border-radius:18px;border:1.5px solid #e0c9b0;background:#fff8f0;color:#7a5c3e;font-size:12px;cursor:pointer;transition:all 0.15s;font-family:inherit;}
.f-chip:hover{background:var(--accent-soft);}
.f-chip.selected{background:#2d8a4e;color:#fff;border-color:#2d8a4e;}
.f-num{width:70px;padding:7px 10px;border:1.5px solid #c8a87a;border-radius:8px;font-size:14px;background:#fff;color:#2c1d0e;font-family:inherit;}
.f-num:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.f-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#3d2b1f;user-select:none;}
.f-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#2d8a4e;cursor:pointer;flex-shrink:0;}
.f-reset{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:4px 0;margin-top:10px;font-family:inherit;text-decoration:underline;}
.meta-row{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 10px;}
.meta-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 9px;border-radius:10px;background:#fdebd0;color:#7a4f1e;border:1px solid #e0c9b0;white-space:nowrap;font-weight:500;}
.mp-day{background:#fffdf9;border:1px solid #e8d5be;border-radius:12px;padding:12px 14px;margin-bottom:10px;box-shadow:0 1px 3px rgba(180,130,80,0.08);}
.mp-day.today{border-color:var(--accent);background:#fffaf0;}
.mp-day-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;}
.mp-day-title{font-size:14px;font-weight:600;color:#3d2b1f;}
.mp-day-title .mp-day-date{font-weight:400;color:#9a7a5a;font-size:12px;margin-left:6px;}
.mp-day-today-tag{display:inline-block;font-size:10px;padding:2px 7px;border-radius:10px;background:var(--accent);color:#fff;font-weight:500;margin-left:6px;vertical-align:middle;}
.mp-recipe{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid #eddfc8;border-radius:8px;background:#fff8f0;margin-bottom:6px;}
.mp-recipe:last-child{margin-bottom:0;}
.mp-recipe-name{font-size:13px;color:#3d2b1f;flex:1;cursor:pointer;}
.mp-recipe-name:hover{color:var(--accent);}
.mp-recipe-meta{font-size:11px;color:#9a7a5a;margin-top:2px;}
.mp-remove{background:none;border:none;color:#a32d2d;cursor:pointer;font-size:18px;padding:0 4px;line-height:1;flex-shrink:0;}
.mp-add-btn{margin-top:4px;padding:8px 12px;font-size:13px;background:#fff8f0;border:1.5px dashed #c8a87a;color:#7a5c3e;border-radius:8px;cursor:pointer;width:100%;font-family:inherit;}
.mp-add-btn:hover{background:var(--accent-soft);border-style:solid;}
.mp-empty{font-size:12px;color:#b09070;font-style:italic;padding:4px 0 2px;}
.mp-picker-item{padding:10px 14px;font-size:13px;cursor:pointer;color:#3d2b1f;border-bottom:1px solid #f0e0cc;}
.mp-picker-item:hover{background:var(--accent-soft);}
.mp-picker-item:last-child{border-bottom:none;}
.settings-cat-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #eddfc8;}
.settings-cat-row:last-child{border-bottom:none;}
.settings-cat-name{font-size:13px;color:#3d2b1f;}
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:10px;}
.theme-swatch{border:1.5px solid #e0c9b0;border-radius:10px;padding:10px 8px;cursor:pointer;background:#fff8f0;text-align:center;transition:all 0.15s;font-family:inherit;}
.theme-swatch:hover{border-color:#c8a87a;}
.theme-swatch.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow);}
.theme-preview{height:46px;border-radius:8px;margin-bottom:8px;position:relative;overflow:hidden;border:1px solid rgba(0,0,0,0.05);}
.theme-preview-tab{position:absolute;bottom:5px;left:5px;width:28px;height:10px;border-radius:4px;}
.theme-name{font-size:12px;color:#3d2b1f;font-weight:500;}
.color-picker-row{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap;}
.color-picker-row input[type=color]{width:42px;height:32px;border:1.5px solid #c8a87a;border-radius:6px;padding:2px;cursor:pointer;background:#fff;}
.color-picker-row .cp-label{font-size:13px;color:#5c3d1e;font-weight:500;min-width:95px;}
.mp-sug-card{background:#fffdf9;border:1px solid #e8d5be;border-radius:10px;padding:12px;margin-bottom:10px;}
.mp-sug-card-name{font-size:14px;font-weight:600;color:#3d2b1f;margin-bottom:4px;}
.mp-sug-card-desc{font-size:12px;color:#9a7a5a;margin-bottom:8px;line-height:1.45;}
.mp-sug-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;align-items:center;}
.mp-sug-day-select{padding:6px 8px;border:1.5px solid #c8a87a;border-radius:6px;font-size:12px;background:#fff;color:#2c1d0e;font-family:inherit;flex:1;min-width:130px;}

/* ---------- Visual polish & new features ---------- */
/* Typography contrast */
h1{font-size:22px;font-weight:700;letter-spacing:-0.01em;}
h2{font-size:19px;font-weight:700;letter-spacing:-0.01em;}
h3{font-size:15px;font-weight:600;}
.section-header h2{position:relative;padding-left:11px;}
.section-header h2::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:70%;background:var(--accent);border-radius:2px;}

/* Nav: primary tabs with bottom accent bar, not filled buttons */
.nav{position:relative;align-items:flex-end;}
.nav-btn{position:relative;background:transparent;border:1px solid transparent;box-shadow:none;transition:color 0.15s,background 0.15s;}
.nav-btn:hover:not(.active){background:rgba(196,124,43,0.08);border-color:transparent;}
.nav-btn.active{background:transparent;color:var(--accent);border-color:transparent;font-weight:600;}
.nav-btn.active::after{content:'';position:absolute;bottom:-1px;left:12%;right:12%;height:3px;border-radius:2px 2px 0 0;background:var(--accent);}
.nav-primary{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;flex:1;}
.nav-primary .nav-btn{flex:1 1 0;min-width:80px;}
.nav-more-wrap{position:relative;flex-shrink:0;}
.nav-more-btn{background:#fff8f0;border:1px solid #e0c9b0;border-radius:8px;padding:10px 14px;cursor:pointer;font-size:12px;color:#7a5c3e;font-family:inherit;display:inline-flex;align-items:center;gap:6px;min-height:44px;transition:all 0.15s;}
.nav-more-btn:hover,.nav-more-btn.open{background:var(--accent-soft);border-color:#c8a87a;color:#3d2b1f;}
.nav-more-btn.has-active{color:var(--accent);font-weight:600;}
.nav-more-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;z-index:60;background:#fffdf9;border:1px solid #e8d5be;border-radius:10px;box-shadow:0 6px 24px rgba(60,30,10,0.18);padding:6px;min-width:170px;}
.nav-more-menu.open{display:block;}
.nav-more-menu .nav-btn{display:block;width:100%;flex:none;min-width:0;text-align:left;border-radius:6px;padding:10px 12px;font-size:13px;}
.nav-more-menu .nav-btn.active{background:var(--accent-soft);color:var(--accent);}
.nav-more-menu .nav-btn.active::after{display:none;}

/* Card hover/press animations */
.recipe-card{transition:transform 0.15s,box-shadow 0.15s,border-color 0.15s;}
.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(180,130,80,0.16);}
.recipe-card:active{transform:translateY(0);box-shadow:0 1px 3px rgba(180,130,80,0.1);}
.mp-sug-card{transition:transform 0.15s,box-shadow 0.15s;}
.mp-sug-card:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(180,130,80,0.12);}

/* Sync bar fade */
.sync-bar{transition:opacity 0.6s ease,max-height 0.6s ease,margin 0.6s ease,padding 0.6s ease;overflow:hidden;max-height:60px;}
.sync-bar.faded{opacity:0;max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0;border:none;}

/* Auth screen decorative background */
#auth-screen{position:relative;overflow:hidden;}
#auth-screen::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 12% 18%,rgba(196,124,43,0.08) 0,transparent 45%),
  radial-gradient(circle at 88% 82%,rgba(45,138,78,0.07) 0,transparent 45%),
  radial-gradient(circle at 82% 14%,rgba(217,79,90,0.06) 0,transparent 40%);
  pointer-events:none;z-index:0;}
#auth-screen .auth-card{position:relative;z-index:1;}
.auth-emoji-cluster{position:absolute;font-size:22px;opacity:0.28;line-height:1;pointer-events:none;user-select:none;z-index:0;}

/* Toast with icon */
.toast{display:inline-flex;align-items:center;gap:8px;}
.toast-icon{display:inline-flex;width:18px;height:18px;border-radius:50%;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:rgba(255,255,255,0.25);flex-shrink:0;}

/* 5-star rating */
.star-rating{display:inline-flex;align-items:center;gap:3px;}
.star-btn{background:none;border:none;font-size:28px;line-height:1;padding:2px 3px;cursor:pointer;color:#d8c4a6;transition:color 0.12s,transform 0.12s;}
.star-btn:hover{transform:scale(1.12);}
.star-btn.filled{color:#e8a83a;}
.star-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px;}

/* Pantry stock status chip */
.stock-summary{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:0.75rem;font-size:12px;}
.stock-summary-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:14px;background:#fff8f0;border:1px solid #e0c9b0;color:#5c3d1e;font-weight:500;}
.stock-summary-chip .dot{width:8px;height:8px;border-radius:50%;}

/* Pantry category chips — coloured & with count badges */
.cat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:18px;border:1.5px solid transparent;background:#fff8f0;color:#5c3d1e;cursor:pointer;font-size:13px;transition:all 0.15s;font-family:inherit;}
.cat-chip:hover{filter:brightness(0.97);}
.cat-chip.active{box-shadow:0 0 0 2px var(--accent);}
.cat-count{display:inline-flex;min-width:20px;padding:0 6px;height:18px;border-radius:9px;background:rgba(0,0,0,0.08);font-size:11px;font-weight:600;align-items:center;justify-content:center;}

/* Frequent item border accent */
.ing-row.frequent{border-left:3px solid var(--accent);padding-left:10px;margin-left:-13px;border-radius:2px;}

/* Recipe card thumbnail */
.recipe-thumb{width:48px;height:48px;border-radius:10px;background:var(--accent-soft);display:inline-flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;border:1px solid #e8d5be;}
.recipe-card-head{display:flex;gap:12px;align-items:flex-start;}
.recipe-card-head-body{flex:1;min-width:0;}

/* Have/need pill layout for ingredient table */
.ing-pill-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #eddfc8;}
.ing-pill-row:last-child{border-bottom:none;}
.ing-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;flex-shrink:0;min-width:64px;justify-content:center;}
.ing-pill.have{background:#EAF3DE;color:#27500A;border:1px solid #b8daa0;}
.ing-pill.need{background:#FAEEDA;color:#633806;border:1px solid #e7c9a4;}
.ing-pill-name{flex:1;font-size:13px;color:#3d2b1f;min-width:0;overflow:hidden;text-overflow:ellipsis;}
.ing-pill-amt{font-size:12px;color:#5c3d1e;font-weight:500;white-space:nowrap;}
.ing-pill-stock{display:flex;align-items:center;gap:3px;}

/* Filter summary chips */
.f-summary-chips{display:flex;flex-wrap:wrap;gap:4px;flex:1;justify-content:flex-end;max-width:70%;}
.f-sum-chip{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(196,124,43,0.25);white-space:nowrap;font-weight:500;}
.filter-card[open] .f-summary-chips{display:none;}

/* Count slider */
.count-slider-wrap{display:flex;align-items:center;gap:10px;margin-top:8px;}
.count-slider-wrap input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:#e8d5be;outline:none;cursor:pointer;}
.count-slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid #fff;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.2);}
.count-slider-wrap input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);border:2px solid #fff;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.2);}
.count-slider-value{min-width:34px;text-align:center;font-size:14px;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:4px 10px;border-radius:12px;}

/* Sticky modal header (recipe detail) */
#detail-modal-content{padding-top:0;}
.detail-sticky-head{position:sticky;top:0;background:#fffdf9;z-index:5;margin:0 -1.5rem 0;padding:14px 1.5rem 10px;border-bottom:1px solid #eddfc8;display:flex;gap:10px;align-items:center;}
.detail-sticky-head h2{flex:1;min-width:0;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0;}
.detail-sticky-head button{flex-shrink:0;}
.detail-close{background:none;border:none;font-size:22px;color:#9a7a5a;padding:4px 8px;line-height:1;cursor:pointer;}
.detail-sticky-action{padding:7px 12px;font-size:13px;border-radius:8px;border:1.5px solid #c8a87a;background:#fff8f0;color:#3d2b1f;cursor:pointer;font-family:inherit;}
.detail-sticky-action.primary{background:#2d8a4e;color:#fff;border-color:#2d8a4e;}
.detail-sticky-action.primary:hover{background:#236e3e;}
.detail-sticky-action.saved{background:#fdebd0;color:#7a4f1e;border-color:#e0c9b0;}

/* Onboarding card */
.onboard-card{background:linear-gradient(145deg,#fffdf9,var(--accent-soft));border:1px solid #e8d5be;border-radius:14px;padding:1.25rem;text-align:center;margin-bottom:1rem;}
.onboard-card .illus{font-size:44px;margin-bottom:8px;line-height:1;}
.onboard-card h3{margin-bottom:4px;font-size:17px;}
.onboard-card p{font-size:13px;color:#9a7a5a;margin-bottom:14px;line-height:1.5;}
.onboard-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.onboard-btn{padding:10px 14px;border-radius:10px;border:1.5px solid var(--accent);background:#fff;color:var(--accent);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px;}
.onboard-btn:hover{background:var(--accent);color:#fff;}
.onboard-btn.primary{background:var(--accent);color:#fff;}
.onboard-btn.primary:hover{background:var(--accent-hover);}
.empty-illus{text-align:center;padding:1.5rem 1rem;}
.empty-illus .icon{font-size:40px;margin-bottom:8px;display:block;line-height:1;}
.empty-illus .title{font-size:15px;font-weight:600;color:#3d2b1f;margin-bottom:4px;}
.empty-illus .sub{font-size:13px;color:#9a7a5a;line-height:1.5;max-width:340px;margin:0 auto;}

/* Stock icon (accessibility: not color-only) */
.stock-icon{font-size:11px;margin-right:4px;}

/* ---------- Mobile polish: safe-area, hit targets, contrast, motion ---------- */

/* Safe-area insets for iOS home-indicator devices */
.app{padding-bottom:max(0.75rem,env(safe-area-inset-bottom));}
.modal-inner{padding-bottom:max(1.5rem,env(safe-area-inset-bottom));}
@media(max-width:499px){
  #modal-wrap .modal-inner,#detail-modal-wrap .modal-inner{padding-bottom:max(1.5rem,env(safe-area-inset-bottom));}
}

/* Prevent iOS Safari zoom-on-focus by forcing >=16px font on small viewports */
@media(max-width:500px){
  input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],select,textarea{font-size:16px;}
  .scan-select,.f-num,.mp-sug-day-select{font-size:16px;}
}

/* Modal scroll containment so background doesn't scroll once modal hits its edge */
.modal-inner{overscroll-behavior:contain;}

/* Bigger tap targets (>=44px) for icon-only remove buttons */
.tag-remove,.mp-remove,.bi-remove{min-width:32px;min-height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;}
.tag-remove:hover,.mp-remove:hover,.bi-remove:hover{background:rgba(163,45,45,0.08);}
.detail-close{min-width:40px;min-height:40px;}

/* Bigger rating buttons for one-handed use */
.rating-btn{width:38px;height:38px;font-size:14px;}

/* Bigger pantry-row stock slider thumb on mobile */
@media(max-width:680px){
  .ing-row-stock .stock-slider::-webkit-slider-thumb{width:32px;height:32px;}
  .ing-row-stock .stock-slider::-moz-range-thumb{width:32px;height:32px;}
}

/* Higher-contrast placeholder text (was #b09070, ~3.0:1 vs #fff — bumped to ~4.6:1) */
input::placeholder,textarea::placeholder{color:#8a6a48;opacity:1;}

/* Respect prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.001ms!important;animation-iteration-count:1!important;transition-duration:0.001ms!important;scroll-behavior:auto!important;}
  .recipe-card:hover,.mp-sug-card:hover{transform:none;}
}

/* Visible keyboard-focus ring on every interactive control */
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,details:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;}
.f-chip:focus-visible,.mood-btn:focus-visible,.cat-chip:focus-visible{outline-offset:3px;}

/* Loading skeletons */
@keyframes skeleton-shimmer{0%{background-position:-200px 0;}100%{background-position:calc(200px + 100%) 0;}}
.skeleton-list{display:flex;flex-direction:column;gap:4px;}
.skeleton-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid #eddfc8;}
.skeleton-row:last-child{border-bottom:none;}
.skeleton-line{height:14px;border-radius:6px;background:#eddfc8;background-image:linear-gradient(90deg,#eddfc8 0,#f7efe2 40%,#eddfc8 80%);background-size:200px 100%;background-repeat:no-repeat;animation:skeleton-shimmer 1.4s ease infinite;}
.skeleton-line.short{height:10px;}
@media(prefers-reduced-motion:reduce){.skeleton-line{animation:none;}}

/* Lazy-loaded scan preview shouldn't reflow on load */
.scan-preview{content-visibility:auto;}

