*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f7f5f0;--surface:#fff;--border:#e8e4dc;--text:#1a1714;--text-muted:#6b6560;
  --accent:#ff6b35;--accent2:#f7931e;--accent-light:#fff3ed;
  --skill-1:#4caf50;--skill-2:#8bc34a;--skill-3:#ff9800;--skill-4:#f44336;--skill-5:#9c27b0;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 12px rgba(0,0,0,.08);--shadow-lg:0 8px 24px rgba(0,0,0,.10);
  --radius:14px;--radius-sm:8px;--radius-pill:100px;
}
[data-theme=dark]{
  --bg:#0d0d0d;--surface:#161616;--border:#272727;--text:#ede9e3;--text-muted:#888;
  --accent-light:#2a1a10;--shadow-sm:0 1px 3px rgba(0,0,0,.35);--shadow-md:0 4px 12px rgba(0,0,0,.45);--shadow-lg:0 8px 28px rgba(0,0,0,.55);
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;transition:background .3s,color .3s}

/* Pages */
.page{display:none;min-height:100vh}.page.active{display:block}.page[hidden]{display:none!important}
.page-inner{max-width:600px;margin:0 auto;padding:40px 24px 80px}
.page-inner h2{font-size:28px;font-weight:800;margin-bottom:8px}
.page-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}

/* Input page redesign */
.input-page-hero{
  background:linear-gradient(160deg,#ff6b35 0%,#f7931e 50%,#ffcd3c 100%);
  padding:32px 24px 48px;text-align:center;position:relative
}
.btn-back-light{position:absolute;top:20px;left:20px;background:rgba(255,255,255,.2);border:1.5px solid rgba(255,255,255,.35);color:#fff;border-radius:var(--radius-pill);padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;backdrop-filter:blur(8px);transition:background .2s}
.btn-back-light:hover{background:rgba(255,255,255,.3)}
.input-page-title{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:8px}
.input-page-emoji{font-size:52px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.15))}
.input-page-title h2{font-size:30px;font-weight:900;color:#fff;letter-spacing:-.5px;margin:0}
.input-page-title p{font-size:15px;color:rgba(255,255,255,.8);font-weight:500}
.input-page-body{
  max-width:580px;margin:-24px auto 0;padding:0 20px 60px;
  display:flex;flex-direction:column;gap:16px;position:relative;z-index:1
}
.input-card{background:var(--surface);border-radius:20px;padding:20px;box-shadow:0 4px 24px rgba(0,0,0,.10),0 0 0 1px rgba(0,0,0,.04)}
.input-card-label{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:12px}
.filters-card{background:var(--surface);border-radius:20px;padding:20px;box-shadow:0 4px 24px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04)}
.filters-card-label{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.optional-tag{background:var(--bg);border-radius:var(--radius-pill);padding:2px 8px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}
.quick-add-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.quick-add-btn{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-pill);padding:4px 12px;font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}
.quick-add-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,107,53,.06)}

/* ── Dashboard ── */
#pageLanding{overflow-y:auto;background:var(--bg)}

/* Dashboard header */
.dash-header{
  background:linear-gradient(160deg,#ff6b35 0%,#f7931e 38%,#ffcd3c 100%);
  position:relative;overflow:hidden
}
.dash-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 85% 12%,rgba(255,255,255,.22) 0%,transparent 55%),radial-gradient(ellipse at 10% 88%,rgba(180,60,0,.18) 0%,transparent 50%);pointer-events:none}
[data-theme=dark] .dash-header{background:linear-gradient(160deg,#6b1e0a 0%,#7a3200 38%,#4a3000 100%)}
.dash-header-inner{padding:20px 20px 24px;position:relative;z-index:1;max-width:640px;margin:0 auto}

.dash-top-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.dash-greeting-wrap{display:flex;flex-direction:column;gap:3px}
.dash-hello{font-size:14px;color:rgba(255,255,255,.8);font-weight:600}
.dash-app-name{font-size:28px;font-weight:900;color:#fff;letter-spacing:-1px;text-shadow:0 2px 12px rgba(0,0,0,.15);line-height:1.1}
.dash-topbar{display:flex;gap:8px;padding-top:2px}
.dash-topbar-btn{background:rgba(255,255,255,.2);border:1.5px solid rgba(255,255,255,.3);color:#fff;border-radius:100px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;backdrop-filter:blur(8px);transition:background .2s}
.dash-topbar-btn:hover{background:rgba(255,255,255,.32)}

/* Stats strip */
.dash-stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:rgba(0,0,0,.18);backdrop-filter:blur(16px);border-radius:18px;border:1px solid rgba(255,255,255,.2);overflow:hidden}
.dash-stat-pill{display:flex;flex-direction:column;align-items:center;padding:13px 6px;border-right:1px solid rgba(255,255,255,.12);cursor:pointer;transition:background .2s}
.dash-stat-pill:last-child{border-right:none}
.dash-stat-pill:hover{background:rgba(255,255,255,.12)}
.dsp-icon{font-size:18px;margin-bottom:2px}
.dsp-val{font-size:20px;font-weight:900;color:#fff;line-height:1}
.dsp-label{font-size:10px;color:rgba(255,255,255,.7);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}

/* Dashboard body */
.dash-body{padding:20px 16px 80px;max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.dash-section{margin-bottom:24px}
.dash-section-hd{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:12px}
.dash-section-link{background:none;border:none;font-size:12px;font-weight:700;color:var(--accent);cursor:pointer;padding:0;text-transform:none;letter-spacing:0}

/* Cook action cards */
.dash-cook-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dash-cook-card{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;padding:18px 10px 14px;display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.dash-cook-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.10)}
.dash-cook-card:active{transform:scale(.97)}
.dash-cook-card.snap{border-top:3px solid #ff6b35}.dash-cook-card.snap:hover{border-color:#ff6b35}
.dash-cook-card.type{border-top:3px solid #8e44ad}.dash-cook-card.type:hover{border-color:#8e44ad}
.dash-cook-card.surprise{border-top:3px solid #27ae60}.dash-cook-card.surprise:hover{border-color:#27ae60}
.dcc-icon{font-size:30px;line-height:1}
.dcc-title{font-size:13px;font-weight:800;color:var(--text);line-height:1.2}
.dcc-desc{font-size:11px;color:var(--text-muted);font-weight:500;line-height:1.3}

/* Today card */
.dash-today-card{background:var(--surface);border-radius:18px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.04)}
.dash-today-hero{background:linear-gradient(135deg,#8e44ad,#3498db);padding:18px 16px;color:#fff}
.dash-today-label{font-size:11px;font-weight:700;opacity:.7;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.dash-today-name{font-size:19px;font-weight:900;letter-spacing:-.4px;margin-bottom:4px}
.dash-today-meta{font-size:12px;opacity:.8;font-weight:500}
.dash-today-actions{display:flex;gap:8px;padding:12px 14px}
.dash-today-btn{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:100px;padding:8px 12px;font-size:12px;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all .15s}
.dash-today-btn:hover{border-color:var(--accent);color:var(--accent)}
.dash-today-empty{background:var(--surface);border:1.5px dashed var(--border);border-radius:18px;padding:28px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.dash-today-empty-icon{font-size:36px}
.dash-today-empty p{font-size:14px;color:var(--text-muted);font-weight:500;margin:0}
.dash-link-btn{background:var(--accent);color:#fff;border:none;border-radius:100px;padding:8px 18px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .2s}
.dash-link-btn:hover{opacity:.88}

/* Recent activity */
.dash-recent-list{display:flex;flex-direction:column;gap:8px}
.dash-recent-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:13px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .18s}
.dash-recent-card:hover{border-color:var(--accent);transform:translateX(3px)}
.dash-recent-emoji{font-size:26px;flex-shrink:0;width:40px;height:40px;background:var(--bg);border-radius:12px;display:flex;align-items:center;justify-content:center}
.dash-recent-info{flex:1;min-width:0}
.dash-recent-title{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-recent-meta{font-size:12px;color:var(--text-muted);margin-top:2px}
.dash-recent-arrow{color:var(--text-muted);font-size:14px;flex-shrink:0;opacity:.5}
.dash-empty-msg{text-align:center;padding:20px;color:var(--text-muted);font-size:14px;background:var(--surface);border-radius:14px;border:1.5px dashed var(--border)}

/* Trending */
.dash-trending-tags{display:flex;flex-wrap:wrap;gap:8px}
.trending-tag{background:var(--surface);border:1.5px solid var(--border);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}
.trending-tag:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,107,53,.06)}

/* More grid */
.dash-more-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dash-more-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:16px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .2s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.dash-more-btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.dmb-icon{font-size:24px;line-height:1}
.dmb-label{font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}

/* Buttons */
.btn-back{background:none;border:none;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;padding:0;margin-bottom:24px;transition:color .15s}
.btn-back:hover{color:var(--accent)}
.btn-voice{background:rgba(255,107,53,.1);border:2px solid var(--accent);color:var(--accent);border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.btn-voice.listening{background:var(--accent);color:#fff;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.hint{font-size:14px;color:var(--text-muted);margin-bottom:16px}

/* Tag input */
.tag-input-wrapper{background:var(--surface);border-radius:var(--radius);border:2px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;min-height:56px;cursor:text;transition:border-color .2s;box-shadow:var(--shadow-sm);margin-bottom:16px}
.tag-input-wrapper:focus-within{border-color:var(--accent)}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{display:inline-flex;align-items:center;gap:5px;background:var(--accent);color:#fff;border-radius:var(--radius-pill);padding:4px 10px 4px 12px;font-size:14px;font-weight:500;animation:tagIn .18s ease}
@keyframes tagIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.tag-remove{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:16px;line-height:1;padding:0;transition:color .15s}
.tag-remove:hover{color:#fff}
.tag-input-wrapper input{flex:1;min-width:140px;border:none;outline:none;font-size:15px;background:transparent;color:var(--text)}
.tag-input-wrapper input::placeholder{color:#aaa}

/* Filters */
.filters-panel{margin-bottom:20px;display:flex;flex-direction:column;gap:14px}
.filter-group{display:flex;flex-direction:column;gap:8px}
.filter-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}
.filter-pills{display:flex;flex-wrap:wrap;gap:8px}
.filter-pill{padding:6px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;border:2px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all .15s}
.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.filter-pill:hover:not(.active){border-color:var(--accent);color:var(--accent)}
.serving-control{display:flex;align-items:center;gap:12px}
.serving-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:var(--surface);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-muted);transition:all .15s}
.serving-btn:hover{border-color:var(--accent);color:var(--accent)}
.serving-count{font-size:18px;font-weight:800;min-width:30px;text-align:center}
.chef-input{width:100%;border:2px solid var(--border);border-radius:var(--radius-pill);padding:8px 16px;font-size:14px;background:var(--surface);color:var(--text);outline:none}
.chef-input:focus{border-color:var(--accent)}

/* Generate button */
.btn-generate{width:100%;background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none;border-radius:var(--radius);padding:16px;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s;box-shadow:0 4px 16px rgba(255,107,53,.35)}
.btn-generate:hover:not(:disabled){transform:translateY(-1px);opacity:.9}
.btn-generate:disabled{opacity:.4;cursor:not-allowed}

/* Photo */
.photo-preview-wrap{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:24px;background:#000;box-shadow:var(--shadow-md)}
#photoPreview{width:100%;display:block;max-height:360px;object-fit:cover}
.identify-status{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.65);color:#fff;padding:12px 16px;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;backdrop-filter:blur(4px)}
.section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}

/* Results */
.results-section{max-width:1200px;margin:0 auto;padding:40px 24px 80px}
.results-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.results-header h2{font-size:24px;font-weight:700}
.results-meta{font-size:13px;color:var(--text-muted);margin-top:4px}
.results-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.results-toolbar{display:flex;gap:10px;margin-bottom:0;flex-wrap:wrap}
.search-bar{flex:1;min-width:180px;border:2px solid var(--border);border-radius:var(--radius-pill);padding:10px 16px;font-size:14px;background:var(--surface);color:var(--text);outline:none;transition:border-color .2s}
.search-bar:focus{border-color:var(--accent)}
.toolbar-select{border:2px solid var(--border);border-radius:var(--radius-pill);padding:10px 14px;font-size:14px;background:var(--surface);color:var(--text);cursor:pointer;outline:none}
.btn-icon-pill{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-pill);padding:8px 14px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s}
.btn-icon-pill:hover{border-color:var(--accent);color:var(--accent)}
.btn-reset{background:none;border:2px solid var(--border);border-radius:var(--radius-pill);padding:8px 16px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s}
.btn-reset:hover{border-color:var(--accent);color:var(--accent)}

/* Results banner */
.results-banner{background:linear-gradient(160deg,#ff6b35 0%,#f7931e 38%,#ffcd3c 100%);position:relative;overflow:hidden}
.results-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 88% 8%,rgba(255,255,255,.22) 0%,transparent 55%),radial-gradient(ellipse at 12% 92%,rgba(180,60,0,.18) 0%,transparent 50%);pointer-events:none}
[data-theme=dark] .results-banner{background:linear-gradient(160deg,#6b1e0a 0%,#7a3200 38%,#5a4200 100%)}
.results-banner-inner{max-width:1200px;margin:0 auto;padding:20px 24px 28px;position:relative;z-index:1}
.results-banner-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.results-banner h2{font-size:clamp(26px,5vw,40px);font-weight:900;color:#fff;letter-spacing:-1.5px;margin-bottom:5px;text-shadow:0 2px 16px rgba(0,0,0,.15)}
.results-banner .results-meta{color:rgba(255,255,255,.75);font-size:14px;font-weight:500;margin-bottom:16px}
.results-banner .results-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.results-banner .btn-icon-pill{background:rgba(255,255,255,.2);border:1.5px solid rgba(255,255,255,.35);color:#fff}
.results-banner .btn-icon-pill:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.55);color:#fff}
.results-banner .search-bar,.results-banner .toolbar-select{background:rgba(255,255,255,.92);border:none;color:#1a1714;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.results-banner .search-bar:focus{background:#fff;border:none;box-shadow:0 4px 18px rgba(0,0,0,.18)}
.results-banner .search-bar::placeholder{color:#999}
.recipe-grid-wrap{max-width:1200px;margin:0 auto;padding:28px 24px 80px}

/* Recipe grid & cards */
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.recipe-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s;animation:cardIn .3s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.recipe-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}

/* ── Recipe Cards (modern redesign) ── */
.recipe-card{background:var(--surface);border-radius:20px;border:none;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04);transition:box-shadow .25s,transform .25s;animation:cardIn .35s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.recipe-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.14),0 0 0 1px rgba(0,0,0,.05);transform:translateY(-5px)}

/* Colored card hero */
.card-hero{padding:14px 16px 20px;position:relative;overflow:hidden;min-height:190px;display:flex;flex-direction:column;justify-content:flex-end}
.card-hero-emoji{position:absolute;right:-10px;top:-8px;font-size:120px;opacity:.18;line-height:1;transform:rotate(12deg);z-index:0;pointer-events:none}
.card-hero-content{position:relative;z-index:1}
.card-type-chip{display:inline-block;background:rgba(0,0,0,.22);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700;color:rgba(255,255,255,.9);text-transform:capitalize;letter-spacing:.3px;margin-bottom:8px}
.card-name{font-size:22px;font-weight:900;line-height:1.2;color:#fff;letter-spacing:-.5px;margin-bottom:5px;text-shadow:0 2px 8px rgba(0,0,0,.25)}
.card-description{font-size:13px;color:rgba(255,255,255,.82);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-actions{position:absolute;top:12px;right:14px;display:flex;gap:6px;z-index:2}
.card-btn{background:rgba(0,0,0,.28);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:var(--radius-pill);padding:5px 11px;font-size:14px;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:3px}
.card-btn:hover{background:rgba(0,0,0,.45)}
.card-btn.saved{background:rgba(220,40,40,.4)}
.cooked-badge{position:absolute;top:12px;left:14px;background:rgba(0,180,100,.45);backdrop-filter:blur(6px);color:#fff;border-radius:var(--radius-pill);padding:4px 10px;font-size:11px;font-weight:700;z-index:2}

/* Card stat bar */
.card-stats{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border);background:var(--surface)}
.card-stat{padding:14px 8px;text-align:center;border-right:1px solid var(--border)}
.card-stat:last-child{border-right:none}
.card-stat-val{font-size:16px;font-weight:800;color:var(--text);line-height:1;margin-bottom:3px}
.card-stat-key{font-size:11px;color:var(--text-muted);font-weight:600}

/* Cost bar */
.card-cost-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:linear-gradient(135deg,rgba(255,107,53,.06),rgba(247,147,30,.06));border-bottom:1px solid var(--border)}
.card-cost-total{font-size:22px;font-weight:900;color:var(--accent)}
.card-cost-detail{text-align:right}
.card-cost-per{font-size:13px;font-weight:700;color:var(--text-muted)}
.card-cost-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}

/* Badges row */
.card-badges{display:flex;gap:6px;padding:10px 16px;flex-wrap:wrap;align-items:center;border-bottom:1px solid var(--border)}
.badge{display:inline-flex;align-items:center;gap:3px;border-radius:var(--radius-pill);padding:4px 11px;font-size:11px;font-weight:600}
.badge-skill{color:#fff;border-color:transparent}
.skill-1{background:var(--skill-1)}.skill-2{background:var(--skill-2)}.skill-3{background:var(--skill-3)}.skill-4{background:var(--skill-4)}.skill-5{background:var(--skill-5)}
.badge-light{background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}
.allergen-badge{background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:var(--radius-pill);padding:3px 9px;font-size:11px;font-weight:600}
[data-theme=dark] .allergen-badge{background:rgba(255,200,60,.12);color:#f59e0b;border-color:rgba(255,200,60,.2)}

/* Card body */
.card-body{padding:14px 18px}
.ingredient-section{margin-bottom:12px}
.section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:7px}
.ingredient-tags{display:flex;flex-wrap:wrap;gap:5px}
.ing-tag{display:inline-flex;align-items:center;gap:3px;border-radius:var(--radius-pill);padding:4px 10px;font-size:12px;font-weight:500}
.ing-tag.have{background:rgba(255,107,53,.12);color:#c94b00}
.ing-tag.need{background:#f0ece4;color:#5c5248}
.ing-tag.equipment{background:#eef2ff;color:#3730a3}
.ing-tag.in-list{background:#d1fae5;color:#065f46}
.ing-tag.clickable{cursor:pointer;transition:opacity .15s}.ing-tag.clickable:hover{opacity:.75}
.add-grocery{background:none;border:none;cursor:pointer;font-size:12px;opacity:.5;padding:0;transition:opacity .15s}
.add-grocery:hover{opacity:1}

/* Expandable sections */
.card-expand-btn{width:100%;background:var(--bg);border:none;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s;margin-bottom:6px}
.card-expand-btn:hover,.card-expand-btn.open{background:linear-gradient(135deg,rgba(255,107,53,.1),rgba(247,147,30,.08));color:var(--text)}
.card-expand-btn .chev{transition:transform .2s;font-style:normal}
.card-expand-btn.open .chev{transform:rotate(180deg)}
.card-expand-content{display:none;padding:4px 0 8px}.card-expand-content.visible{display:block}

.steps-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.step-item{display:flex;gap:12px;font-size:13px;line-height:1.6}
.step-num{flex-shrink:0;width:22px;height:22px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;margin-top:2px}

.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}
.nutrition-item{background:var(--bg);border-radius:10px;padding:10px 4px}
.nutrition-val{font-size:17px;font-weight:900;color:var(--text)}
.nutrition-key{font-size:9px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}

/* Action bar */
.card-action-bar{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.card-action{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-pill);padding:6px 13px;font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}
.card-action:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,107,53,.06)}

/* Swap */
.swap-form{display:flex;gap:6px;margin-top:8px}
.swap-input{flex:1;border:2px solid var(--accent);border-radius:var(--radius-pill);padding:7px 13px;font-size:13px;outline:none;background:var(--surface);color:var(--text)}
.swap-btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:var(--radius-pill);padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer}

/* Rating */
.card-rating{display:flex;gap:3px;margin-top:8px}
.star-btn{background:none;border:none;font-size:20px;cursor:pointer;opacity:.25;transition:opacity .15s,transform .15s}
.star-btn.filled{opacity:1}
.star-btn:hover{transform:scale(1.25);opacity:.7}

/* Notes */
.card-notes{width:100%;border:2px solid var(--border);border-radius:10px;padding:9px 12px;font-size:13px;background:var(--bg);color:var(--text);outline:none;resize:vertical;min-height:60px;margin-top:8px;font-family:inherit;transition:border-color .2s}
.card-notes:focus{border-color:var(--accent);background:var(--surface)}

/* Scale */
.scale-row{display:flex;align-items:center;gap:8px;margin-top:8px}
.scale-label{font-size:13px;color:var(--text-muted)}
.scale-btn{background:var(--bg);border:2px solid var(--border);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .15s}
.scale-btn:hover{border-color:var(--accent);color:var(--accent)}
.scale-val{font-size:16px;font-weight:800;min-width:30px;text-align:center}

/* History */
.history-list{display:flex;flex-direction:column;gap:10px}
.history-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;cursor:pointer;transition:border-color .2s}
.history-item:hover{border-color:var(--accent)}
.history-item-title{font-size:15px;font-weight:700}
.history-item-meta{font-size:12px;color:var(--text-muted);margin-top:4px}

/* Meal planner */
.planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.planner-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;min-height:120px}
.planner-day-label{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}
.planner-slot{background:var(--bg);border-radius:6px;padding:8px;font-size:12px;cursor:pointer;transition:background .15s;min-height:60px;display:flex;align-items:center;justify-content:center;text-align:center;border:1.5px dashed var(--border)}
.planner-slot.filled{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:600;border-style:solid}
@media(max-width:700px){.planner-grid{grid-template-columns:repeat(2,1fr)}}

/* Fridge tracker */
.fridge-add-row{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.fridge-input{flex:1;min-width:120px;border:2px solid var(--border);border-radius:var(--radius-pill);padding:10px 14px;font-size:14px;background:var(--surface);color:var(--text);outline:none}
.fridge-input:focus{border-color:var(--accent)}
.btn-add-fridge{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-pill);padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer}
.fridge-list{display:flex;flex-direction:column;gap:8px}
.fridge-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}
.fridge-item.expiring{border-color:#f59e0b;background:#fffbeb}
.fridge-item.expired{border-color:#ef4444;background:#fef2f2}
.fridge-name{flex:1;font-size:14px;font-weight:600}
.fridge-date{font-size:12px;color:var(--text-muted)}
.fridge-badge{font-size:11px;font-weight:700;border-radius:var(--radius-pill);padding:2px 8px}
.fridge-badge.ok{background:#d1fae5;color:#065f46}
.fridge-badge.soon{background:#fef3c7;color:#92400e}
.fridge-badge.exp{background:#fee2e2;color:#991b1b}
.fridge-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}

/* Cook mode */
.cook-mode{display:none;position:fixed;inset:0;background:var(--bg);z-index:500;flex-direction:column}
.cook-mode.active{display:flex}
.cook-header{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 20px;display:flex;align-items:center;gap:16px}
.btn-back-cook{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-muted);line-height:1}
.cook-title{font-size:16px;font-weight:700;flex:1}
.cook-step-counter{font-size:14px;color:var(--text-muted);font-weight:600}
.cook-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;gap:32px}
.cook-step-text{font-size:clamp(18px,4vw,28px);font-weight:600;line-height:1.4;max-width:600px}
.cook-timer-area{display:flex;flex-direction:column;align-items:center;gap:12px}
.cook-timer{font-size:48px;font-weight:900;font-variant-numeric:tabular-nums;color:var(--accent)}
.cook-timer-btns{display:flex;gap:8px;align-items:center}
.timer-btn{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-pill);padding:8px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}
.timer-btn:hover{border-color:var(--accent);color:var(--accent)}
.timer-input{width:80px;border:2px solid var(--border);border-radius:var(--radius-pill);padding:8px 12px;font-size:14px;text-align:center;background:var(--surface);color:var(--text);outline:none}
.cook-footer{border-top:1px solid var(--border);padding:16px 24px;background:var(--surface)}
.cook-ingredients{font-size:13px;color:var(--text-muted);margin-bottom:12px;display:flex;flex-wrap:wrap;gap:6px}
.cook-nav{display:flex;gap:10px;justify-content:space-between}
.cook-nav-btn{flex:1;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:14px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s}
.cook-nav-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.cook-nav-btn:disabled{opacity:.35;cursor:not-allowed}

/* Empty / misc */
.empty-msg{color:var(--text-muted);font-size:15px;text-align:center;padding:40px 20px}

/* Modals */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(4px)}
.modal-overlay.visible{display:flex}
.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:460px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}
.modal-header h3{font-size:18px;font-weight:700}
.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-muted);line-height:1}
.modal-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border);margin-top:8px}
.grocery-items{padding:16px 20px;display:flex;flex-direction:column;gap:8px}
.grocery-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg);border-radius:var(--radius-sm)}
.grocery-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.grocery-item label{flex:1;font-size:15px;cursor:pointer}
.grocery-item label.checked{text-decoration:line-through;color:var(--text-muted)}
.grocery-item .remove-item{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}
.share-label{padding:16px 20px 8px;font-size:14px;color:var(--text-muted)}
.share-url-wrap{display:flex;gap:8px;padding:0 20px 16px}
.share-url-wrap input{flex:1;border:2px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;background:var(--bg);color:var(--text)}
.share-btns{display:flex;gap:8px;padding:0 20px 20px}
.share-social{flex:1;border:none;border-radius:var(--radius-sm);padding:10px;font-size:13px;font-weight:700;cursor:pointer;color:#fff}
.share-social.whatsapp{background:#25d366}
.share-social.email{background:#4285f4}
.share-social.insta{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.unit-converter{padding:20px;display:flex;flex-direction:column;gap:12px}
.unit-input,.unit-select{border:2px solid var(--border);border-radius:var(--radius-pill);padding:10px 14px;font-size:14px;background:var(--surface);color:var(--text);outline:none;width:100%}
.unit-input:focus,.unit-select:focus{border-color:var(--accent)}
.unit-result{font-size:28px;font-weight:900;text-align:center;color:var(--accent);padding:12px 0}
.profile-body{padding:20px;display:flex;flex-direction:column;gap:16px}
.profile-row{display:flex;flex-direction:column;gap:8px}
.profile-row label{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.profile-input{border:2px solid var(--border);border-radius:var(--radius-pill);padding:10px 14px;font-size:15px;background:var(--surface);color:var(--text);outline:none}
.profile-input:focus{border-color:var(--accent)}

/* Buttons */
.btn-copy{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}
.btn-copy:hover{opacity:.85}
.btn-clear{background:none;border:2px solid var(--border);border-radius:var(--radius-sm);padding:10px 18px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer}
.btn-cancel{background:rgba(0,0,0,.08);border:none;color:var(--text-muted);border-radius:var(--radius-pill);padding:8px 20px;font-size:14px;cursor:pointer;margin-top:12px}

/* Loading */
.loading-overlay{display:none;position:fixed;inset:0;background:rgba(247,245,240,.85);backdrop-filter:blur(4px);align-items:center;justify-content:center;z-index:100}
[data-theme=dark] .loading-overlay{background:rgba(17,17,17,.85)}
.loading-overlay.visible{display:flex}
.loading-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:40px 48px;text-align:center;border:1px solid var(--border)}
.loading-card p{margin-top:18px;color:var(--text-muted);font-size:15px;font-weight:500}
.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
.spinner.small{width:18px;height:18px;border-width:2px;margin:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* Print */
@media print {
  .hero,.results-banner,.results-actions,.results-toolbar,.card-actions,.card-action-bar,.card-btn,.cooked-badge,.loading-overlay,.modal-overlay{display:none!important}
  .recipe-grid{grid-template-columns:1fr 1fr}
  .recipe-card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}
  .steps-list,.card-expand-content{display:block!important}
  body{background:#fff;color:#000}
}

@media(max-width:560px){
  .recipe-grid{grid-template-columns:1fr}
  .results-banner-top{flex-direction:column;align-items:flex-start}
  .results-actions{width:100%;justify-content:flex-start}
  .share-btns{flex-direction:column}
}

/* ── Chef Show ── */
.chef-show{display:none;position:fixed;inset:0;z-index:600;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.chef-show.active{display:flex}
.chef-show-bg{position:absolute;inset:0;background:var(--chef-color,#c0392b);opacity:.95;transition:background .5s}
.chef-show-inner{position:relative;width:100%;max-width:700px;background:rgba(0,0,0,.55);border-radius:24px;padding:28px;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);color:#fff;display:flex;flex-direction:column;gap:20px}
.chef-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.15);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.chef-close:hover{background:rgba(255,255,255,.3)}
.chef-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.chef-avatar{font-size:52px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));animation:chefPop .4s cubic-bezier(.36,.07,.19,.97)}
@keyframes chefPop{from{transform:scale(.5) rotate(-10deg);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}
.chef-name{font-size:22px;font-weight:900;letter-spacing:-.5px}
.chef-recipe-name{font-size:14px;opacity:.7;font-weight:500;margin-top:2px}
.chef-yt-btn{background:rgba(255,0,0,.8);color:#fff;border:none;border-radius:var(--radius-pill);padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .2s;margin-left:auto}
.chef-yt-btn:hover{background:red}
.chef-stage{background:rgba(0,0,0,.3);border-radius:16px;padding:24px;min-height:160px;display:flex;flex-direction:column;gap:12px}
.chef-step-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;opacity:.55}
.chef-narration{font-size:clamp(16px,3vw,22px);font-weight:600;line-height:1.5;animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.chef-tip{font-size:14px;opacity:.7;font-style:italic;padding-left:12px;border-left:3px solid rgba(255,255,255,.4);animation:fadeUp .35s ease .1s both}
.chef-progress-bar{height:4px;background:rgba(255,255,255,.2);border-radius:99px;overflow:hidden}
.chef-progress-fill{height:100%;background:#fff;border-radius:99px;transition:width .4s ease}
.chef-controls{display:flex;gap:10px}
.chef-ctrl-btn{flex:1;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);color:#fff;border-radius:12px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}
.chef-ctrl-btn:hover{background:rgba(255,255,255,.25)}
.chef-ctrl-btn.primary{background:rgba(255,255,255,.9);color:#111}
.chef-ctrl-btn.primary:hover{background:#fff}
.chef-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}
.chef-footer{display:flex;align-items:center;justify-content:space-between}
.chef-voice-toggle{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;opacity:.75}
.chef-voice-toggle input{accent-color:#fff;cursor:pointer}
.chef-step-dots{display:flex;gap:6px}
.chef-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);transition:background .3s}
.chef-dot.active{background:#fff}
