/* ═══ Calendar Overlay ═══ */
.cal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:250;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}
.cal-box{background:var(--card);border-radius:var(--r);padding:20px;width:calc(100% - 32px);max-width:380px;animation:slideUp .3s ease}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-header .cal-title{font-size:16px;font-weight:600}
.cal-header button{background:none;border:none;color:var(--pri);font-size:20px;cursor:pointer;padding:6px 10px;border-radius:8px}
.cal-header button:hover{background:rgba(var(--pri-rgb),.1)}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:11px;color:var(--muted);margin-bottom:6px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:12px;font-size:13px;cursor:pointer;position:relative;transition:all .15s;gap:2px}
.cal-cell:hover{background:rgba(var(--pri-rgb),.1)}
.cal-cell.other{color:var(--muted);opacity:.4}
.cal-cell.today{background:var(--accent);color:#fff;font-weight:700}
.cal-cell.today:hover{background:var(--accent2)}
.cal-cell.has-meal{}
.cal-cell .cycle-dot{width:5px;height:5px;border-radius:50%;background:var(--err);flex-shrink:0}
.cal-cell .cycle-dot.predicted{background:rgba(248,113,113,.4)}
.cal-cell .event-dot{width:5px;height:5px;border-radius:50%;background:var(--pri);flex-shrink:0}
.cal-cell .workout-dot{width:5px;height:5px;border-radius:50%;background:var(--ok);flex-shrink:0}
.calorie-boost{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;margin-left:6px}
.calorie-boost.cycle{background:rgba(248,113,113,.12);color:var(--err)}
.calorie-boost.workout{background:rgba(52,211,153,.12);color:var(--ok)}
.day-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.day-badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}
.day-badge.cycle-badge{background:rgba(248,113,113,.1);color:var(--err);border:1px solid rgba(248,113,113,.2)}
.day-badge.workout-badge{background:rgba(52,211,153,.1);color:var(--ok);border:1px solid rgba(52,211,153,.2)}
.day-badge.boost-badge{background:rgba(var(--pri-rgb),.1);color:var(--pri);border:1px solid rgba(var(--pri-rgb),.2)}

/* ═══ Date Action Menu ═══ */
.date-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:260;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s}
.date-menu{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;width:calc(100% - 48px);max-width:320px}
.date-menu h4{font-size:15px;font-weight:600;margin-bottom:12px;text-align:center}
.date-menu-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-sm);cursor:pointer;transition:background .15s;font-size:14px}
.date-menu-item:hover{background:rgba(var(--pri-rgb),.08)}
.date-menu-item .dmi-icon{font-size:20px;width:28px;text-align:center}
.date-menu-info{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.date-menu-info .ev-item{display:flex;align-items:center;justify-content:space-between;padding:4px 0}
.date-menu-info .ev-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px}
.date-menu-info .ev-del:hover{color:var(--err)}
.header .date{display:none}
.header .date:hover{background:rgba(var(--pri-rgb),.08)}
.header .gear-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:20px;padding:6px;border-radius:10px;transition:all .2s;display:flex;align-items:center}
.header .gear-btn:hover{background:rgba(var(--pri-rgb),.08);color:var(--pri)}
.header .gear-btn svg{width:20px;height:20px}
.cal-page-box{background:var(--card-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}
@media(max-width:400px){
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
}

/* ═══ Reminders ═══ */
.reminder-card{display:flex;align-items:center;gap:10px;padding:12px;background:var(--card-glass);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:8px}
.reminder-card .rem-icon{font-size:22px;width:36px;text-align:center}
.reminder-card .rem-info{flex:1;min-width:0}
.reminder-card .rem-label{font-size:14px;font-weight:500}
.reminder-card .rem-meta{font-size:11px;color:var(--muted)}
.reminder-card .rem-time{font-size:16px;font-weight:700;color:var(--accent);min-width:50px;text-align:right}
.reminder-card .rem-toggle{width:44px;height:24px;border-radius:12px;border:none;cursor:pointer;position:relative;transition:all .2s;flex-shrink:0}
.reminder-card .rem-toggle.on{background:var(--pri)}
.reminder-card .rem-toggle.off{background:var(--border)}
.reminder-card .rem-toggle::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;transition:left .2s}
.reminder-card .rem-toggle.on::after{left:23px}
.reminder-card .rem-toggle.off::after{left:3px}
.reminder-card .rem-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:4px}
.reminder-card .rem-del:hover{color:var(--err)}
.rem-add{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:1px dashed var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--pri);font-size:13px;transition:all .15s}
.rem-add:hover{background:rgba(var(--pri-rgb),.06);border-color:var(--pri)}
.rem-form{padding:14px;background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:10px}

/* ═══ Allergen Tags ═══ */
.allergen-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.allergen-tag{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:16px;font-size:12px;font-weight:500}
.allergen-tag.confirmed{background:rgba(248,113,113,.1);color:var(--err);border:1px solid rgba(248,113,113,.2)}
.allergen-tag.suggested{background:rgba(251,191,36,.1);color:var(--warn);border:1px dashed rgba(251,191,36,.3)}
.allergen-tag .at-del{background:none;border:none;color:inherit;cursor:pointer;font-size:11px;opacity:.7;padding:0 2px}
.allergen-tag .at-del:hover{opacity:1}
.allergen-warn{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(248,113,113,.12);color:var(--err);font-size:10px;margin-left:3px;cursor:help;flex-shrink:0}

/* ═══ Extended Analytics ═══ */
.ext-analytics-section{margin-top:14px}
.deficit-card{padding:10px 14px;border-radius:var(--r-sm);margin-bottom:8px;font-size:13px;display:flex;align-items:center;gap:8px}
.deficit-card.low{background:rgba(96,165,250,.08);border:1px solid rgba(96,165,250,.15);color:#60a5fa}
.deficit-card.high{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.15);color:var(--err)}
.deficit-card .dc-icon{font-size:18px}
.trend-row{display:flex;align-items:center;gap:6px;padding:6px 0;font-size:13px;color:var(--muted)}
.trend-row .trend-val{font-weight:600}
.trend-row .trend-up{color:var(--err)}
.trend-row .trend-down{color:var(--ok)}

/* ═══ KBJU Suggestion Card ═══ */
.kbju-card{padding:14px;background:rgba(var(--pri-rgb),.05);border:1px solid rgba(var(--pri-rgb),.15);border-radius:var(--r);margin-bottom:10px}
.kbju-card .kc-title{font-size:14px;font-weight:600;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.kbju-card .kc-reason{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:8px}
.kbju-card .kc-values{display:flex;gap:8px;font-size:12px;margin-bottom:8px}
.kbju-card .kc-current{color:var(--muted);text-decoration:line-through}
.kbju-card .kc-new{color:var(--ok);font-weight:600}
.kbju-card .kc-actions{display:flex;gap:6px}

/* ═══ Alternatives ═══ */
.alt-card{display:flex;align-items:center;gap:10px;padding:10px;background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px}
.alt-card .alt-name{font-size:13px;font-weight:500;flex:1}
.alt-card .alt-reason{font-size:11px;color:var(--muted)}
.alt-card .alt-cal{font-size:12px;color:var(--accent);font-weight:600;min-width:60px;text-align:right}

/* ═══ Period Toggle ═══ */
.period-toggle{display:flex;gap:4px;background:var(--card2);border-radius:var(--r-sm);padding:3px;margin-bottom:14px}
.period-toggle .pt-btn{flex:1;padding:8px 12px;border-radius:12px;border:none;background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:all .2s;text-align:center}
.period-toggle .pt-btn.active{background:var(--accent);color:#fff}

/* ═══ Notification Badge ═══ */
.notif-badge{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:300;padding:12px 20px;border-radius:var(--r);background:var(--card);border:1px solid var(--pri);box-shadow:0 8px 32px rgba(var(--pri-rgb),.2);display:flex;align-items:center;gap:10px;animation:slideDown .4s ease}
.notif-badge .nb-icon{font-size:22px}
.notif-badge .nb-text{font-size:14px;font-weight:500}
.notif-badge .nb-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:4px}
@keyframes slideDown{from{transform:translateX(-50%) translateY(-100%);opacity:0}to{transform:translateX(-50%);opacity:1}}

/* ═══ Auth Screens ═══ */
.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;padding:20px}
.auth-card{background:var(--card-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r);padding:28px 24px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}
.auth-card h2{font-size:20px;text-align:center;margin-bottom:6px;display:flex;align-items:center;justify-content:center;gap:8px}
.auth-card .auth-sub{font-size:13px;color:var(--muted);text-align:center;margin-bottom:20px}
.auth-card .auth-link{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}
.auth-card .auth-link a{color:var(--pri);cursor:pointer}
.auth-card .auth-link a:hover{text-decoration:underline}
.auth-card .auth-error{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);color:var(--err);padding:10px 14px;border-radius:var(--r-sm);font-size:13px;margin-bottom:14px;display:none}

/* ═══ Weight Dynamics ═══ */
.weight-chart-svg{width:100%;height:140px;display:block}
.weight-chart-svg .line-raw{fill:none;stroke:var(--muted);stroke-width:1.5;stroke-dasharray:4 2}
.weight-chart-svg .line-smooth{fill:none;stroke:var(--pri);stroke-width:2.5}
.weight-chart-svg .line-target{fill:none;stroke:var(--ok);stroke-width:1;stroke-dasharray:6 3}
.weight-chart-svg .dot{fill:var(--accent);r:3}
.weight-chart-svg .dot-cycle{fill:#f472b6;r:3.5}
.weight-chart-svg text{font-size:10px;fill:var(--muted)}
.wt-stat-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.wt-stat{background:var(--card-glass);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 12px;flex:1;min-width:80px;text-align:center}
.wt-stat .val{font-size:16px;font-weight:700;color:var(--text)}
.wt-stat .lbl{font-size:11px;color:var(--muted);margin-top:2px}
.wt-tip{background:var(--card2);border-left:3px solid var(--pri);padding:8px 12px;margin-bottom:6px;border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:13px;line-height:1.5;color:var(--text)}
.wt-forecast-row{display:flex;gap:10px;margin-bottom:6px}
.wt-fc{flex:1;background:var(--card2);border-radius:var(--r-sm);padding:10px;text-align:center}
.wt-fc .fc-val{font-size:17px;font-weight:700}
.wt-fc .fc-lbl{font-size:11px;color:var(--muted)}
.wt-fc .fc-delta{font-size:12px;margin-top:2px}
.wt-fc .fc-delta.loss{color:var(--ok)}
.wt-fc .fc-delta.gain{color:var(--err)}
.wt-eb{background:var(--card2);border-radius:var(--r-sm);padding:10px}
.wt-eb-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}
.wt-eb-row .label{color:var(--muted)}
.wt-tdee{background:var(--card2);border-radius:var(--r-sm);padding:10px}
.wt-progress{height:6px;background:var(--overlay2);border-radius:3px;margin-top:8px;overflow:hidden}
.wt-progress-bar{height:100%;background:linear-gradient(90deg,var(--pri),var(--ok));border-radius:3px;transition:width .5s}
.wt-conf-bar{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding:6px 10px;border-radius:var(--r-sm);background:var(--card2)}
.wt-conf-bar .cb-fill{height:6px;border-radius:3px;flex:1;background:var(--overlay2);overflow:hidden}
.wt-conf-bar .cb-inner{height:100%;border-radius:3px;transition:width .4s}
.wt-conf-bar .cb-label{font-size:11px;color:var(--muted);white-space:nowrap}
.wt-conf-bar .cb-val{font-size:13px;font-weight:700;min-width:36px;text-align:right}
.wt-water-card{background:var(--card2);border-radius:var(--r-sm);padding:10px;margin-bottom:10px}
.wt-water-card .wf-tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;margin:2px;background:rgba(106,165,196,.1);color:#5a9fb5}
.wt-metab-card{background:var(--card2);border-radius:var(--r-sm);padding:10px;margin-bottom:10px}
.wt-goal-card{background:linear-gradient(135deg,rgba(var(--pri-rgb),.06),rgba(52,211,153,.06));border-radius:var(--r);padding:12px;margin-bottom:10px}
.wt-goal-row{display:flex;gap:6px;margin-top:8px}
.wt-goal-item{flex:1;text-align:center;padding:6px;border-radius:var(--r-sm);background:var(--card-glass)}
.wt-goal-item .gi-val{font-size:13px;font-weight:700}
.wt-goal-item .gi-lbl{font-size:10px;color:var(--muted);margin-top:2px}
.wt-recomp-card{background:linear-gradient(135deg,rgba(52,211,153,.06),rgba(234,179,8,.06));border-radius:var(--r);padding:12px;margin-bottom:10px;border-left:3px solid var(--ok)}
.wt-pred-svg{width:100%;height:110px;display:block;margin-bottom:10px}
.wt-pred-svg .band-2s{fill:rgba(var(--pri-rgb),.04)}
.wt-pred-svg .band-1s{fill:rgba(var(--pri-rgb),.1)}
.wt-pred-svg .line-central{fill:none;stroke:var(--pri);stroke-width:2;stroke-dasharray:6 3}
.wt-pred-svg .line-target-pred{fill:none;stroke:var(--ok);stroke-width:1;stroke-dasharray:4 2}
.wt-pred-svg text{font-size:9px;fill:var(--muted)}
.wt-prob-badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:12px;margin-left:6px}

/* ═══ AI Nutritionist Cards ═══ */
.ai-nutri-header{text-align:center;padding:16px 0 8px}
.ai-nutri-header h2{font-size:20px;margin:0;color:var(--text)}
.ai-nutri-header .ai-subtitle{font-size:12px;color:var(--muted);margin-top:4px}
.ai-section{margin-bottom:16px}
.ai-section-title{font-size:14px;font-weight:600;color:var(--pri2);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.ai-section-title svg{width:16px;height:16px}
.ai-card{background:var(--card2);border-radius:var(--r);padding:12px;margin-bottom:8px;border-left:3px solid var(--muted);transition:all .2s}
.ai-card.severity-high{border-left-color:var(--err)}
.ai-card.severity-medium{border-left-color:var(--warn)}
.ai-card.severity-good{border-left-color:var(--ok)}
.ai-card.severity-info{border-left-color:var(--pri)}
.ai-card-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.ai-card-title .ai-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}
.severity-high .ai-icon{background:rgba(248,113,113,.12);color:var(--err)}
.severity-medium .ai-icon{background:rgba(251,191,36,.12);color:var(--warn)}
.severity-good .ai-icon{background:rgba(52,211,153,.12);color:var(--ok)}
.severity-info .ai-icon{background:rgba(var(--pri-rgb),.12);color:var(--pri)}
.ai-card-detail{font-size:12px;color:var(--muted);margin-bottom:6px;line-height:1.4}
.ai-card-action{font-size:11px;color:var(--pri2);padding:6px 8px;background:rgba(var(--pri-rgb),.06);border-radius:8px;line-height:1.3}
.ai-key-cards{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:12px}
.ai-key-card{min-width:120px;padding:10px 12px;border-radius:var(--r);text-align:center;flex-shrink:0}
.ai-key-card.severity-high{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.15)}
.ai-key-card.severity-medium{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.15)}
.ai-key-card.severity-good{background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.15)}
.ai-key-card.severity-info{background:rgba(var(--pri-rgb),.08);border:1px solid rgba(var(--pri-rgb),.15)}
.ai-key-card .kc-icon{font-size:20px;margin-bottom:4px}
.ai-key-card .kc-text{font-size:11px;color:var(--text);line-height:1.3}
.ai-weekly{background:var(--card2);border-radius:var(--r);padding:14px;margin-bottom:12px}
.ai-weekly-grade{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.ai-grade-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700}
.grade-5{background:rgba(52,211,153,.15);color:var(--ok);border:2px solid var(--ok)}
.grade-4{background:rgba(52,211,153,.08);color:#6ee7b7;border:2px solid #6ee7b7}
.grade-3{background:rgba(251,191,36,.12);color:var(--warn);border:2px solid var(--warn)}
.grade-2{background:rgba(248,113,113,.08);color:#fca5a5;border:2px solid #fca5a5}
.grade-1{background:rgba(248,113,113,.15);color:var(--err);border:2px solid var(--err)}
.ai-weekly-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ai-wstat{text-align:center;padding:8px;background:var(--card-glass);border-radius:var(--r-sm)}
.ai-wstat .ws-val{font-size:16px;font-weight:600;color:var(--text)}
.ai-wstat .ws-lbl{font-size:10px;color:var(--muted);margin-top:2px}
.ai-data-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.ai-data-badge{font-size:10px;padding:3px 8px;border-radius:10px;background:var(--card-glass);color:var(--muted)}
.ai-empty{text-align:center;padding:40px 20px;color:var(--muted)}
.ai-empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}
.ai-empty-text{font-size:14px;margin-bottom:6px}
.ai-empty-hint{font-size:12px}
.ai-refresh-btn{display:inline-flex;align-items:center;gap:4px;margin:8px 0;padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);font-size:12px;cursor:pointer}
.ai-refresh-btn:active{transform:scale(.96)}
.ai-refresh-btn svg{width:14px;height:14px}
.bottom-nav .nav-btn span{font-size:9px}

/* ═══ AI Chat ═══ */
.chat-container{display:flex;flex-direction:column;height:calc(100vh - 176px);height:calc(100dvh - 176px);max-width:480px;margin:0 auto}
.chat-header{text-align:center;padding:12px 0 8px;flex-shrink:0}
.chat-header h2{font-size:18px;margin:0;color:var(--text);display:flex;align-items:center;justify-content:center;gap:8px}
.chat-header h2 svg{width:22px;height:22px;color:var(--accent)}
.chat-header .chat-subtitle{font-size:11px;color:var(--muted);margin-top:2px}
.chat-messages{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:8px;-webkit-overflow-scrolling:touch}
.chat-msg{max-width:85%;padding:10px 14px;border-radius:var(--r-sm);font-size:13px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}
.chat-msg.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chat-msg.ai{align-self:flex-start;background:var(--card-glass);color:var(--text);border-bottom-left-radius:4px;border:1px solid var(--border)}
.chat-msg.ai .msg-time,.chat-msg.user .msg-time{font-size:9px;opacity:.6;margin-top:4px;display:block}
.chat-msg.system{align-self:center;background:none;color:var(--muted);font-size:11px;padding:4px 8px}
.chat-typing{align-self:flex-start;padding:8px 14px;background:var(--card-glass);border-radius:var(--r-sm);border-bottom-left-radius:4px;border:1px solid var(--border);font-size:12px;color:var(--muted)}
.chat-typing .dots{display:inline-block;animation:dotPulse 1.4s infinite}
.chat-typing .dots span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--muted);margin:0 1px;animation:dotBounce 1.4s infinite}
.chat-typing .dots span:nth-child(2){animation-delay:.2s}
.chat-typing .dots span:nth-child(3){animation-delay:.4s}
@keyframes dotBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}
.chat-suggestions{display:flex;gap:6px;flex-wrap:wrap;padding:6px 12px;flex-shrink:0}
.chat-chip{padding:6px 12px;background:var(--card-glass);border:1px solid var(--border);border-radius:var(--r-sm);font-size:11px;color:var(--pri);cursor:pointer;white-space:nowrap;transition:all .2s}
.chat-chip:active{background:var(--accent);color:#fff;transform:scale(.95)}
.chat-input-area{display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--border);background:var(--card);flex-shrink:0;padding-bottom:max(8px,env(safe-area-inset-bottom))}
.chat-input{flex:1;padding:10px 14px;background:var(--input);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:14px;outline:none;resize:none;max-height:80px;line-height:1.4;font-family:inherit}
.chat-input:focus{border-color:var(--pri)}
.chat-input::placeholder{color:var(--muted)}
.chat-send{width:40px;height:40px;border-radius:50%;background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.chat-send:disabled{opacity:.4;cursor:default}
.chat-send:active:not(:disabled){transform:scale(.9)}
.chat-send svg{width:18px;height:18px}
.chat-clear{position:absolute;top:10px;right:12px;background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:4px 8px;display:flex;align-items:center;gap:4px}
.chat-clear svg{width:14px;height:14px}
.chat-clear:hover{color:var(--err)}

/* ═══ Module Toggles ═══ */
.module-toggles{display:flex;flex-direction:column;gap:10px}
.mod-toggle{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer;padding:8px 12px;border-radius:var(--r-sm);background:var(--card-glass);border:1px solid var(--border);transition:background .2s}
.mod-toggle:hover{background:var(--overlay2)}
.mod-toggle input[type="checkbox"]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.mod-toggle span{color:var(--text)}

/* ═══ Suggestion Chips ═══ */
.suggestion-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;max-height:120px;overflow-y:auto}
.sugg-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:16px;background:var(--card-glass);border:1px solid var(--border);font-size:13px;cursor:pointer;transition:all .15s;white-space:nowrap}
.sugg-chip:active{transform:scale(.95)}
.sugg-chip:hover{border-color:var(--pri);background:rgba(var(--pri-rgb),.06)}
.sc-icon{font-size:11px}
.sc-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sc-cal{font-size:11px;color:var(--muted);margin-left:2px}

/* ═══ Recipe Modal ═══ */
.recipe-modal{max-width:420px;width:90%;max-height:85vh;overflow-y:auto}
.recipe-btns .btn{font-size:13px;padding:8px 10px}

/* ═══ Recipe List Items ═══ */
.recipe-list-item{display:flex;align-items:flex-start;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}
.recipe-list-item:last-child{border-bottom:none}
.rli-info{flex:1;cursor:pointer;min-width:0}
.rli-info:hover .rli-name{color:var(--pri)}
.rli-name{font-size:14px;font-weight:600;margin-bottom:2px}
.rli-meta{font-size:12px;color:var(--muted)}
.rli-ingr{font-size:12px;color:var(--muted);margin-top:2px;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rli-actions{display:flex;gap:4px;flex-shrink:0}
.rli-actions button{background:none;border:none;cursor:pointer;font-size:14px;padding:4px 6px;border-radius:6px}
.rli-actions button:hover{background:var(--overlay2)}

/* ═══ Recipe Ingredient Tray ═══ */
.ri-item{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.ri-item:last-child{border-bottom:none}
.ri-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.ri-weight{width:60px;padding:4px 6px;border:1px solid var(--border);border-radius:6px;color:var(--text);text-align:center;font-size:13px;background:var(--input)}
.ri-unit{color:var(--muted);font-size:12px;flex-shrink:0}
.ri-cal{color:var(--muted);font-size:12px;min-width:60px;text-align:right;flex-shrink:0}
.ri-del{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;color:var(--err);flex-shrink:0}
.ri-del:hover{background:rgba(239,68,68,.08)}
#recipeIngrTray{background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;margin-top:8px}

.bottom-nav.kb-hidden{transform:translateY(200%);opacity:0;pointer-events:none;transition:transform .2s,opacity .2s}

/* Fix for notifications overlapping the notch / dynamic island / header */
.toast-box {
    top: calc(env(safe-area-inset-top, 40px) + 70px) !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    align-items: center !important;
    width: 90% !important;
    max-width: 400px;
}
.toast {
    text-align: center;
    width: 100%;
}

.notif-badge {
    top: calc(env(safe-area-inset-top, 40px) + 70px) !important;
}
