*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0F1113;--bg-secondary:#161819;--card:rgba(255,255,255,0.04);--card-hover:rgba(255,255,255,0.07);--card-elevated:rgba(255,255,255,0.06);--border:rgba(255,255,255,0.08);--border-hover:rgba(255,255,255,0.15);--text:#F5F5F5;--text-secondary:rgba(255,255,255,0.6);--text-tertiary:rgba(255,255,255,0.35);--text-on-dark:#ffffff;--accent:#10B981;--accent-hover:#34D399;--accent-light:rgba(16,185,129,0.08);--accent-50:rgba(16,185,129,0.05);--accent-glow:rgba(16,185,129,0.15);--accent-subtle:rgba(16,185,129,0.08);--green:#10B981;--red:#EF4444;--yellow:#F59E0B;--blue:#3B82F6;--purple:#8B5CF6;--orange:#f97316;--z-sticky:10;--z-dropdown:100;--z-modal-base:1000;--z-modal-feature:8000;--z-modal-overlay:9000;--z-modal-nested:9500;--z-pricing:9999;--text-muted:rgba(255,255,255,0.4);--z-login:10000}
[data-theme="light"]{--bg:#F5F5F5;--bg-secondary:#FFFFFF;--card:rgba(0,0,0,0.03);--card-hover:rgba(0,0,0,0.06);--card-elevated:rgba(0,0,0,0.05);--border:rgba(0,0,0,0.1);--border-hover:rgba(0,0,0,0.2);--text:#1A1A1A;--text-secondary:rgba(0,0,0,0.6);--text-tertiary:rgba(0,0,0,0.35);--text-on-dark:#ffffff;--text-muted:rgba(0,0,0,0.4);--accent-glow:rgba(16,185,129,0.2);--accent-light:rgba(16,185,129,0.1);--accent-subtle:rgba(16,185,129,0.08)}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI','Pretendard',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;word-break:keep-all;overflow-wrap:break-word}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(16,185,129,0.3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(16,185,129,0.5)}
.header{background:rgba(22,24,25,0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:22px 24px 26px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
[data-theme="light"] .header{background:rgba(255,255,255,0.85)}
[data-theme="light"] .login-page{background:var(--bg)}
[data-theme="light"] .mobile-nav{background:rgba(255,255,255,0.92);border-top:1px solid var(--border)}
/* ═══ LIGHT MODE COMPREHENSIVE OVERRIDES ═══ */
[data-theme="light"] .card{box-shadow:0 1px 3px rgba(0,0,0,0.06)}
[data-theme="light"] .ing-cat-hdr{background:rgba(0,0,0,0.03)}
[data-theme="light"] .ing-cell:hover{background:rgba(0,0,0,0.04)}
[data-theme="light"] .ing-sub-row .ing-cell{background:rgba(0,0,0,0.02);border-left-color:rgba(16,185,129,0.3)}
[data-theme="light"] .ing-sub-row .ing-cell:hover{background:rgba(0,0,0,0.05)}
[data-theme="light"] .add-health-btn{border-color:rgba(0,0,0,0.15)}
[data-theme="light"] input[type=range]{background:rgba(0,0,0,0.08)}
[data-theme="light"] .analyze-btn:disabled{background:rgba(0,0,0,0.06)}
[data-theme="light"] .analyze-btn--main:disabled{background:rgba(0,0,0,0.06)}
[data-theme="light"] .intensity-bar{background:rgba(0,0,0,0.06)}
[data-theme="light"] .ret-bar{background:rgba(0,0,0,0.06)}
[data-theme="light"] .flavor-bar{background:rgba(0,0,0,0.06)}
[data-theme="light"] .add-member-btn{border-color:rgba(0,0,0,0.15)}
[data-theme="light"] .login-right{background:var(--bg-secondary);box-shadow:-4px 0 30px rgba(0,0,0,0.08)}
[data-theme="light"] .login-guest{border-color:rgba(0,0,0,0.15);color:var(--text-tertiary)}
[data-theme="light"] .mode-toggle{background:rgba(0,0,0,0.05);border-color:rgba(0,0,0,0.12);color:rgba(0,0,0,0.7)}
[data-theme="light"] .mode-toggle:hover{background:rgba(0,0,0,0.1)}
[data-theme="light"] .pricing-btn{border-color:rgba(0,0,0,0.15);color:rgba(0,0,0,0.7)}
[data-theme="light"] .pricing-btn:hover{background:rgba(0,0,0,0.05)}
[data-theme="light"] .user-avatar{background:rgba(0,0,0,0.05);color:rgba(0,0,0,0.7);border-color:rgba(0,0,0,0.08)}
[data-theme="light"] .user-avatar .circle{background:rgba(0,0,0,0.1)}
[data-theme="light"] .version-badge{color:rgba(0,0,0,0.35)}
[data-theme="light"] .lang-btn{border-color:rgba(0,0,0,0.15);background:rgba(0,0,0,0.04);color:rgba(0,0,0,0.7)}
[data-theme="light"] .lang-btn:hover{background:rgba(0,0,0,0.08)}
[data-theme="light"] .loading-spinner{border-color:rgba(0,0,0,0.1)}
[data-theme="light"] .profile-step .step-num{background:rgba(0,0,0,0.06)}
[data-theme="light"] .header-tab:hover{background:rgba(0,0,0,0.04)}
[data-theme="light"] .hf-section-count{background:rgba(0,0,0,0.06)}
[data-theme="light"] .fd-modal{background:#ffffff;border-color:rgba(0,0,0,0.12);box-shadow:0 16px 48px rgba(0,0,0,0.15)}
[data-theme="light"] .fd-close:hover{background:rgba(0,0,0,0.06)}
[data-theme="light"] .fd-actions{background:#ffffff}
[data-theme="light"] .fd-mockup{background:rgba(0,0,0,0.03);border-color:var(--border)}
[data-theme="light"] .fdm-nav-tab{background:rgba(0,0,0,0.04)}
[data-theme="light"] .fdm-btn{background:rgba(0,0,0,0.04)}
[data-theme="light"] .fdm-search{background:rgba(0,0,0,0.02)}
[data-theme="light"] .fdm-card{background:rgba(0,0,0,0.03)}
[data-theme="light"] .fdm-chip{background:rgba(0,0,0,0.04)}
[data-theme="light"] .fdm-wiz-step{background:rgba(0,0,0,0.04)}
[data-theme="light"] .fdm-result-row{background:rgba(0,0,0,0.03)}
[data-theme="light"] .fdm-ing{background:rgba(0,0,0,0.03)}
[data-theme="light"] .fdm-calendar{background:rgba(0,0,0,0.02)}
[data-theme="light"] .fdm-cal-header{background:rgba(0,0,0,0.04)}
[data-theme="light"] .fdm-cal-slot{border-color:rgba(0,0,0,0.06)}
[data-theme="light"] .fdm-bar{background:rgba(0,0,0,0.06)}
[data-theme="light"] .appmap-close{background:rgba(0,0,0,0.06)}
[data-theme="light"] .wizard-step .wizard-step-num{background:rgba(0,0,0,0.06)}
[data-theme="light"] .wizard-step.active .wizard-step-num{background:rgba(255,255,255,0.3)}
[data-theme="light"] .sub-tab:hover{background:rgba(0,0,0,0.03)}
[data-theme="light"] .yt-feat-thumb{background:rgba(0,0,0,0.04)}
[data-theme="light"] .yt-thumb{background:rgba(0,0,0,0.04)}
[data-theme="light"] .yt-modal-back{background:rgba(0,0,0,0.08);color:var(--text)}
[data-theme="light"] .yt-modal-back:hover{background:rgba(0,0,0,0.15)}
[data-theme="light"] .yt-modal-close{background:rgba(0,0,0,0.08);color:var(--text)}
[data-theme="light"] .yt-modal-close:hover{background:rgba(0,0,0,0.15)}
[data-theme="light"] .yt-modal-title{color:var(--text)}
[data-theme="light"] .yt-modal-hint{background:rgba(0,0,0,0.04);color:rgba(0,0,0,0.4)}
[data-theme="light"] .profile-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(0,0,0,0.35)' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}
[data-theme="light"] .more-menu-overlay{background:rgba(0,0,0,0.3)}
[data-theme="light"] .more-menu{box-shadow:0 -4px 30px rgba(0,0,0,0.15)}
[data-theme="light"] .modal-box{box-shadow:0 25px 50px rgba(0,0,0,0.15)}
[data-theme="light"] .modal-content{box-shadow:0 25px 50px rgba(0,0,0,0.15)}
[data-theme="light"] .method-modal{box-shadow:0 20px 60px rgba(0,0,0,0.2)}
[data-theme="light"] .health-modal{box-shadow:0 20px 60px rgba(0,0,0,0.2)}
[data-theme="light"] .home-onboard-hero h1{background:linear-gradient(135deg,#1A1A1A 30%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
[data-theme="light"] .home-hero h2{background:linear-gradient(135deg,#1A1A1A,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
[data-theme="light"] #devNav{background:rgba(245,245,245,0.95);border-top-color:rgba(0,0,0,0.08)}
[data-theme="light"] #devNav .dev-sep{background:rgba(0,0,0,0.15)}
[data-theme="light"] #devNav button{border-color:rgba(0,0,0,0.15);color:#333}
[data-theme="light"] #devNav button:hover{background:rgba(0,0,0,0.08)}
[data-theme="light"] #devNav .dev-close{border-color:rgba(0,0,0,0.1)}
[data-theme="light"] .glass-overlay{background:rgba(0,0,0,0.4)}
[data-theme="light"] .price-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.1)}
[data-theme="light"] .recipe-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.1)}
[data-theme="light"] .yt-feat:hover{box-shadow:0 4px 20px rgba(0,0,0,0.1)}
[data-theme="light"] .yt-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.1)}
[data-theme="light"] .rxn-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08)}
/* Mobile nav light */
@media(max-width:768px){[data-theme="light"] .mobile-nav{background:rgba(255,255,255,0.95);box-shadow:0 -2px 24px rgba(0,0,0,0.08);border-top:1px solid rgba(0,0,0,0.06)}[data-theme="light"] .mobile-nav-btn{color:rgba(0,0,0,0.35)}}
.header::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.header::after{content:none}
.logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#059669,#10b981);display:flex;align-items:center;justify-content:center;font-size:19px;position:relative;z-index:2;box-shadow:0 0 16px rgba(16,185,129,0.2)}
.container{max-width:600px;margin:0 auto;padding:20px 16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.card{background:var(--card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:20px;border:1px solid var(--border);box-shadow:inset 2px 2px 2px rgba(255,255,255,0.02);min-width:0;overflow:visible;transition:all 0.2s ease}
.card:hover{border-color:var(--border-hover);background:var(--card-hover)}
.section-title{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--text)}
.search-wrap{position:relative;margin-bottom:12px}
.search-wrap input{width:100%;padding:10px 14px 10px 38px;background:var(--card);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:14px;outline:none;transition:all .2s;backdrop-filter:blur(12px)}
.search-wrap input:focus{background:var(--card-hover);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.search-wrap input::placeholder{color:var(--text-tertiary)}
.search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}
/* ── Category tabs (pill style) ──────────────────────────────── */
.cat-scroll-wrap{margin-bottom:10px}
.cat-scroll{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:4px 0}
@media(min-width:500px){.cat-scroll{grid-template-columns:repeat(8,1fr)}}
.cat-tab{padding:8px 4px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:10px;font-weight:500;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s;line-height:1.3;text-align:center}
.cat-tab:hover:not(.active){color:var(--text);background:var(--card-hover);border-color:var(--border-hover)}
.cat-tab.active{color:var(--accent);border-color:var(--accent);background:var(--accent-light);font-weight:600}
/* ── Ingredient table ───────────────────────────────────────────────────── */
.ing-table{max-height:320px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;scrollbar-width:thin;scrollbar-color:rgba(16,185,129,0.3) transparent;background:var(--card)}
.ing-table::-webkit-scrollbar{width:3px}
.ing-table::-webkit-scrollbar-track{background:transparent}
.ing-table::-webkit-scrollbar-thumb{background:rgba(16,185,129,0.3);border-radius:2px}
.ing-cat-hdr{padding:5px 8px;background:rgba(255,255,255,0.04);border-bottom:1px solid var(--border);font-size:10px;font-weight:700;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:5px;position:sticky;top:0;z-index:1}
.ing-row{display:grid;grid-template-columns:repeat(4,1fr)}
.ing-cell{padding:10px 6px;min-height:44px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:all .15s;min-width:0;user-select:none;overflow:hidden;text-align:center}
.ing-cell:nth-child(5n){border-right:1px solid var(--border)}
.ing-cell:nth-child(4n){border-right:none}
.ing-cell:last-child{border-right:none}
.ing-cell:hover{background:rgba(255,255,255,0.04)}
.ing-cell.active{background:rgba(16,185,129,0.15);border-color:rgba(16,185,129,0.4);position:relative}
.ing-cell.active::after{content:'✓';position:absolute;top:3px;right:4px;font-size:9px;font-weight:700;color:#fff;background:var(--accent);border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;line-height:1}
.ing-cell .ci-e{font-size:16px;flex-shrink:0;line-height:1}
.ing-cell .ci-img{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0}
.ing-cell .fi-lazy{font-size:16px;flex-shrink:0;line-height:1;display:inline-block;width:36px;height:36px;text-align:center;line-height:36px}
.ing-cell .fi-emoji{font-size:16px}
.ing-cell .ci-n{font-size:11px;color:var(--text-secondary);line-height:1.3;word-break:keep-all;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%}
.ing-cell.active .ci-n{color:var(--accent);font-weight:600}
.ing-cell.active .ci-img{box-shadow:0 0 0 2px var(--accent)}
/* ── Parent expand ───────────────────────────────────────────────────────── */
.ing-cell--parent .ci-arr{margin-left:auto;font-size:9px;color:var(--text-tertiary);flex-shrink:0;transition:transform .15s}
.ing-cell--parent.expanded .ci-arr{transform:rotate(90deg);color:var(--accent)}
.ing-cell--parent.expanded{background:var(--accent-subtle)}
.ing-expand{display:none;border-bottom:1px solid var(--border)}
.ing-expand.open{display:block}
.ing-sub-row .ing-cell{background:rgba(255,255,255,0.02);padding-left:14px;border-left:3px solid rgba(16,185,129,0.2)}
.ing-sub-row .ing-cell:hover{background:rgba(255,255,255,0.05)}
.ing-sub-row .ing-cell.active{background:rgba(16,185,129,0.15);border-left-color:var(--accent)}
/* ── Selected row (table style) ────────────────────────────────────────── */
.sel-bar{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.sel-bar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.sel-bar-title{font-size:12px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px}
.sel-bar-title .sel-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:#fff;border-radius:3px;font-size:10px;font-weight:700}
.sel-bar-clear{font-size:11px;color:var(--text-tertiary);cursor:pointer;padding:3px 8px;border-radius:3px;border:1px solid var(--border);background:transparent;transition:all .15s;font-weight:500}
.sel-bar-clear:hover{background:rgba(239,68,68,0.1);color:#EF4444;border-color:rgba(239,68,68,0.3)}
.sel-chips{display:flex;flex-wrap:wrap;gap:4px}
.sel-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 7px 4px 8px;background:var(--card);border:1px solid rgba(16,185,129,0.2);border-radius:8px;transition:border-color .15s}
.sel-chip:hover{border-color:var(--accent)}
.sel-chip .sc-e{font-size:13px;line-height:1}
.sel-chip .sc-img{width:24px;height:24px;border-radius:4px;object-fit:cover;flex-shrink:0}
.sel-chip .fi-lazy{font-size:13px;line-height:1;display:inline-block}
.sel-chip .fi-emoji{font-size:13px}
.sel-chip .sc-n{font-size:11px;color:var(--accent);font-weight:500;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sel-chip .sc-g{width:30px;border:none;background:transparent;color:var(--accent);font-size:11px;font-weight:700;text-align:center;outline:none;padding:0}
.sel-chip .sc-u{font-size:10px;color:rgba(16,185,129,0.5);margin-right:2px}
.sel-chip .sc-rm{cursor:pointer;opacity:.4;font-size:14px;line-height:1;color:var(--text-secondary);padding-left:1px;transition:opacity .15s}
.sel-chip .sc-rm:hover{opacity:1;color:#EF4444}
/* ── Legacy compat (hidden) ─────────────────────────────────────────────── */
.ing-btn{padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s}
.ing-btn:hover{border-color:var(--border-hover);background:var(--card-hover)}
.ing-btn.active{border-color:transparent;background:var(--accent);color:#fff}
.gram-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}
.gram-row:last-child{border-bottom:none}
.gram-input{width:64px;padding:8px 10px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;text-align:right;outline:none}
.gram-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.gram-unit{font-size:11px;color:var(--text-tertiary);min-width:14px}
.method-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:14px}
.method-btn{padding:8px 4px;border-radius:12px;font-size:11px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;text-align:center;transition:all .2s;line-height:1.2;backdrop-filter:blur(12px)}
.method-btn:hover{border-color:var(--border-hover);background:var(--card-hover)}
.method-btn:active{transform:translateY(1px);opacity:0.8}
.method-btn.active{border-color:transparent;background:var(--accent);color:#fff;box-shadow:0 0 16px var(--accent-glow)}
.method-btn .emoji{font-size:16px;display:block;margin-bottom:2px}
.method-btn .method-icon{display:flex;align-items:center;justify-content:center;margin-bottom:2px}
.method-btn .method-img{width:32px;height:32px;border-radius:8px;object-fit:cover;display:block}
.method-btn.active .method-img{box-shadow:0 0 0 2px #fff}
.method-btn.add-method-btn{border-style:dashed;color:var(--text-tertiary);font-size:18px;display:flex;align-items:center;justify-content:center;min-height:52px}
.method-btn.add-method-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}
.method-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.method-modal-overlay.open{display:flex}
.method-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;padding:24px;width:min(380px,90vw);box-shadow:0 20px 60px rgba(0,0,0,0.5);animation:fadeInScale .3s ease}
.method-modal h3{margin:0 0 6px;font-size:16px;font-weight:600;color:var(--text)}
.method-modal p{margin:0 0 16px;font-size:13px;color:var(--text-tertiary)}
.method-modal input{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:14px;outline:none;background:var(--card);color:var(--text);transition:all .2s}
.method-modal input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.method-modal input::placeholder{color:var(--text-tertiary)}
.method-modal-actions{display:flex;gap:8px;margin-top:12px}
.method-modal-actions button{flex:1;padding:10px;border-radius:12px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}
.method-modal-confirm{background:var(--accent);color:#fff}
.method-modal-confirm:hover{background:var(--accent-hover)}
.method-modal-confirm:active{transform:translateY(1px)}
.method-modal-cancel{background:var(--card);color:var(--text-secondary);border:1px solid var(--border) !important}
.method-modal-cancel:hover{background:var(--card-hover)}
#methodModalStatus{margin-top:10px;font-size:13px;min-height:20px;text-align:center;color:var(--text-secondary)}
/* Health add button */
.add-health-btn{background:none;border:1px dashed rgba(255,255,255,0.15);color:var(--text-tertiary);border-radius:8px;padding:3px 10px;font-size:11px;cursor:pointer;transition:all .2s}
.add-health-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}
/* Custom item display */
.custom-item{border-style:dashed !important;position:relative}
.custom-item::after{content:'AI';position:absolute;top:-5px;right:-5px;font-size:8px;background:var(--accent);color:#fff;border-radius:4px;padding:1px 3px;line-height:1.4}
/* Health add modal */
.health-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.health-modal-overlay.open{display:flex}
.health-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;padding:24px;width:min(400px,92vw);box-shadow:0 20px 60px rgba(0,0,0,0.5);animation:fadeInScale .3s ease}
.health-modal h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text)}
.health-modal .health-modal-sub{margin:0 0 16px;font-size:13px;color:var(--text-tertiary)}
.health-modal input{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:14px;outline:none;background:var(--card);color:var(--text);transition:all .2s}
.health-modal input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.health-modal input::placeholder{color:var(--text-tertiary)}
.health-modal-status{margin-top:10px;font-size:13px;min-height:20px;text-align:center;color:var(--text-tertiary)}
.health-modal-status.error{color:#EF4444}
.health-modal-status.success{color:var(--accent)}
.health-modal-result{margin-top:12px;background:var(--accent-subtle);border-radius:12px;padding:12px;font-size:13px;display:none;border:1px solid rgba(16,185,129,0.15)}
.health-modal-result .result-name{font-weight:600;font-size:15px;margin-bottom:4px;color:var(--text)}
.health-modal-result .result-desc{color:var(--text-secondary);margin-bottom:6px}
.health-modal-result .result-tags{display:flex;flex-wrap:wrap;gap:4px}
.health-modal-result .result-tag{background:var(--card);border:1px solid rgba(16,185,129,0.2);border-radius:6px;padding:2px 7px;font-size:11px;color:var(--accent)}
.health-modal-actions{display:flex;gap:8px;margin-top:12px}
.health-modal-actions button{flex:1;padding:10px;border-radius:12px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}
.health-modal-confirm{background:var(--accent);color:#fff}
.health-modal-confirm:hover{background:var(--accent-hover)}
.health-modal-cancel{background:var(--card);color:var(--text-secondary);border:1px solid var(--border) !important}
.health-modal-cancel:hover{background:var(--card-hover)}
.slider-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.slider-row label{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;font-weight:500}
input[type=range]{-webkit-appearance:none;width:100%;height:5px;border-radius:3px;background:rgba(255,255,255,0.08);outline:none;margin-bottom:8px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s;box-shadow:0 0 10px var(--accent-glow)}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 16px var(--accent-glow)}
.range-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text-tertiary);margin-bottom:16px}
.analyze-btn{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10B981);color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 0 20px var(--accent-glow)}
.analyze-btn:disabled{background:rgba(255,255,255,0.06);color:var(--text-tertiary);cursor:not-allowed;box-shadow:none}
.analyze-btn:not(:disabled):hover{background:linear-gradient(135deg,#10B981,#34D399);box-shadow:0 4px 24px var(--accent-glow);transform:translateY(-1px)}
.analyze-btn:not(:disabled):active{transform:translateY(1px)}
.warning{padding:12px 16px;border-radius:12px;margin-bottom:8px;display:flex;align-items:center;gap:10px;font-size:13px}
.warning.warn{background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.2);color:#F59E0B}
.warning.error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2);color:#EF4444}
.tabs{display:flex;flex-wrap:wrap;margin-bottom:0;gap:6px;position:relative;flex:1}
.tab-btn{padding:8px 14px;border-radius:20px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s;font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.tab-btn:hover{border-color:var(--accent);color:var(--text)}
.tab-btn.active{background:var(--accent);color:#fff;font-weight:600;border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}
.tab-btn .tab-icon{font-size:13px;line-height:1}
.rxn-card{background:var(--card);backdrop-filter:blur(12px);border-radius:16px;padding:18px;margin-bottom:12px;transition:all .2s;border:1px solid var(--border)}
.rxn-card:hover{border-color:var(--border-hover);box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.rxn-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.rxn-icon{font-size:26px}
.rxn-name{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-0.01em}
.intensity-bar{height:5px;border-radius:3px;background:rgba(255,255,255,0.06);overflow:hidden;width:80px}
.intensity-fill{height:100%;border-radius:3px;transition:width .5s}
.effect-tag{padding:4px 10px;border-radius:6px;background:var(--accent-subtle);border:1px solid rgba(16,185,129,0.2);color:var(--accent);font-size:11px;display:inline-block;margin:3px}
.science-box{background:var(--card);border-radius:12px;padding:12px;margin:8px 0;border:1px solid var(--border)}
.science-box h4{font-size:11px;color:var(--text-tertiary);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.science-box p{font-size:12px;color:var(--text-secondary);font-family:'SF Mono','Geist Mono',monospace}
.health-box{background:var(--accent-subtle);border-radius:12px;padding:12px;border:1px solid rgba(16,185,129,0.15)}
.health-box h4{font-size:11px;color:var(--accent);margin-bottom:4px;font-weight:600}
.health-box p{font-size:12px;color:var(--accent-hover)}
.chart-wrap{position:relative;width:100%;max-width:100%}
.chart-wrap canvas{width:100%!important}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:8px 12px;color:var(--text-tertiary);border-bottom:1px solid var(--border);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.03em}
td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.ret-bar{height:6px;border-radius:3px;background:rgba(255,255,255,0.06);overflow:hidden}
.ret-fill{height:100%;border-radius:3px;transition:width .5s}
.compound-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.compound-card{background:var(--card);border-radius:12px;padding:14px;border:1px solid var(--border)}
.compound-tag{padding:4px 10px;border-radius:6px;background:var(--accent-subtle);border:1px solid rgba(16,185,129,0.2);color:var(--accent);font-size:11px;display:inline-block;margin:2px}
.empty-state{text-align:center;padding:60px 20px;background:var(--card);border-radius:16px;border:1px solid var(--border)}
.empty-state .big-icon{font-size:56px;opacity:.5;margin-bottom:16px}
.fade-in{animation:fadeInUp .4s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInScale{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 20px 4px var(--accent-glow)}}
.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--card-hover) 50%,var(--card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
.flavor-detail{margin-bottom:16px}
.flavor-label{display:flex;justify-content:space-between;margin-bottom:4px;color:var(--text-secondary);font-size:12px}
.flavor-bar{height:6px;border-radius:3px;background:rgba(255,255,255,0.06);overflow:hidden;margin-bottom:4px}
.flavor-fill{height:100%;border-radius:3px;transition:width .5s}
.flavor-desc{font-size:11px;color:var(--text-tertiary)}
@media(max-width:768px){.grid2{grid-template-columns:1fr}.method-grid{grid-template-columns:repeat(5,1fr)}}
@media(max-width:400px){.method-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:480px){
  .header{padding:12px 14px}
  .header h1{font-size:15px!important}
  .header p{display:none!important}
  .logo{width:32px;height:32px}
  .mode-toggle{display:none!important}
  .pricing-btn{display:none!important}
  .auth-btn{padding:5px 10px;font-size:11px}
  .user-avatar{padding:4px 8px}
  .user-avatar span{display:none}
  .header-right{gap:6px}
  .version-badge{display:none}
}
.condition-grid{margin-bottom:12px}
.cond-btn{display:none} /* legacy — not used */
.health-card{border-radius:12px;padding:16px;margin-bottom:12px;border-left:4px solid}
.health-card.danger{background:rgba(239,68,68,0.08);border-color:#EF4444}
.health-card.caution{background:rgba(245,158,11,0.08);border-color:#F59E0B}
.health-card.good{background:rgba(16,185,129,0.08);border-color:#10B981}
.health-card.info{background:rgba(59,130,246,0.08);border-color:#3B82F6}
.health-severity{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;margin-right:8px}
.sev-danger{background:rgba(239,68,68,0.15);color:#EF4444}
.sev-caution{background:rgba(245,158,11,0.15);color:#F59E0B}
.sev-good{background:rgba(16,185,129,0.15);color:#10B981}
.sev-info{background:rgba(59,130,246,0.15);color:#3B82F6}
.health-detail{font-size:12px;color:var(--text-secondary);line-height:1.7;margin-top:8px}
.health-tip{background:var(--card);border-radius:12px;padding:12px;margin-top:8px;font-size:12px;color:var(--text-secondary);border:1px solid var(--border)}
.health-score{display:flex;align-items:center;gap:16px;padding:18px;border-radius:16px;margin-bottom:16px;background:var(--card);color:var(--text);border:1px solid var(--border);backdrop-filter:blur(12px)}
.score-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}
.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:12px}
.profile-field{background:var(--card);border-radius:12px;padding:12px;border:1px solid var(--border)}
.profile-field label{display:block;font-size:11px;color:var(--text-tertiary);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.profile-field input,.profile-field select{width:100%;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none;transition:all .2s}
.profile-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.35)' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}
.profile-field input:focus,.profile-field select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.profile-field input::placeholder{color:var(--text-tertiary)}
.family-grid{} /* replaced by health-table */
.family-btn{display:none} /* legacy */
/* ── Health profile grid ── */
.health-ing-row{display:grid;grid-template-columns:repeat(4,1fr)}
.health-ing-row .ing-cell:nth-child(4n){border-right:none}
.ing-cell.cond-active{background:rgba(239,68,68,0.08)}
.ing-cell.cond-active .ci-n{color:#EF4444;font-weight:600}
/* ── Condition group headers ────────────────────────────────────────────── */
.cond-group-hdr{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--card);border-bottom:1px solid var(--border);cursor:pointer;font-weight:600;font-size:13px;user-select:none;transition:background .15s;color:var(--text)}
.cond-group-hdr:hover{background:var(--card-hover)}
.cond-group-hdr .cg-e{font-size:16px;line-height:1;flex-shrink:0}
.cond-group-hdr .cg-badge{background:var(--accent);color:#fff;font-size:9px;padding:1px 6px;border-radius:8px;font-weight:700;line-height:1.6}
.cond-group-hdr .cg-arr{margin-left:auto;font-size:9px;color:var(--text-tertiary);flex-shrink:0;transition:transform .15s}
.cond-group-hdr.expanded .cg-arr{transform:rotate(90deg);color:var(--accent)}
.cond-group-hdr.expanded{background:var(--accent-subtle)}
/* ── Condition/family tabs ─────────────────────────────────────────────── */
.cond-tab-bar{display:flex;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:10px}
.cond-tab{flex:1;padding:9px 12px;border:none;background:var(--card);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;color:var(--text-tertiary);line-height:1.2}
.cond-tab:first-child{border-right:1px solid var(--border)}
.cond-tab:hover:not(.active){background:var(--card-hover)}
.cond-tab.me.active{background:var(--accent-subtle);color:var(--accent);font-weight:700}
.cond-tab.fam.active{background:rgba(59,130,246,0.1);color:#3B82F6;font-weight:700}
/* Family tab active cells */
.ing-cell.fam-active{background:rgba(59,130,246,0.08)}
.ing-cell.fam-active .ci-n{color:#3B82F6;font-weight:600}
.ing-sub-row .ing-cell.fam-active{background:rgba(59,130,246,0.12);border-left-color:#3B82F6}
/* Cross-tab indicator */
.ci-cross-tag{font-size:8px;color:var(--text-tertiary);margin-top:1px;line-height:1;white-space:nowrap}
.ing-cell.health-custom .ci-n::after{content:'AI';font-size:7px;background:var(--accent);color:#fff;border-radius:3px;padding:0 3px;margin-left:3px;vertical-align:middle;font-weight:700}
.toggle-btn{padding:10px 20px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;font-weight:500}
.toggle-btn:hover{border-color:var(--accent);color:var(--accent)}
.toggle-btn:active{transform:translateY(1px)}
.profile-summary{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.profile-chip{padding:5px 12px;border-radius:8px;font-size:11px;background:var(--accent);color:#fff;font-weight:500}
.member-tab{padding:8px 16px;border-radius:12px;border:1px solid var(--border);background:var(--card);font-size:13px;cursor:pointer;transition:all .2s;color:var(--text-secondary);font-weight:500}
.member-tab:hover{border-color:var(--accent);background:var(--accent-subtle)}
.member-tab.active{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 0 12px var(--accent-glow)}
.member-tab .delete-member{margin-left:6px;font-size:10px;opacity:.6;cursor:pointer;transition:opacity .2s}
.member-tab .delete-member:hover{opacity:1;color:#EF4444}
.add-member-btn{padding:8px 16px;border-radius:12px;border:1px dashed rgba(255,255,255,0.15);background:transparent;font-size:13px;cursor:pointer;color:var(--text-tertiary);transition:all .2s}
.add-member-btn:hover{border-color:var(--accent);color:var(--accent)}
.substance-category{font-size:11px;color:var(--text-tertiary);width:100%;padding:6px 0 2px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
/* ═══ Modal ═══ */
.modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:rgba(0,0,0,0.6);display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(8px)}
.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;padding:24px;max-width:400px;width:100%;box-shadow:0 25px 50px rgba(0,0,0,0.4);animation:fadeInScale .3s ease}
/* ═══ Login Page ═══ */
.login-page{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;background:var(--bg);transition:opacity .5s,transform .5s}
.login-page.hidden{opacity:0;pointer-events:none;transform:scale(1.02)}
.login-left{flex:1;background:linear-gradient(135deg,#064e3b 0%,#065f46 40%,#059669 100%);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px;position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:rgba(16,185,129,0.08);top:-200px;right:-200px}
.login-left::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:rgba(16,185,129,0.05);bottom:-150px;left:-100px}
.login-left-content{position:relative;z-index:1;max-width:400px;text-align:center}
.login-logo{width:72px;height:72px;border-radius:20px;background:rgba(255,255,255,0.1);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;margin:0 auto 28px;border:1px solid rgba(255,255,255,0.15)}
.login-brand{font-size:32px;font-weight:700;color:white;letter-spacing:-0.03em;margin-bottom:8px}
.login-tagline{font-size:16px;color:rgba(255,255,255,0.75);line-height:1.6;margin-bottom:40px}
.login-features{text-align:left;display:flex;flex-direction:column;gap:16px}
.login-feature{display:flex;align-items:center;gap:14px;color:rgba(255,255,255,0.85);font-size:14px}
.login-feature-icon{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:1px solid rgba(255,255,255,0.1)}
.login-right{width:480px;display:flex;flex-direction:column;justify-content:center;padding:60px;background:var(--bg-secondary);box-shadow:-4px 0 30px rgba(0,0,0,0.2);border-left:1px solid var(--border)}
.login-form-header{margin-bottom:32px}
.login-form-header h2{font-size:24px;font-weight:700;color:var(--text);letter-spacing:-0.02em;margin-bottom:6px}
.login-form-header p{font-size:14px;color:var(--text-tertiary)}
.login-input-group{margin-bottom:18px}
.login-input-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:7px}
.login-input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;outline:none;transition:all .2s;background:var(--card);color:var(--text);font-family:inherit}
.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--card-hover)}
.login-input::placeholder{color:var(--text-tertiary)}
.login-submit{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10B981);color:white;font-size:15px;font-weight:600;cursor:pointer;transition:all .25s;margin-top:8px;font-family:inherit;letter-spacing:-0.01em}
.login-submit:hover{background:linear-gradient(135deg,#047857,#059669);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}
.login-submit:active{transform:translateY(0)}
.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-tertiary);font-size:13px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.login-google{width:100%;padding:12px;border-radius:12px;border:1.5px solid var(--border);background:var(--card);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s;font-family:inherit}
.login-google:hover{background:var(--card-hover);border-color:var(--border-hover)}
.login-toggle{text-align:center;margin-top:28px;font-size:13px;color:var(--text-tertiary)}
.login-toggle a{color:var(--accent);font-weight:600;text-decoration:none;cursor:pointer}
.login-toggle a:hover{text-decoration:underline;color:var(--accent-hover)}
.login-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2);color:#EF4444;padding:10px 14px;border-radius:12px;font-size:13px;margin-bottom:16px;display:none;align-items:center;gap:8px}
.login-error.show{display:flex}
.login-forgot{text-align:right;margin-top:-10px;margin-bottom:18px}
.login-forgot a{font-size:12px;color:var(--accent);text-decoration:none;font-weight:500}
.login-forgot a:hover{text-decoration:underline}
.login-terms{text-align:center;margin-top:20px;font-size:11px;color:var(--text-tertiary);line-height:1.6}
.login-terms a{color:var(--text-secondary);text-decoration:underline}
.login-guest{width:100%;padding:10px;border-radius:12px;border:1px dashed rgba(255,255,255,0.15);background:transparent;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:all .2s;margin-top:12px;font-family:inherit}
.login-guest:hover{border-color:var(--accent);color:var(--accent)}
@media(max-width:900px){
  .login-left{display:none}
  .login-right{width:100%;padding:40px 24px}
}
@keyframes loginSlideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.login-right{animation:loginSlideIn .5s ease}
/* ═══ Commercial Upgrade Styles ═══ */
.header-actions{display:flex;align-items:center;gap:10px}
.mode-toggle{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.8);padding:5px 10px;border-radius:8px;font-size:11px;cursor:pointer;transition:all .2s;font-weight:500}
.mode-toggle:hover{background:rgba(255,255,255,0.15)}
.mode-toggle.pro{background:rgba(139,92,246,0.15);border-color:rgba(139,92,246,0.3);color:#a78bfa}
.auth-btn{background:var(--accent);color:#fff;padding:5px 12px;border-radius:8px;border:none;font-size:11px;cursor:pointer;font-weight:600;transition:all .2s}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-glow)}
.auth-btn:active{transform:translateY(0)}
.pricing-btn{background:transparent;border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.8);padding:5px 10px;border-radius:8px;font-size:11px;cursor:pointer;transition:all .2s}
.pricing-btn:hover{background:rgba(255,255,255,0.08)}
.user-avatar{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.08);padding:5px 10px;border-radius:8px;color:rgba(255,255,255,0.8);font-size:11px;cursor:pointer;border:1px solid rgba(255,255,255,0.08)}
.user-avatar .circle{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;font-size:10px}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);z-index:9999;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.modal-overlay.active{display:flex}
.modal-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;padding:32px;max-width:420px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px rgba(0,0,0,0.4);animation:fadeInScale .3s ease}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-tertiary);transition:color .2s}
.modal-close:hover{color:var(--text)}
.modal-title{font-size:20px;font-weight:700;margin-bottom:20px;letter-spacing:-0.02em;color:var(--text)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}
.form-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:12px;font-size:14px;outline:none;transition:all .2s;background:var(--card);color:var(--text)}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.form-input::placeholder{color:var(--text-tertiary)}
.form-btn{width:100%;padding:12px;border-radius:12px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}
.form-btn.primary{background:var(--accent);color:white}
.form-btn.primary:hover{background:var(--accent-hover)}
.form-btn.primary:active{transform:translateY(1px)}
.form-btn.google{background:var(--card);color:var(--text);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}
.form-btn.google:hover{background:var(--card-hover)}
.form-divider{text-align:center;margin:16px 0;color:var(--text-tertiary);font-size:12px;position:relative}
.form-divider::before,.form-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:var(--border)}
.form-divider::before{left:0}
.form-divider::after{right:0}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:768px){.pricing-grid{grid-template-columns:1fr}}
.price-card{border:1px solid var(--border);border-radius:16px;padding:24px;text-align:center;transition:all .2s;position:relative;background:var(--card);backdrop-filter:blur(12px)}
.price-card:hover{border-color:var(--border-hover);box-shadow:0 4px 20px rgba(0,0,0,0.3)}
.price-card.popular{border-color:var(--accent);box-shadow:0 0 24px var(--accent-glow)}
.price-card.popular::before{content:'Popular';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:white;padding:3px 14px;border-radius:20px;font-size:11px;font-weight:600}
.price-name{font-size:16px;font-weight:700;margin-bottom:4px;color:var(--text)}
.price-amount{font-size:28px;font-weight:700;color:var(--accent);margin:12px 0}
.price-amount span{font-size:14px;font-weight:400;color:var(--text-tertiary)}
.price-features{text-align:left;margin:16px 0;font-size:13px;color:var(--text-secondary);line-height:2}
.price-btn{width:100%;padding:10px;border-radius:12px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.price-btn.filled{background:var(--accent);color:white}
.price-btn.filled:hover{background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow)}
.price-btn.outline{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.price-btn.outline:hover{background:var(--accent-subtle)}
.rxn-confidence{display:inline-block;font-size:10px;background:var(--accent-subtle);color:var(--accent);padding:2px 7px;border-radius:5px;font-weight:600;margin-left:6px}
.ref-toggle{background:none;border:1px solid var(--border);padding:4px 8px;border-radius:5px;font-size:10px;cursor:pointer;color:var(--text-tertiary);transition:all .2s;margin-left:auto}
.ref-toggle:hover{border-color:var(--accent);color:var(--accent)}
.ref-detail{display:none;background:var(--card);border-radius:8px;padding:10px;margin-top:8px;font-size:11px;line-height:1.7;color:var(--text-secondary);border:1px solid var(--border)}
.ref-detail.show{display:block}
.pro-badge{display:inline-block;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:white;font-size:9px;padding:2px 6px;border-radius:4px;font-weight:600;margin-left:4px;vertical-align:middle}
.pro-only-blur{filter:blur(3px);pointer-events:none;user-select:none;position:relative}
.export-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:12px;background:var(--card);border:1px solid var(--border);margin-bottom:16px}
.export-bar-label{font-size:13px;font-weight:600;color:var(--text)}
.export-bar-buttons{display:flex;gap:8px}
.export-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:8px 18px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.export-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}
.export-btn-pdf{border-color:#EF4444;color:#EF4444;background:rgba(239,68,68,0.08)}
.export-btn-pdf:hover{background:rgba(239,68,68,0.18);color:#EF4444;border-color:#EF4444}
/* ── Recipe & YouTube ─────────────────────────────────────────────── */
.cuisine-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.cuisine-label{font-size:11px;color:var(--text-tertiary);font-weight:600;white-space:nowrap;margin-right:2px}
.cuisine-chip{padding:5px 11px;border-radius:20px;border:1px solid var(--border);background:var(--card);font-size:11px;cursor:pointer;transition:all .2s;white-space:nowrap;color:var(--text-secondary)}
.cuisine-chip:hover{border-color:var(--accent);color:var(--accent)}
.cuisine-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 0 12px var(--accent-glow)}
.recipe-card{border:1px solid var(--border);border-radius:16px;padding:0;margin-bottom:14px;background:var(--card);transition:all .2s;overflow:hidden;backdrop-filter:blur(12px)}
.recipe-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.3);transform:translateY(-1px);border-color:var(--border-hover)}
.recipe-card-header{display:flex;align-items:flex-start;gap:12px;padding:16px;cursor:pointer}
.recipe-num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.recipe-title-wrap{flex:1;min-width:0}
.recipe-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.3}
.recipe-title-en{font-size:11px;color:var(--text-tertiary);font-weight:400;margin-top:2px}
.recipe-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.recipe-tag{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;background:var(--card);color:var(--text-secondary)}
.recipe-tag.cuisine{background:var(--accent-subtle);color:var(--accent);border:1px solid rgba(16,185,129,0.2)}
.recipe-tag.diff-easy{background:rgba(59,130,246,0.1);color:#3B82F6;border:1px solid rgba(59,130,246,0.2)}
.recipe-tag.diff-medium{background:rgba(245,158,11,0.1);color:#F59E0B;border:1px solid rgba(245,158,11,0.2)}
.recipe-tag.diff-hard{background:rgba(239,68,68,0.1);color:#EF4444;border:1px solid rgba(239,68,68,0.2)}
.recipe-tag.diff-쉬움{background:rgba(59,130,246,0.1);color:#3B82F6;border:1px solid rgba(59,130,246,0.2)}
.recipe-tag.diff-보통{background:rgba(245,158,11,0.1);color:#F59E0B;border:1px solid rgba(245,158,11,0.2)}
.recipe-tag.diff-어려움{background:rgba(239,68,68,0.1);color:#EF4444;border:1px solid rgba(239,68,68,0.2)}
.recipe-body{padding:0 16px 14px}
.recipe-desc{font-size:12.5px;color:var(--text-secondary);line-height:1.65}
.recipe-health{font-size:11.5px;padding:8px 12px;border-radius:12px;background:var(--accent-subtle);color:var(--accent);border:1px solid rgba(16,185,129,0.15);margin-top:10px}
.recipe-ings{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px}
.recipe-ing{padding:3px 8px;border-radius:6px;font-size:10px;background:var(--accent-subtle);color:var(--accent);border:1px solid rgba(16,185,129,0.15);font-weight:500}
.recipe-yt-footer{border-top:1px solid var(--border);padding:10px 16px;display:flex;gap:8px}
.recipe-save-btn{flex-shrink:0;padding:10px 16px;border-radius:12px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.recipe-save-btn:hover{background:var(--accent-subtle);box-shadow:0 0 12px var(--accent-glow)}
.yt-open-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:12px;border:none;background:linear-gradient(135deg,#ff0000,#cc0000);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s}
.yt-open-btn:hover{background:linear-gradient(135deg,#cc0000,#aa0000);box-shadow:0 4px 16px rgba(220,38,38,.3);transform:translateY(-1px)}
.yt-open-btn:active{transform:translateY(0)}
.yt-open-btn.open{background:linear-gradient(135deg,#cc0000,#aa0000)}
.yt-open-btn svg{width:16px;height:16px;fill:#fff;flex-shrink:0}
.yt-panel{display:none;border-top:1px solid var(--border)}
.yt-panel-inner{padding:14px 16px}
.yt-sort-bar{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap;align-items:center;background:var(--card);border-radius:12px;padding:6px 8px;border:1px solid var(--border)}
.yt-sort-label{font-size:11px;color:var(--text-tertiary);font-weight:600;padding:0 4px;white-space:nowrap}
.yt-sort-btn{padding:5px 11px;border-radius:8px;border:none;background:transparent;font-size:11.5px;cursor:pointer;transition:all .15s;font-weight:500;color:var(--text-secondary);white-space:nowrap}
.yt-sort-btn:hover{background:var(--card-hover);color:var(--text)}
.yt-sort-btn.active{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 0 8px var(--accent-glow)}
.yt-loading{text-align:center;padding:24px;color:var(--text-tertiary);font-size:13px}
.yt-error{padding:12px;border-radius:12px;background:rgba(239,68,68,0.1);color:#EF4444;font-size:12px;border:1px solid rgba(239,68,68,0.2)}
.yt-feat{display:block;text-decoration:none;color:inherit;border-radius:16px;overflow:hidden;border:1px solid var(--border);margin-bottom:12px;transition:all .2s;background:var(--card)}
.yt-feat:hover{box-shadow:0 4px 20px rgba(0,0,0,0.3);border-color:var(--border-hover);transform:translateY(-1px)}
.yt-feat-thumb{position:relative;width:100%;aspect-ratio:16/9;background:rgba(255,255,255,0.02);overflow:hidden}
.yt-feat-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.yt-feat:hover .yt-feat-thumb img{transform:scale(1.03)}
.yt-feat-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;background:rgba(0,0,0,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}
.yt-feat:hover .yt-feat-play{background:#ff0000;transform:translate(-50%,-50%) scale(1.1)}
.yt-feat-dur{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.82);color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-weight:700}
.yt-feat-badge{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,#ff0000,#cc0000);color:#fff;font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.05em}
.yt-feat-info{padding:12px}
.yt-feat-title{font-size:13px;font-weight:700;color:var(--text);line-height:1.45}
.yt-feat-meta{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap;align-items:center}
.yt-feat-channel{font-size:11px;color:var(--text-tertiary);font-weight:500}
.yt-feat-stat{font-size:11px;color:var(--text-tertiary)}
.yt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.yt-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .2s;background:var(--card)}
.yt-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.25);border-color:var(--border-hover);transform:translateY(-1px)}
.yt-thumb{position:relative;width:100%;aspect-ratio:16/9;background:rgba(255,255,255,0.02);overflow:hidden}
.yt-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.yt-card:hover .yt-thumb img{transform:scale(1.04)}
.yt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;background:rgba(0,0,0,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}
.yt-card:hover .yt-play{opacity:1;background:#ff0000}
.yt-dur{position:absolute;bottom:4px;right:4px;background:rgba(0,0,0,.82);color:#fff;font-size:9px;padding:2px 5px;border-radius:3px;font-weight:700}
.yt-info{padding:8px;flex:1;display:flex;flex-direction:column;gap:3px}
.yt-vtitle{font-size:11.5px;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.yt-vchannel{font-size:10px;color:var(--text-tertiary)}
.yt-vstats{display:flex;gap:5px;flex-wrap:wrap;margin-top:auto;padding-top:4px}
.yt-vstat{font-size:10px;color:var(--text-tertiary)}
/* ── YouTube In-App Modal Player ───────────────────────────────── */
.yt-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9000;display:flex!important;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.yt-modal-overlay.show{opacity:1;pointer-events:all}
.yt-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:720px;padding:16px 16px 28px;transform:translateY(100%);transition:transform .32s cubic-bezier(.32,.72,0,1)}
.yt-modal-overlay.show .yt-modal{transform:translateY(0)}
.yt-modal-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.yt-modal-back{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.1);color:#fff;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}
.yt-modal-back:hover{background:rgba(255,255,255,.2)}
.yt-modal-title{flex:1;font-size:13px;font-weight:600;color:#fff;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.yt-modal-yt-link{width:32px;height:32px;border-radius:50%;background:rgba(255,0,0,.15);color:#ff4444;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;text-decoration:none}
.yt-modal-yt-link:hover{background:rgba(255,0,0,.3);color:#ff0000;transform:scale(1.08)}
.yt-modal-close{width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.1);color:#fff;font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}
.yt-modal-close:hover{background:rgba(255,255,255,.2)}
.yt-iframe-wrap{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#000;position:relative;z-index:1}
.yt-iframe-wrap iframe{width:100%;height:100%;border:none;display:block;position:relative;z-index:2}
.yt-modal-hint{margin-top:10px;padding:8px 12px;border-radius:8px;background:rgba(255,255,255,.05);font-size:11px;color:rgba(255,255,255,.45);text-align:center;line-height:1.6}
.version-badge{font-size:10px;color:rgba(255,255,255,0.4);margin-left:4px}
.trust-footer{background:var(--bg-secondary);border-top:1px solid var(--border);padding:20px;margin-top:40px;text-align:center;font-size:11px;color:var(--text-tertiary);line-height:2}
.trust-footer a{color:var(--accent);text-decoration:none}
.trust-footer a:hover{text-decoration:underline}
.methodology-banner{background:var(--accent-subtle);border:1px solid rgba(16,185,129,0.15);border-radius:16px;padding:16px 20px;margin-bottom:18px;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--accent);cursor:pointer;transition:all .2s}
.methodology-banner:hover{box-shadow:0 0 16px var(--accent-glow)}
.methodology-content{display:none;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:18px;font-size:13px;color:var(--text-secondary);line-height:1.8}
.methodology-content.show{display:block}
.methodology-content h3{font-size:14px;font-weight:700;color:var(--text);margin:12px 0 6px}
.methodology-content h3:first-child{margin-top:0}

/* ── DevNav ──────────────────────────────────────────────────────────────── */
/* z-index:99999 — DEV ONLY, reduce before production */
#devNav { position:fixed;bottom:0;left:0;right:0;z-index:99999;background:rgba(15,15,15,0.93);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:7px 10px;display:flex;align-items:center;gap:5px;overflow-x:auto;border-top:1px solid rgba(255,255,255,0.08);-ms-overflow-style:none;scrollbar-width:none }
#devNav::-webkit-scrollbar { display:none }
#devNav .dev-label { color:#f97316;font-size:9px;font-weight:700;white-space:nowrap;flex-shrink:0;letter-spacing:.06em;padding:2px 6px;background:rgba(249,115,22,0.15);border-radius:4px;border:1px solid rgba(249,115,22,0.3) }
#devNav .dev-sep { width:1px;height:18px;background:rgba(255,255,255,0.15);flex-shrink:0;margin:0 2px }
#devNav button { padding:4px 9px;border-radius:6px;border:1px solid rgba(255,255,255,0.18);background:transparent;color:#e5e5e5;font-size:11px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s;font-family:inherit }
#devNav button:hover { background:rgba(255,255,255,0.12) }
#devNav .dev-close { margin-left:auto;flex-shrink:0;border-color:rgba(255,255,255,0.1) }

/* ── Touch target: ingredient cells ─────────────────────────────────────── */
/* Overrides above for 4-col layout with 44px min tap target — already set above */

/* ── Analyze button (main, below all inputs) ─────────────────────────────── */
.analyze-btn--main{width:100%;margin:0 0 20px;padding:16px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10B981);color:#fff;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 0 24px var(--accent-glow)}
.analyze-btn--main:disabled{background:rgba(255,255,255,0.06);color:var(--text-tertiary);cursor:not-allowed;box-shadow:none}
.analyze-btn--main:not(:disabled):hover{background:linear-gradient(135deg,#10B981,#34D399);box-shadow:0 4px 30px var(--accent-glow);transform:translateY(-1px)}
.analyze-btn--main:not(:disabled):active{transform:translateY(1px)}

/* ── Progressive Disclosure: Profile Steps ──────────────────────────────── */
.profile-steps{display:flex;align-items:center;gap:0;margin-bottom:16px;padding:4px 0}
.profile-step{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:1.5px solid var(--border);background:var(--card);color:var(--text-tertiary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;flex-shrink:0}
.profile-step .step-num{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,0.06);color:var(--text-tertiary);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.profile-step.active{border-color:var(--accent);color:var(--accent)}
.profile-step.active .step-num{background:var(--accent);color:#fff}
.profile-step.completed{border-color:rgba(16,185,129,0.3);color:var(--accent)}
.profile-step.completed .step-num{background:var(--accent-subtle);color:var(--accent)}
.step-connector{flex:1;height:1.5px;background:var(--border);min-width:8px;max-width:24px}
.profile-step-panel{animation:fadeInUp .25s ease}
.step-next-btn,.step-back-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;font-weight:500}
.step-next-btn{background:var(--accent);color:#fff;border-color:transparent}
.step-next-btn:hover{background:var(--accent-hover)}
.step-next-btn:active{transform:translateY(1px)}
.step-back-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── Mobile Bottom Navigation ────────────────────────────────────────────── */
.mobile-nav{display:none}
@media(max-width:768px){
  .mobile-nav{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:9000;
    background:rgba(18,20,21,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-top:1px solid rgba(255,255,255,0.06);padding:4px 0 env(safe-area-inset-bottom);
    box-shadow:0 -2px 24px rgba(0,0,0,0.4)
  }
  .mobile-nav-btn{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:4px;padding:8px 4px 6px;border:none;background:transparent;cursor:pointer;
    min-height:56px;color:rgba(255,255,255,0.35);transition:all .2s ease;font-family:inherit;
    position:relative
  }
  .mobile-nav-btn.active{color:var(--accent)}
  .mobile-nav-btn::before{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:0;height:2px;background:var(--accent);border-radius:0 0 2px 2px;transition:width .25s ease
  }
  .mobile-nav-btn.active::before{width:32px}
  .mobile-nav-btn .mnav-svg{width:22px;height:22px;transition:transform .2s ease}
  .mobile-nav-btn.active .mnav-svg{transform:scale(1.08)}
  .mobile-nav-btn .mnav-label{font-size:11px;font-weight:600;line-height:1;letter-spacing:0.01em}
  .mobile-nav-btn.active .mnav-label{font-weight:700}
  /* Push container content above the nav */
  body{padding-bottom:calc(64px + env(safe-area-inset-bottom))}
  #devNav{display:none}
}

/* ── Language Switcher ───────────────────────────────────────────────────── */
.lang-btn{padding:5px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.15);background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.8);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.05em}
.lang-btn:hover{background:rgba(255,255,255,0.12)}

/* ── Meal Planner Responsive ─────────────────────────────────────────────── */
@media(max-width:768px){
  .mobile-nav-btn .mnav-svg{width:20px;height:20px}
  .mobile-nav-btn .mnav-label{font-size:10px}
  .mobile-nav-btn{gap:3px;padding:6px 2px 5px}
}

/* ── Photo Scan Button (in search bar) ──────────────────────────────────── */
.photo-scan-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:1px solid var(--border);border-radius:8px;padding:5px 8px;font-size:16px;cursor:pointer;transition:all .2s;line-height:1;color:var(--text-secondary)}
.photo-scan-btn:hover{background:var(--accent-subtle);border-color:var(--accent);color:var(--accent)}
/* Loading spinner for AI modals */
.loading-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,0.1);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── More Menu ─────────────────────────────────────────────────────────── */
.more-menu-overlay {
  position:fixed; inset:0; z-index:7000;
  background:rgba(0,0,0,0.5);
  display:flex; align-items:flex-end; justify-content:center;
  padding-bottom:70px;
  backdrop-filter:blur(4px);
}
.more-menu {
  background:var(--bg-secondary); border-radius:20px 20px 0 0;
  width:100%; max-width:480px;
  box-shadow:0 -4px 30px rgba(0,0,0,0.4);
  padding:12px 0 8px;
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:4px;
  border:1px solid var(--border);
  border-bottom:none;
}
.more-menu button {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:12px 8px; border:none; background:transparent;
  font-size:11px; font-weight:600; color:var(--text-secondary); cursor:pointer;
  border-radius:12px; transition:all .15s;
}
.more-menu button:hover { background:var(--card-hover); color:var(--text); }
.more-menu button:active { transform:translateY(1px); opacity:0.8; }
.more-menu button span { font-size:22px; }

/* ── Global select/textarea dark styles ───────────────────────────────── */
select,textarea{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:8px;outline:none;font-family:inherit}
select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
select option{background:var(--bg-secondary);color:var(--text)}

/* ── Glass overlay for modals ────────────────────────────────── */
.glass-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:var(--z-modal-overlay);display:none;align-items:center;justify-content:center}
.glass-overlay.open{display:flex}

/* ── Accent stripe (top of page) ─────────────────────────────── */
.accent-stripe{width:100%;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);position:fixed;top:0;left:0;z-index:99999}

/* ── Skeleton loading ────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--card-hover) 50%,var(--card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
.skeleton-container{padding:20px;display:flex;flex-direction:column;gap:16px}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes fadeInScale{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 20px 4px var(--accent-glow)}}

/* ── Reduced motion ──────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}}

/* ══════════════════════════════════════════════════════════════════
   TAB NAVIGATION SYSTEM
   ══════════════════════════════════════════════════════════════════ */

/* Tab sections - only active is visible */
.tab-section{display:none}
.tab-section.active{display:block;animation:fadeIn 0.25s ease}

/* Desktop header tabs */
.header-tabs{display:flex;align-items:center;gap:2px;background:var(--card);border-radius:12px;padding:3px}
.header-tab{padding:8px 18px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:inherit;white-space:nowrap;display:flex;align-items:center;gap:6px}
.header-tab:hover{color:var(--text);background:rgba(255,255,255,0.04)}
.header-tab.active{background:var(--accent);color:white;font-weight:600;box-shadow:0 2px 8px var(--accent-glow)}
.header-tab .tab-icon{font-size:15px;line-height:1}
@media(max-width:768px){.header-tabs{display:none}}

/* Header layout update */
.header-left{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header-center{flex:1;display:flex;justify-content:center}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ══════════════════════════════════════════════════════════════════
   HOME DASHBOARD
   ══════════════════════════════════════════════════════════════════ */
.home-container{max-width:700px;margin:0 auto;padding:20px 16px}

.home-hero{text-align:center;padding:48px 20px 32px}
.home-hero h2{font-size:28px;font-weight:700;letter-spacing:-0.02em;margin-bottom:8px;background:linear-gradient(135deg,var(--text),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.home-hero p{color:var(--text-secondary);font-size:15px;line-height:1.5;max-width:480px;margin:0 auto}

.home-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:32px}
.home-action-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all 0.2s;position:relative;overflow:hidden;display:flex;align-items:center;gap:14px;text-align:left}
.home-action-card:hover{background:var(--card-hover);border-color:var(--border-hover)}
.home-action-card:active{opacity:0.9}
.home-action-card .action-icon{font-size:28px;flex-shrink:0}
.home-action-card .action-icon img{width:40px;height:40px;border-radius:10px;object-fit:cover}
.home-action-card .action-text{flex:1;min-width:0}
.home-action-card .action-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap}
.home-action-card .action-desc{font-size:11px;color:var(--text-tertiary);line-height:1.4}
@media(min-width:600px){.home-actions{grid-template-columns:repeat(3,1fr);gap:12px}.home-action-card{flex-direction:column;text-align:center;padding:24px 16px}.home-action-card .action-icon{margin-bottom:8px}}

.home-section-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}

.home-recent{margin-bottom:32px}
.home-recent-list{display:grid;gap:8px}
.home-recent-item{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:12px}
.home-recent-item:hover{background:var(--card-hover);border-color:var(--border-hover)}
.home-recent-item .recent-icon{font-size:24px;flex-shrink:0}
.home-recent-item .recent-info{flex:1;min-width:0}
.home-recent-item .recent-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.home-recent-item .recent-meta{font-size:11px;color:var(--text-tertiary);margin-top:2px}
.home-recent-item .recent-date{font-size:10px;color:var(--text-tertiary);margin-top:2px}
.home-recent-item .recent-arrow{font-size:18px;color:var(--text-tertiary);flex-shrink:0}

.home-discover{margin-bottom:32px}
.home-discover-grid{display:grid;grid-template-columns:1fr;gap:8px}
.home-discover-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:14px}
.home-discover-card:hover{background:var(--card-hover);border-color:var(--border-hover)}
.home-discover-card .discover-icon{font-size:24px;flex-shrink:0}
.home-discover-card .discover-text{flex:1;min-width:0}
.home-discover-card .discover-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap}
.home-discover-card .discover-desc{font-size:11px;color:var(--text-tertiary);line-height:1.4}
@media(min-width:600px){.home-discover-grid{grid-template-columns:repeat(2,1fr);gap:10px}}

.home-stats{text-align:center;padding:20px;color:var(--text-tertiary);font-size:12px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.home-stat{display:flex;align-items:center;gap:4px}
.home-stat strong{color:var(--accent);font-weight:600}

/* ── New User Onboarding ── */
.home-onboard{padding:0 4px}
.home-onboard-hero{text-align:center;padding:48px 16px 32px;position:relative}
.home-onboard-hero h1{font-size:24px;font-weight:700;letter-spacing:-0.02em;margin-bottom:12px;background:linear-gradient(135deg,#fff 30%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.3}
.home-onboard-hero p{color:var(--text-secondary);font-size:14px;line-height:1.6;max-width:440px;margin:0 auto}
.onboard-logo-glow{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:120px;height:120px;background:radial-gradient(circle,rgba(16,185,129,0.12) 0%,transparent 70%);border-radius:50%;pointer-events:none}

.home-start-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;margin-bottom:12px}
.home-start-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.home-start-btn:active{transform:scale(0.98)}

.home-alt-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:32px}
.home-alt-btn{display:flex;align-items:center;gap:8px;padding:14px 12px;border:1px solid var(--border);border-radius:12px;background:var(--card);color:var(--text);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;font-family:inherit}
.home-alt-btn:hover{background:var(--card-hover);border-color:var(--border-hover)}
.home-alt-btn svg{flex-shrink:0;color:var(--accent)}

.home-how-it-works{margin-bottom:24px}
.how-steps{display:flex;flex-direction:column;gap:0}
.how-step{display:flex;align-items:flex-start;gap:14px;padding:16px 0;position:relative}
.how-step:not(:last-child)::after{content:'';position:absolute;left:16px;top:44px;bottom:0;width:1px;background:var(--border)}
.how-step-num{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.how-step-text{font-size:13px;color:var(--text-secondary);line-height:1.5}
.how-step-text strong{color:var(--text);font-weight:600;display:block;margin-bottom:2px}

/* ── Returning User Quick Duo ── */
.home-quick-duo{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.home-primary-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.home-primary-btn:hover{filter:brightness(1.1)}
.home-primary-btn:active{transform:scale(0.97)}
.home-primary-btn--secondary{background:var(--card);border:1px solid var(--border);color:var(--text)}
.home-primary-btn--secondary:hover{background:var(--card-hover);border-color:var(--border-hover);filter:none}

/* ── Home Feature Showcase ── */
.home-features{margin:24px 0 16px}
.hf-section{margin-bottom:16px}
.hf-section-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:12px 12px 0 0;border-bottom:2px solid var(--hf-color, var(--accent))}
.hf-section-icon{display:flex;align-items:center;color:var(--hf-color, var(--accent))}
.hf-section-title{font-size:14px;font-weight:700;color:var(--text)}
.hf-section-count{margin-left:auto;font-size:11px;color:var(--text-tertiary);background:rgba(255,255,255,0.06);padding:2px 8px;border-radius:10px}
.hf-items{display:grid;gap:1px;background:var(--border);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;overflow:hidden}
.hf-item{display:block;width:100%;text-align:left;padding:12px 14px;border:none;background:var(--card);color:var(--text);cursor:pointer;transition:background .15s;font-family:inherit;position:relative}
.hf-item:hover{background:var(--card-hover)}
.hf-item-label{font-size:13px;font-weight:600;margin-bottom:2px;padding-right:20px}
.hf-item-desc{font-size:11px;color:var(--text-tertiary);line-height:1.4;padding-right:20px}
.hf-item-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);opacity:.4;transition:opacity .15s,transform .15s}
.hf-item:hover .hf-item-arrow{opacity:.8;transform:translateY(-50%) translateX(2px)}
@media(min-width:600px){.hf-items{grid-template-columns:1fr 1fr}}

/* ── Feature Detail Popup ── */
.fd-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:9500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s ease;backdrop-filter:blur(8px)}
.fd-overlay.open{opacity:1}
.fd-modal{position:relative;background:#1a1d20;border:1px solid rgba(255,255,255,.1);border-radius:20px;width:100%;max-width:420px;padding:32px 28px 24px;box-shadow:0 16px 48px rgba(0,0,0,.6);animation:fdSlideUp .3s ease}
@keyframes fdSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fd-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.fd-close:hover{background:rgba(255,255,255,.08)}
.fd-icon-badge{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;margin-bottom:12px}
.fd-icon-badge svg{width:24px;height:24px}
.fd-category{font-size:12px;font-weight:600;margin-bottom:4px;letter-spacing:.3px;text-transform:uppercase}
.fd-title{font-size:20px;font-weight:700;color:var(--text);margin:0 0 12px;line-height:1.3}
.fd-detail{font-size:14px;color:var(--text-secondary);line-height:1.7;margin:0 0 20px}
.fd-modal-guide{max-width:480px;max-height:88vh;overflow-y:auto;padding:28px 24px 20px}
.fd-actions{display:flex;gap:10px;position:sticky;bottom:0;padding:16px 0 0;background:#1a1d20;z-index:1}
.fd-go-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border:none;border-radius:12px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s;font-family:inherit;width:100%;justify-content:center}
.fd-go-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}
.fd-go-btn svg{transition:transform .2s}
.fd-go-btn:hover svg{transform:translateX(3px)}

/* Guide Steps */
.fd-guide{margin:0 0 8px;border-top:1px solid var(--border);padding-top:16px}
.fd-guide-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text);margin-bottom:14px}
.fd-step{display:flex;gap:12px;margin-bottom:16px}
.fd-step:last-child{margin-bottom:8px}
.fd-step-num{flex-shrink:0;width:24px;height:24px;border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}
.fd-step-content{flex:1;min-width:0}
.fd-step-text{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px}
.fd-step-text b{color:var(--text);font-weight:600}
.fd-step-tip{font-size:11px;color:var(--accent);display:flex;align-items:flex-start;gap:4px;margin-top:6px;line-height:1.4}
.fd-step-tip svg{flex-shrink:0;margin-top:1px}

/* Mockup UI Components */
.fd-mockup{background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:10px;padding:10px;margin-top:6px;font-size:12px}
.fdm-nav{display:flex;gap:4px;margin-bottom:0}
.fdm-nav-tab{padding:5px 10px;border-radius:8px;font-size:11px;color:var(--text-tertiary);background:rgba(255,255,255,.04);text-align:center;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fdm-nav-tab.active{background:var(--accent);color:#fff;font-weight:600}
.fdm-btn{display:inline-block;padding:6px 12px;border-radius:8px;font-size:11px;font-weight:600;color:var(--text-secondary);background:rgba(255,255,255,.06);border:1px solid var(--border);white-space:nowrap}
.fdm-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.fdm-search{display:flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);font-size:11px;background:rgba(255,255,255,.03)}
.fdm-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;padding:10px;margin-top:6px}
.fdm-card-title{font-size:12px;font-weight:600;color:var(--text)}
.fdm-card-sub{font-size:10px;color:var(--text-tertiary);margin-top:2px}
.fdm-chips{display:flex;gap:4px;flex-wrap:wrap;margin:6px 0}
.fdm-chip{padding:3px 9px;border-radius:12px;font-size:10px;color:var(--text-tertiary);background:rgba(255,255,255,.04);border:1px solid var(--border)}
.fdm-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.fdm-wizard{display:flex;gap:3px;margin-bottom:8px}
.fdm-wiz-step{flex:1;padding:4px 6px;border-radius:6px;font-size:10px;text-align:center;background:rgba(255,255,255,.04);color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fdm-wiz-step.active{background:var(--accent);color:#fff;font-weight:600}
.fdm-wiz-step.done{background:rgba(16,185,129,.15);color:var(--accent)}
.fdm-img{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(16,185,129,.03));border-radius:8px;font-size:32px;min-height:60px}
.fdm-results{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.fdm-result-row{font-size:11px;color:var(--text-secondary);padding:4px 8px;background:rgba(255,255,255,.03);border-radius:6px;line-height:1.4}
.fdm-ingredients{display:flex;gap:6px;flex-wrap:wrap}
.fdm-ing{padding:5px 10px;border-radius:8px;font-size:11px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text-secondary)}
.fdm-ing.selected{border-color:var(--accent);background:rgba(16,185,129,.08);color:var(--accent)}
.fdm-actions-row{display:flex;gap:12px;padding-top:6px;margin-top:6px;border-top:1px solid var(--border);font-size:11px;color:var(--text-tertiary)}
.fdm-action{display:flex;align-items:center;gap:3px}
.fdm-calendar{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-top:6px}
.fdm-cal-header{padding:6px 10px;font-size:11px;font-weight:600;color:var(--text);background:rgba(255,255,255,.04);border-bottom:1px solid var(--border)}
.fdm-cal-slot{display:flex;justify-content:space-between;align-items:center;padding:5px 10px;font-size:11px;color:var(--text-tertiary);border-bottom:1px solid rgba(255,255,255,.04)}
.fdm-cal-slot:last-child{border-bottom:none}
.fdm-cal-slot.filled{color:var(--text-secondary)}
.fdm-cal-add{color:var(--accent);font-weight:700;font-size:14px}
.fdm-bars{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.fdm-bar-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary)}
.fdm-bar{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.fdm-bar-fill{height:100%;border-radius:4px;max-width:100%}
.fdm-chart{margin-top:6px}
.fdm-chart-bars{display:flex;align-items:flex-end;gap:4px;height:60px}
.fdm-chart-bar{flex:1;background:var(--accent);border-radius:3px 3px 0 0;opacity:.5;min-height:2px}
.fdm-chart-bar.active{opacity:1}
.fdm-chart-labels{display:flex;gap:4px;margin-top:3px}
.fdm-chart-labels span{flex:1;text-align:center;font-size:9px;color:var(--text-tertiary)}
.fdm-score{display:flex;align-items:center;gap:12px;margin-top:6px}
.fdm-score-ring{width:50px;height:50px;border-radius:50%;border:3px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--accent)}
.fdm-score-label{font-size:12px;color:var(--text-secondary);font-weight:600}

/* ── App Map Overlay ── */
.appmap-overlay{position:fixed;inset:0;z-index:9600;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center}
@media(min-width:600px){.appmap-overlay{align-items:center}}
.appmap-modal{background:var(--bg);border-radius:20px 20px 0 0;width:100%;max-width:540px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease}
@media(min-width:600px){.appmap-modal{border-radius:20px;max-height:80vh}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.appmap-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}
.appmap-header h2{font-size:18px;font-weight:700;margin:0}
.appmap-close{width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,0.08);color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.appmap-body{overflow-y:auto;padding:16px 20px 24px;-webkit-overflow-scrolling:touch}
.appmap-section{margin-bottom:20px}
.appmap-sec-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.appmap-sec-items{display:grid;gap:6px}
.appmap-link{display:block;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;transition:all .15s;color:var(--text)}
.appmap-link:hover{background:var(--card-hover);border-color:var(--border-hover)}
.appmap-link-label{font-size:13px;font-weight:600;display:block}
.appmap-link-desc{font-size:11px;color:var(--text-tertiary);display:block;margin-top:2px}
@media(min-width:480px){.appmap-sec-items{grid-template-columns:1fr 1fr}}

/* ══════════════════════════════════════════════════════════════════
   ANALYZE STEP WIZARD
   ══════════════════════════════════════════════════════════════════ */
.wizard-container{max-width:640px;margin:0 auto;padding:20px 16px}

.wizard-progress{display:flex;gap:6px;margin-bottom:24px;padding:4px;background:var(--card);border-radius:14px;border:1px solid var(--border)}
.wizard-step{flex:1;text-align:center;padding:10px 8px;border-radius:10px;font-size:12px;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:none;font-family:inherit}
.wizard-step .wizard-step-num{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,0.06);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;color:var(--text-tertiary)}
.wizard-step.active{background:var(--accent);color:white}
.wizard-step.active .wizard-step-num{background:rgba(255,255,255,0.2);color:white}
.wizard-step.completed{color:var(--accent);background:var(--accent-subtle)}
.wizard-step.completed .wizard-step-num{background:var(--accent);color:white}
.wizard-step-label{font-size:12px}
@media(max-width:480px){.wizard-step .wizard-step-label{display:none}.wizard-step{padding:10px 6px}}

.wizard-panel{display:none}
.wizard-panel.active{display:block;animation:fadeInUp 0.3s ease}

.wizard-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:12px;padding-top:16px;border-top:1px solid var(--border)}
.wizard-back{padding:12px 24px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:inherit}
.wizard-back:hover{background:var(--card);color:var(--text);border-color:var(--border-hover)}
.wizard-next{padding:12px 24px;border-radius:10px;border:none;background:var(--accent);color:white;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:inherit;box-shadow:0 2px 8px var(--accent-glow)}
.wizard-next:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}
.wizard-next:active{transform:translateY(0)}
.wizard-skip{padding:12px 24px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:inherit}
.wizard-skip:hover{color:var(--text);border-color:var(--border-hover)}
.wizard-analyze-btn{padding:14px 32px;border-radius:12px;border:none;background:linear-gradient(135deg,#059669,#10B981);color:white;font-size:15px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:inherit;box-shadow:0 4px 16px var(--accent-glow);flex:1}
.wizard-analyze-btn:hover{box-shadow:0 6px 24px var(--accent-glow);transform:translateY(-1px)}
.wizard-analyze-btn:active{transform:translateY(0)}
.wizard-analyze-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.wizard-next-btn{padding:12px 24px;border-radius:10px;border:none;background:var(--accent);color:white;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:inherit;box-shadow:0 2px 8px var(--accent-glow);white-space:nowrap}
.wizard-next-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}
.wizard-back-btn{padding:12px 24px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:inherit;white-space:nowrap}
.wizard-back-btn:hover{background:var(--card);color:var(--text);border-color:var(--border-hover)}

/* ══════════════════════════════════════════════════════════════════
   SUB-TABS (Recipes tab)
   ══════════════════════════════════════════════════════════════════ */
.sub-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--card);border-radius:12px;padding:4px;border:1px solid var(--border)}
.sub-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:8px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all 0.15s;font-family:inherit;text-align:center}
.sub-tab:hover{color:var(--text);background:rgba(255,255,255,0.03)}
.sub-tab.active{background:var(--accent);color:white;font-weight:600}

/* ══════════════════════════════════════════════════════════════════
   PROFILE HUB (Profile tab)
   ══════════════════════════════════════════════════════════════════ */
.profile-container{max-width:700px;margin:0 auto;padding:20px 16px}
.profile-hub-header{text-align:center;padding:32px 20px 24px}
.profile-hub-header h2{font-size:22px;font-weight:700;margin-bottom:6px}
.profile-hub-header p{color:var(--text-secondary);font-size:13px}

.profile-hub-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:24px}
.profile-hub-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:14px;text-align:left}
.profile-hub-card:hover{background:var(--card-hover);border-color:var(--border-hover)}
.profile-hub-card:active{opacity:0.9}
.profile-hub-card .hub-icon{font-size:28px;flex-shrink:0}
.profile-hub-card .hub-text{flex:1;min-width:0}
.profile-hub-card .hub-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap}
.profile-hub-card .hub-desc{font-size:11px;color:var(--text-tertiary);line-height:1.4}
.profile-hub-card.hub-active{border-color:var(--accent);background:var(--accent-subtle)}
@media(min-width:600px){.profile-hub-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

#profileSectionContent{min-height:200px}

/* Inline content containers for tab rendering */
#planContent,#recipesMyContent,#recipesCommunityContent,#profileSectionContent{min-height:100px}
.tab-inner-container{max-width:900px;margin:0 auto;padding:20px 16px}
.recipes-container{max-width:700px;margin:0 auto;padding:20px 16px}
