*{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#6366f1;--primary-light:#818cf8;--green:#22c55e;--green-light:#4ade80;--amber:#f59e0b;--red:#ef4444;--surface-400:#94a3b8;--surface-500:#64748b;--surface-600:#475569;--surface-700:#334155;--surface-800:#1e293b;--surface-900:#0f172a}
html,body{overflow-x:hidden}
body{font-family:'Inter',sans-serif;background:var(--surface-900);color:#fff;min-height:100dvh}
.app-header{position:sticky;top:0;z-index:50;background:rgba(15,23,42,.98);backdrop-filter:blur(20px);border-bottom:1px solid rgba(51,65,85,.3);padding:16px 20px}
.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}
.header-left{display:flex;align-items:center;gap:16px}
.header-logo{font-size:24px;font-weight:700;color:var(--primary-light)}
.header-logo sup{font-size:12px;color:var(--green)}
.header-greeting{font-size:13px;color:var(--surface-400)}
.header-name{font-size:18px;font-weight:600}
.header-right{display:flex;align-items:center;gap:12px}
.header-streak{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);font-size:14px;font-weight:600;color:#fbbf24}
.header-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#3b82f6);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;cursor:pointer}
.admin-link{color:var(--surface-400);font-size:12px;text-decoration:none;padding:6px 10px;border-radius:8px}
.admin-link:hover{background:rgba(99,102,241,.1);color:var(--primary-light)}
.profile-switcher{position:relative}
.ps-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(51,65,85,.4);border:1px solid var(--surface-700);border-radius:10px;cursor:pointer;font-size:13px;color:#fff}
.ps-btn:hover{background:rgba(51,65,85,.6)}
.ps-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.ps-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.4);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:100}
.ps-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.ps-option{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px}
.ps-option:first-child{border-radius:12px 12px 0 0}
.ps-option:hover{background:rgba(51,65,85,.5)}
.ps-option.active{background:rgba(99,102,241,.15)}
.ps-divider{height:1px;background:var(--surface-700);margin:4px 0}
main{padding:20px;padding-bottom:100px;max-width:1200px;margin:0 auto}
nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:rgba(15,23,42,.98);backdrop-filter:blur(20px);border-top:1px solid rgba(51,65,85,.3);padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom))}
.nav-dots{display:none;justify-content:center;gap:4px;padding-top:4px}.nav-dot{width:4px;height:4px;border-radius:50%;background:var(--surface-700);transition:all .3s}.nav-dot.vis{background:var(--surface-500)}
.nav-items{display:flex;justify-content:space-around;max-width:500px;margin:0 auto}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;border-radius:12px;background:0;border:0;color:var(--surface-500);font-size:10px;font-weight:500;cursor:pointer;transition:all .2s}
.nav-item:hover{color:var(--surface-400)}
.nav-item.active{color:var(--primary-light);background:rgba(99,102,241,.1)}
.nav-item svg{width:22px;height:22px}
@media(max-width:480px){.nav-items{justify-content:flex-start;gap:2px;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 4px}.nav-items::-webkit-scrollbar{display:none}.nav-item{padding:6px 12px;font-size:9px;flex-shrink:0}.nav-item svg{width:20px;height:20px}.ps-btn span:not(.ps-avatar){display:none}.nav-dots{display:flex}}
.view{display:none}.view.active{display:block}
.card{background:linear-gradient(135deg,rgba(30,41,59,.6),rgba(30,41,59,.4));border-radius:20px;border:1px solid rgba(51,65,85,.4);padding:20px;margin-bottom:16px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-size:16px;font-weight:600}
.card-action{font-size:13px;color:var(--primary-light);cursor:pointer}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:linear-gradient(135deg,rgba(30,41,59,.6),rgba(30,41,59,.3));border-radius:16px;padding:16px;border:1px solid rgba(51,65,85,.3);text-align:center}
.stat-value{font-size:28px;font-weight:700}
.stat-label{font-size:11px;color:var(--surface-400);margin-top:4px}
.stat-card.primary .stat-value{color:var(--primary-light)}
.stat-card.green .stat-value{color:var(--green-light)}
.stat-card.amber .stat-value{color:var(--amber)}
/* Smart Insight Cards */
.dash-insights{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.dash-insight{display:flex;gap:10px;padding:12px 14px;border-radius:14px;background:rgba(30,41,59,.5);border:1px solid var(--surface-700);position:relative;transition:all .3s ease;overflow:hidden}
.dash-insight.red{border-left:3px solid var(--red);background:rgba(239,68,68,.04)}
.dash-insight.amber{border-left:3px solid var(--amber);background:rgba(245,158,11,.04)}
.dash-insight.primary{border-left:3px solid var(--primary);background:rgba(99,102,241,.04)}
.dash-insight.blue{border-left:3px solid #06b6d4;background:rgba(6,182,212,.04)}
.dash-insight.strava{border-left:3px solid #FC4C02;background:rgba(252,76,2,.04)}
.dash-insight-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.dash-insight-body{flex:1;min-width:0}
.dash-insight-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:3px}
.dash-insight-text{font-size:11.5px;color:var(--surface-400);line-height:1.5}
.dash-insight-btn{font-size:11px;font-weight:600;padding:5px 12px;border-radius:8px;border:none;cursor:pointer;margin-top:8px;transition:all .15s;font-family:Inter,sans-serif}
.dash-insight-btn.red{background:rgba(239,68,68,.15);color:var(--red)}
.dash-insight-btn.red:hover{background:rgba(239,68,68,.25)}
.dash-insight-btn.amber{background:rgba(245,158,11,.15);color:var(--amber)}
.dash-insight-btn.amber:hover{background:rgba(245,158,11,.25)}
.dash-insight-btn.primary{background:rgba(99,102,241,.15);color:var(--primary-light)}
.dash-insight-btn.primary:hover{background:rgba(99,102,241,.25)}
.dash-insight-btn.blue{background:rgba(6,182,212,.15);color:#06b6d4}
.dash-insight-btn.blue:hover{background:rgba(6,182,212,.25)}
.dash-insight-btn.strava{background:rgba(252,76,2,.12);color:#FC4C02}
.dash-insight-btn.strava:hover{background:rgba(252,76,2,.22)}
.dash-insight-dismiss{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--surface-600);font-size:14px;cursor:pointer;padding:2px 4px;line-height:1;opacity:.5;transition:opacity .15s}
.dash-insight-dismiss:hover{opacity:1;color:var(--surface-400)}
.inv-row:hover{background:rgba(99,102,241,.04)!important}
.inv-filter.active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}
.item-list{display:flex;flex-direction:column;gap:10px}
.list-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(51,65,85,.3);border-radius:14px;cursor:pointer;transition:all .2s}
.list-item:hover{background:rgba(51,65,85,.5)}
.list-item-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:rgba(99,102,241,.15)}
.list-item-info{flex:1}
.list-item-title{font-weight:500;font-size:15px}
.list-item-subtitle{font-size:12px;color:var(--surface-400);margin-top:2px}
.list-item-badge{padding:4px 10px;border-radius:20px;font-size:12px}
.time-badges{display:flex;gap:6px}
.time-badge{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:rgba(51,65,85,.5);border-radius:6px;font-size:12px}
.empty-state{text-align:center;padding:40px 20px;color:var(--surface-400)}
.empty-state-icon{font-size:56px;margin-bottom:16px;opacity:.5}
.empty-state h3{color:#fff;margin-bottom:8px}
.empty-cta{cursor:pointer;transition:all .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;padding:16px}
.empty-cta:hover{transform:translateY(-2px)}
.empty-cta .empty-state-icon{opacity:1;animation:floatBounce 3s ease-in-out infinite}
/* Dashboard Supplements */
.dash-welcome{margin:0 0 12px}
.dash-welcome-content{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(34,197,94,.08));border:1px solid rgba(99,102,241,.2);border-radius:16px}
.dash-welcome-icon{font-size:32px;flex-shrink:0}
.dash-welcome-body{flex:1;min-width:0}
.dash-welcome-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:4px}
.dash-welcome-text{font-size:12px;color:var(--surface-400);line-height:1.5;margin-bottom:10px}
.dash-welcome-actions{display:flex;gap:8px}
.dash-supps-compact{cursor:pointer;transition:all .2s;border-radius:12px;padding:4px 0}
.dash-supps-compact:hover{background:rgba(30,41,59,.3)}
.dash-supps-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dash-supps-count{display:flex;align-items:baseline;gap:6px}
.dash-supps-number{font-size:20px;font-weight:700}
.dash-supps-label{font-size:12px;color:var(--surface-400)}
.dash-supps-pct{font-size:24px;font-weight:700}
.dash-supps-bar{height:6px;background:rgba(30,41,59,.6);border-radius:3px;overflow:hidden;margin-bottom:12px}
.dash-supps-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}
.dash-supps-missing-label{font-size:11px;color:var(--surface-400);margin-bottom:6px}
.dash-supps-missing{display:flex;flex-wrap:wrap;gap:6px}
.dash-supp-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:rgba(30,41,59,.5);border-radius:10px;font-size:12px;color:var(--surface-300);border:1px solid rgba(71,85,105,.4)}
.dash-supp-chip-icon{font-size:14px}
.dash-supp-chip-slot{font-size:11px;opacity:.7}
.dash-supp-chip.more{color:var(--surface-400);font-style:italic;border-style:dashed}
.dash-supps-alldone{text-align:center;padding:8px 0;font-size:13px;font-weight:600;color:var(--green)}
.empty-cta h3{color:var(--primary-light)}
.empty-cta p{font-size:12px;color:var(--surface-400);margin-top:6px;line-height:1.5;max-width:280px;margin-left:auto;margin-right:auto}
.empty-cta .cta-hint{margin-top:12px;font-size:12px;color:var(--primary);font-weight:500;opacity:.7;text-align:center}
@keyframes floatBounce{0%,100%{transform:translateY(0) scale(1)}25%{transform:translateY(-6px) scale(1.05)}50%{transform:translateY(0) scale(1)}75%{transform:translateY(-3px) scale(1.02)}}
.rotating-text{min-height:48px;display:flex;align-items:center;justify-content:center;text-align:center;padding:4px 16px;width:100%}
.rotating-text span{display:block;font-size:18px;font-weight:600;color:var(--primary-light);line-height:1.4;transition:opacity .8s ease;opacity:1}
.rotating-text span.fade-out{opacity:0}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{background:var(--primary-light)}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}
.btn-ghost{background:transparent;border:1px solid var(--surface-600);color:var(--surface-400)}
.profile-header{text-align:center;padding:30px 20px}
.profile-avatar{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#3b82f6);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 16px}
.profile-name{font-size:22px;font-weight:700;margin-bottom:4px}
.profile-email{color:var(--surface-400);font-size:14px}
.profile-badge{display:inline-block;margin-top:12px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600}
.settings-list{background:rgba(30,41,59,.4);border-radius:16px;overflow:hidden}
.settings-item{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(51,65,85,.3);cursor:pointer}
.settings-item:last-child{border-bottom:none}
.settings-item:hover{background:rgba(51,65,85,.3)}
.settings-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:rgba(51,65,85,.5);margin-right:14px}
.settings-label{font-weight:500}
.settings-value{color:var(--surface-400);font-size:14px}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;visibility:hidden;transition:all .3s;padding:20px}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--surface-800);border-radius:24px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;transform:scale(.95);transition:transform .3s;display:flex;flex-direction:column}
.modal-overlay.active .modal{transform:scale(1)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--surface-700);flex-wrap:wrap;gap:12px}
.modal-title{font-size:18px;font-weight:600}
.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface-700);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:20px}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{padding:16px 20px;border-top:1px solid var(--surface-700);display:flex;gap:12px}
.modal-fullscreen .modal{max-width:98vw;width:1400px;height:90vh}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:13px;font-weight:500;color:var(--surface-400);margin-bottom:8px}
.form-input,.form-select{width:100%;padding:12px 14px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:12px;color:#fff;font-size:14px}
.form-input:focus{outline:0;border-color:var(--primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.time-select{display:flex;gap:12px}
.time-select-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px;background:rgba(51,65,85,.3);border:2px solid transparent;border-radius:12px;cursor:pointer}
.time-select-item.selected{border-color:var(--primary);background:rgba(99,102,241,.1)}
.time-select-item input{display:none}
/* Quantity picker inside time slot */
.qty-picker{display:flex;align-items:center;gap:4px;margin-top:6px}
.qty-picker.hidden{display:none}
.qty-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--surface-600);background:rgba(30,41,59,.6);color:var(--surface-300);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;line-height:1}
.qty-btn:hover{background:rgba(99,102,241,.2);border-color:var(--primary)}
.qty-val{font-size:14px;font-weight:700;color:var(--primary-light);min-width:18px;text-align:center}
.dose-summary{margin-top:8px;min-height:18px}
.upload-zone{border:2px dashed var(--surface-600);border-radius:16px;padding:40px;text-align:center;cursor:pointer}
.upload-zone:hover{border-color:var(--primary);background:rgba(99,102,241,.05)}
.toast-container{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:300}
.toast{padding:14px 24px;background:var(--surface-800);border-radius:14px;font-size:14px;border:1px solid var(--surface-700);opacity:0;transform:translateY(-20px);transition:all .3s}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{border-color:var(--green)}
.toast.error{border-color:var(--red)}
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--surface-400)}
.spinner{width:24px;height:24px;border:3px solid var(--surface-700);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{text-align:left;padding:12px 16px;background:rgba(51,65,85,.5);font-weight:600;position:sticky;top:0}
.admin-table td{padding:12px 16px;border-bottom:1px solid rgba(51,65,85,.3)}
.admin-table tr:hover td{background:rgba(51,65,85,.2)}
.role-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}
.role-user{background:rgba(100,116,139,.2);color:var(--surface-400)}
.role-advanced{background:rgba(99,102,241,.2);color:var(--primary-light)}
.role-masterdata{background:rgba(245,158,11,.2);color:var(--amber)}
.role-admin{background:rgba(239,68,68,.2);color:var(--red)}
.goal-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:rgba(51,65,85,.3);border:2px solid transparent;border-radius:10px;cursor:pointer;font-size:13px}
.goal-chip:has(input:checked){border-color:var(--primary);background:rgba(99,102,241,.1)}
.goal-chip input{display:none}
.blood-value-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(51,65,85,.3)}
.blood-value-row:hover{background:rgba(51,65,85,.2)}
.blood-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:16px}
.blood-card{background:linear-gradient(135deg,rgba(30,41,59,.7),rgba(30,41,59,.4));border-radius:16px;padding:16px;border:1px solid rgba(51,65,85,.4);transition:all .2s;cursor:default;position:relative;overflow:hidden}
.blood-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0}
.blood-card.status-normal::before,.blood-card.status-optimal::before{background:var(--green)}
.blood-card.status-high::before,.blood-card.status-critical_high::before{background:var(--red)}
.blood-card.status-low::before,.blood-card.status-critical_low::before{background:#3b82f6}
.blood-card.status-borderline::before{background:var(--amber)}
.blood-card-name{font-size:11px;color:var(--surface-400);font-weight:500;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.blood-card-value{font-size:26px;font-weight:700;line-height:1.1}
.blood-card-unit{font-size:11px;color:var(--surface-400);font-weight:400;margin-top:2px}
.blood-card-ref{font-size:10px;color:var(--surface-500);margin-top:8px;display:flex;align-items:center;gap:4px}
.blood-card-ref-bar{flex:1;height:4px;background:rgba(51,65,85,.5);border-radius:2px;position:relative;overflow:hidden}
.blood-card-ref-fill{position:absolute;top:0;height:100%;border-radius:2px}
.blood-card.status-normal .blood-card-value,.blood-card.status-optimal .blood-card-value{color:var(--green-light)}
.blood-card.status-high .blood-card-value,.blood-card.status-critical_high .blood-card-value{color:#f87171}
.blood-card.status-low .blood-card-value,.blood-card.status-critical_low .blood-card-value{color:#60a5fa}
.blood-card.status-borderline .blood-card-value{color:#fbbf24}
.blood-category-header{padding:12px 16px 4px;font-size:12px;font-weight:600;color:var(--primary-light);text-transform:uppercase;letter-spacing:.5px;grid-column:1/-1}
/* Blood Interpretation Summary */
.bi-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:16px;border-bottom:1px solid var(--surface-700)}
.bi-summary-card{text-align:center;padding:16px 8px;border-radius:12px;cursor:pointer;transition:all .2s;border:2px solid transparent}
.bi-summary-card:hover{transform:translateY(-2px)}
.bi-summary-card.active{border-color:currentColor}
.bi-summary-card .bi-count{font-size:32px;font-weight:800;line-height:1}
.bi-summary-card .bi-label{font-size:12px;font-weight:600;margin-top:4px}
.bi-summary-card.bi-normal{background:rgba(34,197,94,.08);color:#22c55e}
.bi-summary-card.bi-abnormal{background:rgba(251,191,36,.08);color:#fbbf24}
.bi-summary-card.bi-critical{background:rgba(239,68,68,.08);color:#ef4444}
.bi-ai-cta{display:flex;align-items:center;gap:14px;margin:16px;padding:16px 18px;background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(139,92,246,.12));border:1px solid rgba(99,102,241,.3);border-radius:16px;cursor:pointer;transition:all .2s}
.bi-ai-cta:hover{background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(139,92,246,.2));transform:translateY(-1px)}
.bi-ai-cta-icon{font-size:32px;flex-shrink:0}
.bi-ai-cta-body{flex:1;min-width:0}
.bi-ai-cta-title{font-size:14px;font-weight:700;color:var(--primary-light);margin-bottom:3px}
.bi-ai-cta-text{font-size:12px;color:var(--surface-400);line-height:1.4}
.bi-ai-cta-arrow{font-size:20px;color:var(--primary);font-weight:700;flex-shrink:0}
.bi-filters{display:flex;gap:6px;padding:12px 16px;flex-wrap:wrap;border-bottom:1px solid var(--surface-700)}
.bi-filter{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--surface-600);background:var(--surface-800);color:var(--surface-300);transition:all .15s}
.bi-filter.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.bi-filter .bi-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}
.bi-back{padding:8px 16px;font-size:13px;color:var(--primary-light);cursor:pointer;border-bottom:1px solid var(--surface-700);display:flex;align-items:center;gap:6px}
.bi-back:hover{background:rgba(99,102,241,.06)}
.bi-section-header{padding:16px 16px 8px;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.bi-section-desc{padding:0 16px 12px;font-size:12px;color:var(--surface-400);line-height:1.5}
/* Enhanced blood value card for interpretation */
.bi-value{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;margin:0 16px 12px;overflow:hidden;border-left:4px solid var(--surface-600)}
.bi-value.st-normal,.bi-value.st-optimal{border-left-color:#22c55e}
.bi-value.st-high,.bi-value.st-critical_high{border-left-color:#ef4444}
.bi-value.st-low,.bi-value.st-critical_low{border-left-color:#3b82f6}
.bi-value.st-borderline{border-left-color:#fbbf24}
.bi-value-header{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 14px 0}
.bi-value-name{font-size:15px;font-weight:700;color:var(--surface-100)}
.bi-value-code{font-size:11px;color:var(--surface-500);margin-top:2px}
.bi-value-desc{font-size:11px;color:var(--surface-400);margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bi-value-result{text-align:right;flex-shrink:0}
.bi-value-number{font-size:24px;font-weight:800;line-height:1}
.bi-value-unit{font-size:11px;color:var(--surface-500)}
.bi-gauge{margin:10px 14px 0;height:10px;border-radius:5px;position:relative;overflow:visible;background:linear-gradient(to right,#ef444466,#fbbf2466 20%,#22c55e66 30%,#22c55e66 70%,#fbbf2466 80%,#ef444466)}
.bi-gauge-ref{position:absolute;top:0;height:100%;background:rgba(34,197,94,.35);border-radius:5px;border:1px solid rgba(34,197,94,.5)}
.bi-gauge-marker{position:absolute;top:-3px;width:12px;height:16px;border-radius:3px;transform:translateX(-50%);z-index:2;border:2px solid #fff}
.bi-gauge-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--surface-500);margin:2px 14px 0}
.bi-gauge-ref-text{font-size:10px;color:var(--surface-400);text-align:center;margin-top:2px;padding:0 14px}
.bi-reason{margin:10px 14px;padding:10px 12px;border-radius:8px;font-size:12px;line-height:1.5}
.bi-reason.reason-critical{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:var(--surface-200)}
.bi-reason.reason-abnormal{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);color:var(--surface-200)}
.bi-reason-title{font-weight:700;font-size:12px;margin-bottom:4px}
.bi-details-toggle{padding:10px 14px;font-size:12px;color:var(--primary-light);cursor:pointer;display:flex;align-items:center;gap:6px;border-top:1px solid var(--surface-700)}
.bi-details-toggle:hover{background:rgba(99,102,241,.04)}
.bi-details-toggle .chevron{font-size:10px;transition:transform .2s}
.bi-details-toggle.open .chevron{transform:rotate(90deg)}
.bi-details-body{display:none;padding:0 14px 14px;font-size:12px;line-height:1.6;color:var(--surface-300)}
.bi-details-body.open{display:block}
.bi-detail-section{margin-bottom:10px}
.bi-detail-section-title{font-size:11px;font-weight:600;color:var(--surface-400);margin-bottom:4px;display:flex;align-items:center;gap:4px}
.bi-detail-section p{margin:0}
.bi-sport-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}
.bi-sport-badge.high{background:rgba(34,197,94,.12);color:#22c55e}
.bi-sport-badge.medium{background:rgba(251,191,36,.12);color:#fbbf24}
.bi-sport-badge.low{background:rgba(148,163,184,.12);color:#94a3b8}
.blood-charts-container{padding:16px}
.blood-charts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.blood-charts-header select{background:var(--surface-800);border:1px solid var(--surface-700);color:#fff;padding:8px 12px;border-radius:10px;font-size:13px;min-width:200px}
.blood-chart-card{background:linear-gradient(135deg,rgba(30,41,59,.5),rgba(30,41,59,.3));border:1px solid rgba(51,65,85,.3);border-radius:16px;padding:16px;margin-bottom:12px}
.blood-chart-title{font-size:14px;font-weight:600;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}
.blood-chart-subtitle{font-size:11px;color:var(--surface-400);margin-bottom:12px}
.blood-chart-box{width:100%;height:200px;border-radius:8px;overflow:hidden}
.strava-connect-btn{display:flex;align-items:center;gap:8px;background:rgba(252,76,2,.12);color:#FC4C02;border:1px solid rgba(252,76,2,.3);padding:10px 16px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.strava-connect-btn:hover{background:rgba(252,76,2,.2);border-color:rgba(252,76,2,.5)}
.strava-connect-btn svg{width:16px;height:16px;fill:#FC4C02}
.strava-athlete-card{display:flex;align-items:center;gap:14px;padding:4px 0}
.strava-athlete-img{width:44px;height:44px;border-radius:50%;border:2px solid #FC4C02;object-fit:cover}
.strava-athlete-name{font-weight:600;font-size:14px}
.strava-athlete-meta{font-size:12px;color:var(--surface-400)}
.strava-mode-toggle{display:flex;gap:8px;margin-top:12px}
.strava-mode-btn{flex:1;padding:10px 8px;border-radius:10px;border:1px solid var(--surface-700);background:var(--surface-800);color:var(--surface-400);font-size:12px;cursor:pointer;text-align:center;transition:all .2s}
.strava-mode-btn.active{border-color:#FC4C02;background:rgba(252,76,2,.12);color:#FC4C02;font-weight:600}
.strava-mode-btn:hover{border-color:rgba(252,76,2,.5)}
.strava-info{font-size:11px;color:var(--surface-500);margin-top:8px;line-height:1.5}
.sa-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.sa-header h2{font-size:20px;display:flex;align-items:center;gap:8px}
.sa-header h2 svg{width:20px;height:20px;fill:#FC4C02}
.sa-period-btns{display:flex;gap:4px}
.sa-period-btn{padding:5px 12px;border-radius:8px;border:1px solid var(--surface-700);background:var(--surface-800);color:var(--surface-400);font-size:11px;cursor:pointer;transition:all .2s}
.sa-period-btn.active{border-color:#FC4C02;background:rgba(252,76,2,.12);color:#FC4C02;font-weight:600}
.sa-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.sa-kpi{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:14px;text-align:center}
.sa-kpi-val{font-size:22px;font-weight:700;color:#fff;line-height:1.2}
.sa-kpi-label{font-size:10px;color:var(--surface-400);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.sa-kpi-sub{font-size:10px;color:var(--surface-500);margin-top:2px}
.sa-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.sa-chart-card{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:14px;min-height:260px}
.sa-chart-title{font-size:13px;font-weight:600;margin-bottom:4px;color:var(--surface-300)}
.sa-chart-desc{font-size:11px;color:var(--surface-500);margin-bottom:8px;line-height:1.5}
.sa-ai-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;border-radius:12px;transition:background .2s}
.sa-ai-bar:hover{background:rgba(99,102,241,.08)}
.sa-ai-result{display:none;padding:4px 14px 14px;font-size:13px;line-height:1.7;color:var(--surface-300)}
.sa-explain{margin-top:6px;margin-bottom:4px;position:relative;z-index:10}
.sa-explain-toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--primary-light);padding:5px 10px;border:none;background:rgba(99,102,241,.06);border-radius:6px;transition:all .2s;user-select:none}
.sa-explain-toggle:hover{color:var(--primary);background:rgba(99,102,241,.12)}
.sa-explain-toggle .chevron{transition:transform .3s;font-size:9px}
.sa-explain-toggle.open .chevron{transform:rotate(90deg)}
.sa-explain-body{max-height:0;overflow:hidden;transition:max-height .35s ease,opacity .25s ease;opacity:0}
.sa-explain-body.open{max-height:400px;opacity:1}
.sa-explain-content{background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12);border-radius:10px;padding:12px 14px;margin-top:6px;font-size:12px;line-height:1.7;color:var(--surface-300)}
.sa-heatmap-wrap{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:14px;margin-bottom:16px}
.sa-heatmap{display:flex;gap:2px;overflow-x:auto;padding-bottom:4px}
.sa-heatmap-week{display:flex;flex-direction:column;gap:2px}
.sa-heatmap-cell{width:14px;height:14px;border-radius:3px;background:var(--surface-700);position:relative;cursor:pointer;transition:transform .15s}
.sa-heatmap-cell:hover{transform:scale(1.5);z-index:5}
.sa-heatmap-cell[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:120%;left:50%;transform:translateX(-50%);background:var(--surface-900);color:#fff;font-size:10px;padding:3px 6px;border-radius:4px;white-space:nowrap;z-index:10;pointer-events:none;border:1px solid var(--surface-600)}
.sa-heatmap-labels{display:flex;flex-direction:column;gap:2px;margin-right:4px;font-size:9px;color:var(--surface-500)}
.sa-heatmap-labels span{height:14px;display:flex;align-items:center}
.sa-heatmap-months{display:flex;font-size:9px;color:var(--surface-500);margin-left:20px;margin-bottom:4px}
.sa-heatmap-months span{min-width:14px}
.sa-heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:8px;font-size:10px;color:var(--surface-500)}
.sa-heatmap-legend span{width:14px;height:14px;border-radius:3px}
.sa-recovery-kpi{display:flex;align-items:center;gap:8px}
.sa-recovery-gauge{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff}
.sa-acwr-zones{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.sa-acwr-zone{font-size:10px;padding:3px 8px;border-radius:4px;font-weight:600}
.sa-sports-row{display:flex;gap:10px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}
.sa-sport-tile{flex:1;min-width:0;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:14px;padding:14px 8px 10px;display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .3s ease;position:relative;overflow:hidden;min-height:140px}
.sa-sport-tile:hover{border-color:var(--surface-600);transform:translateY(-2px)}
.sa-sport-tile::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.sa-sport-icon{display:flex;align-items:center;justify-content:center;flex:1;width:100%;transition:all .3s}
.sa-sport-icon svg{fill:currentColor}
.sa-sport-bottom{margin-top:auto;display:flex;flex-direction:column;align-items:center}
.sa-sport-name{font-size:11px;font-weight:600;color:var(--surface-200);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.sa-sport-count{font-size:20px;font-weight:700;color:#fff;line-height:1}
.sa-sport-label{font-size:9px;color:var(--surface-500);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
@media(max-width:640px){.sa-sports-row{gap:6px}.sa-sport-tile{padding:10px 6px;min-width:64px;flex:0 0 auto}}
.sa-chart-box{width:100%;height:220px;position:relative;overflow:hidden}
.sa-grid-card{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:14px;margin-bottom:16px}
.sa-grid-box{width:100%;height:360px}
.sa-type-icon{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500}
@media(max-width:640px){.sa-kpi-row{grid-template-columns:repeat(2,1fr)}.sa-charts-row{grid-template-columns:1fr}.sa-kpi-val{font-size:18px}.sa-chart-card{min-height:220px}.sa-chart-box{height:180px}.sa-heatmap-cell{width:11px;height:11px}}
.supp-view-toggle{display:flex;gap:4px;background:var(--surface-800);border-radius:8px;padding:2px;border:1px solid var(--surface-700)}
.supp-view-btn{padding:5px 12px;border-radius:6px;border:none;background:transparent;color:var(--surface-400);font-size:11px;font-weight:500;cursor:pointer;transition:all .2s}
.supp-view-btn.active{background:var(--primary);color:#fff}
.supp-tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.supp-tile{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:14px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}
.supp-tile:hover{border-color:var(--surface-600);transform:translateY(-2px)}
.supp-tile.expanded{grid-column:1/-1;text-align:left;padding:16px}
.supp-tile-icon{font-size:28px;margin-bottom:8px;display:block}
.supp-tile-name{font-size:13px;font-weight:600;color:#fff;margin-bottom:4px}
.supp-tile-dose{font-size:11px;color:var(--surface-400)}
.supp-tile-times{display:flex;justify-content:center;gap:4px;margin-top:6px}
.supp-tile-times span{font-size:12px}
.supp-tile-detail{max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease,padding .3s ease;opacity:0}
.supp-tile.expanded .supp-tile-detail{max-height:600px;opacity:1;padding-top:14px;margin-top:12px;border-top:1px solid var(--surface-700)}
.supp-tile-detail-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:12px;line-height:1.5}
.supp-tile-detail-row .icon{flex-shrink:0;width:20px;text-align:center}
.supp-tile-detail-row .text{color:var(--surface-300)}
.supp-tile-detail-row .label{font-weight:600;color:var(--surface-200);margin-bottom:2px}
.supp-tile-actions{display:flex;gap:8px;margin-top:10px;justify-content:flex-end}
.supp-tile-actions button{padding:4px 10px;border-radius:6px;border:1px solid var(--surface-600);background:var(--surface-800);color:var(--surface-300);font-size:11px;cursor:pointer}
.supp-tile-actions button:hover{border-color:var(--surface-500)}
.supp-tile-actions button.del{color:var(--red);border-color:rgba(239,68,68,.3)}
.blood-chart-single{display:flex;align-items:center;gap:16px;padding:8px 0}
.blood-chart-single-value{font-size:22px;font-weight:700;color:var(--surface-400)}
.blood-chart-single-label{font-size:12px;color:var(--surface-500)}
@media(max-width:480px){.blood-cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding:10px}.blood-card{padding:12px}.blood-card-value{font-size:22px}}
.param-row{display:grid;grid-template-columns:80px 1fr 80px 140px 40px;gap:12px;padding:10px 16px;border-bottom:1px solid rgba(51,65,85,.3);align-items:center;font-size:13px;cursor:pointer}
.param-row:hover{background:rgba(51,65,85,.2)}
.param-row .code{font-family:monospace;background:var(--surface-700);padding:2px 6px;border-radius:4px;font-size:11px}
.section-title{font-size:12px;font-weight:600;color:var(--primary-light);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid rgba(99,102,241,.2)}
.subuser-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:rgba(51,65,85,.3);border-radius:12px;cursor:pointer;margin-bottom:8px}
.subuser-card:hover{background:rgba(51,65,85,.5)}
.subuser-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}
.color-picker{display:flex;gap:8px;flex-wrap:wrap}
.color-option{width:32px;height:32px;border-radius:50%;cursor:pointer;border:3px solid transparent}
.color-option.selected{border-color:#fff}
.active-banner{background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3);border-radius:12px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.disclaimer-banner{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);width:calc(100% - 40px);max-width:500px;background:linear-gradient(135deg,rgba(30,41,59,.98),rgba(30,41,59,.95));border:1px solid rgba(245,158,11,.3);border-radius:20px;padding:20px;z-index:500;box-shadow:0 10px 40px rgba(0,0,0,.4);backdrop-filter:blur(12px);animation:slideUp .4s ease-out}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.disclaimer-banner.hiding{animation:slideDown .3s ease-in forwards}
@keyframes slideDown{to{opacity:0;transform:translateX(-50%) translateY(20px)}}
.disclaimer-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.disclaimer-icon{font-size:28px;flex-shrink:0}
.disclaimer-title{font-weight:600;font-size:15px;color:var(--amber)}
.disclaimer-text{font-size:13px;color:var(--surface-400);line-height:1.6}
.disclaimer-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.disclaimer-btn{padding:10px 16px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .2s}
.disclaimer-btn-secondary{background:var(--surface-700);color:var(--surface-400)}
.disclaimer-btn-secondary:hover{background:var(--surface-600)}
.disclaimer-btn-primary{background:var(--amber);color:#000}
.disclaimer-btn-primary:hover{background:#fbbf24}
.countdown-ring{position:absolute;top:16px;right:16px;width:36px;height:36px}
.countdown-ring svg{transform:rotate(-90deg)}
.countdown-ring circle{fill:none;stroke-width:3}
.countdown-ring .bg{stroke:var(--surface-700)}
.countdown-ring .progress{stroke:var(--amber);stroke-linecap:round;transition:stroke-dashoffset .1s linear}
.countdown-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:var(--surface-400)}
.hidden{display:none!important}
textarea.form-input{resize:vertical;min-height:60px}
/* Masterdata Table Styles */
.md-table{width:100%;border-collapse:collapse;font-size:13px}
.md-table th{position:sticky;top:0;background:var(--surface-800);padding:10px 8px;text-align:left;font-weight:600;font-size:11px;color:var(--surface-400);border-bottom:2px solid var(--surface-700);white-space:nowrap}
.md-table td{padding:8px;border-bottom:1px solid rgba(51,65,85,.3);vertical-align:middle}
.md-table tr:hover{background:rgba(51,65,85,.3)}
.md-table .cat-row{background:rgba(99,102,241,.1);cursor:default}
.md-table .cat-row td{padding:10px 12px;font-weight:600;color:var(--amber);font-size:14px}
.md-table .cat-row:hover{background:rgba(99,102,241,.15)}
.md-table input.inline-edit{width:100%;padding:4px 6px;background:rgba(30,41,59,.8);border:1px solid var(--primary);border-radius:4px;color:#fff;font-size:12px}
.md-table .code-cell{color:var(--primary-light);font-weight:500;font-family:monospace}
.md-table .unit-cell{color:var(--surface-400)}
.md-table .ref-cell{text-align:center;font-family:monospace;font-size:12px}
.md-table .ref-cell.has-value{color:var(--green-light)}
.md-table .ref-cell.no-value{color:var(--surface-600)}
.md-table .actions-cell{display:flex;gap:4px;justify-content:flex-end}
.md-table .action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:rgba(51,65,85,.5);border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}
.md-table .action-btn:hover{background:rgba(51,65,85,.8)}
.md-table .action-btn.edit{color:var(--amber)}
.md-table .action-btn.save{color:var(--green)}
.md-table .action-btn.delete{color:var(--red)}
.md-table .action-btn.history{color:var(--primary-light)}
.md-table .note-input{width:100%;padding:4px 8px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:4px;color:var(--surface-300);font-size:11px}
.md-table .deleted-row{opacity:.5;background:rgba(239,68,68,.05)}
.md-table .deleted-row td{text-decoration:line-through}
.md-cat-item{padding:10px 14px;cursor:pointer;font-size:13px;border-left:3px solid transparent;transition:all .2s}
.md-cat-item:hover{background:rgba(51,65,85,.3)}
.md-cat-item.active{background:rgba(99,102,241,.15);border-left-color:var(--primary);color:var(--primary-light)}
.md-cat-item .cat-count{float:right;font-size:11px;color:var(--surface-500);background:rgba(51,65,85,.5);padding:2px 8px;border-radius:10px}
.md-cat-item.trash{color:var(--red)}
.history-item{padding:10px;background:rgba(51,65,85,.3);border-radius:8px;margin-bottom:8px;font-size:12px}
.history-item .history-header{display:flex;justify-content:space-between;margin-bottom:6px}
.history-item .history-type{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}
.history-item .history-type.update{background:rgba(99,102,241,.2);color:var(--primary-light)}
.history-item .history-type.create{background:rgba(34,197,94,.2);color:var(--green)}
.history-item .history-type.delete{background:rgba(239,68,68,.2);color:var(--red)}
.history-item .history-type.restore{background:rgba(245,158,11,.2);color:var(--amber)}
.section-title{font-size:13px;font-weight:600;color:var(--surface-400)}

/* ============================================ */
/* AG GRID - VITALS³ CUSTOM DARK THEME         */
/* ============================================ */
#md-grid-container{width:100%;height:100%}

/* AG Grid Vitals³ Theme Override */
.ag-theme-quartz-dark{
    --ag-background-color:#0f172a;
    --ag-foreground-color:#cbd5e1;
    --ag-header-background-color:#1e293b;
    --ag-header-foreground-color:#94a3b8;
    --ag-odd-row-background-color:rgba(30,41,59,.4);
    --ag-row-hover-color:rgba(99,102,241,.15);
    --ag-selected-row-background-color:rgba(99,102,241,.25);
    --ag-range-selection-background-color:rgba(99,102,241,.2);
    --ag-border-color:#334155;
    --ag-secondary-border-color:#1e293b;
    --ag-header-column-separator-color:#475569;
    --ag-input-focus-border-color:#6366f1;
    --ag-accent-color:#6366f1;
    --ag-cell-horizontal-padding:8px;
    --ag-font-family:'Inter',sans-serif;
    --ag-font-size:12px;
    --ag-row-height:32px;
    --ag-header-height:36px;
    --ag-grid-size:4px;
    --ag-list-item-height:28px;
}

/* Header Styling */
.ag-theme-quartz-dark .ag-header{border-bottom:2px solid #475569}
.ag-theme-quartz-dark .ag-header-cell{font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.ag-theme-quartz-dark .ag-header-cell-text{color:#94a3b8}

/* Pinned Columns - Farbliche Unterscheidung */
.ag-theme-quartz-dark .ag-pinned-left-header{background:#1a2744;border-right:2px solid #6366f1}
.ag-theme-quartz-dark .ag-pinned-right-header{background:#1a2744;border-left:2px solid #6366f1}
.ag-theme-quartz-dark .ag-pinned-left-cols-container{background:rgba(26,39,68,.6);border-right:2px solid #6366f1}
.ag-theme-quartz-dark .ag-pinned-right-cols-container{background:rgba(26,39,68,.6);border-left:2px solid #6366f1}

/* Row Hover - Invertierte Farben */
.ag-theme-quartz-dark .ag-row:hover:not(.ag-row-group){background:#cbd5e1 !important}
.ag-theme-quartz-dark .ag-row:hover:not(.ag-row-group) .ag-cell{color:#0f172a !important}
.ag-theme-quartz-dark .ag-row:hover:not(.ag-row-group) .cell-code{color:#4f46e5 !important}

/* Gruppen-Zeilen (Kategorien) */
.ag-theme-quartz-dark .ag-row-group{background:rgba(245,158,11,.12) !important;border-bottom:1px solid rgba(245,158,11,.3)}
.ag-theme-quartz-dark .ag-row-group .ag-group-value{color:#f59e0b;font-weight:600;font-size:13px}
.ag-theme-quartz-dark .ag-row-group .ag-group-child-count{color:#fbbf24;font-size:11px;margin-left:8px}
.ag-theme-quartz-dark .ag-row-group:hover{background:rgba(245,158,11,.2) !important}
.ag-theme-quartz-dark .ag-row-group .ag-icon{color:#f59e0b}

/* Cell Styling */
.ag-theme-quartz-dark .ag-cell{display:flex;align-items:center}
.ag-theme-quartz-dark .cell-code{color:#818cf8;font-family:'Fira Code',monospace;font-weight:600;font-size:11px}
.ag-theme-quartz-dark .cell-name{font-weight:500}
.ag-theme-quartz-dark .cell-unit{color:#64748b;text-align:center}
.ag-theme-quartz-dark .cell-num{font-family:'Fira Code',monospace;text-align:right;color:#94a3b8}
.ag-theme-quartz-dark .cell-num-empty{color:#475569}
.ag-theme-quartz-dark .cell-text{color:#64748b;font-size:11px;overflow:hidden;text-overflow:ellipsis}
.ag-theme-quartz-dark .cell-relevance{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600}
.ag-theme-quartz-dark .cell-relevance.high{background:rgba(34,197,94,.2);color:#4ade80}
.ag-theme-quartz-dark .cell-relevance.medium{background:rgba(245,158,11,.2);color:#fbbf24}
.ag-theme-quartz-dark .cell-relevance.low{background:rgba(100,116,139,.2);color:#94a3b8}
.ag-theme-quartz-dark .cell-url a{color:#818cf8;text-decoration:none}
.ag-theme-quartz-dark .cell-url a:hover{text-decoration:underline}

/* Category Rows (Group Header) */
.ag-theme-quartz-dark .ag-group-contracted,.ag-theme-quartz-dark .ag-group-expanded{background:rgba(245,158,11,.12) !important}
.ag-theme-quartz-dark .ag-group-value{color:#f59e0b;font-weight:600}

/* Editable Cells */
.ag-theme-quartz-dark .ag-cell-inline-editing{background:#1e293b;border:1px solid #6366f1;border-radius:4px;padding:4px 8px}
.ag-theme-quartz-dark .ag-cell-inline-editing input{background:transparent;color:#fff;border:none;outline:none;width:100%}

/* Actions Column */
.ag-theme-quartz-dark .cell-actions{display:flex;gap:4px;justify-content:center}
.ag-theme-quartz-dark .cell-actions button{width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.ag-theme-quartz-dark .cell-actions .btn-edit{background:rgba(99,102,241,.2);color:#818cf8}
.ag-theme-quartz-dark .cell-actions .btn-edit:hover{background:rgba(99,102,241,.4)}
.ag-theme-quartz-dark .cell-actions .btn-save{background:rgba(34,197,94,.2);color:#4ade80}
.ag-theme-quartz-dark .cell-actions .btn-save:hover{background:rgba(34,197,94,.4)}
.ag-theme-quartz-dark .cell-actions .btn-history{background:rgba(245,158,11,.2);color:#fbbf24}
.ag-theme-quartz-dark .cell-actions .btn-history:hover{background:rgba(245,158,11,.4)}
.ag-theme-quartz-dark .cell-actions .btn-delete{background:rgba(239,68,68,.2);color:#f87171}
.ag-theme-quartz-dark .cell-actions .btn-delete:hover{background:rgba(239,68,68,.4)}

/* Notes Textarea */
.ag-theme-quartz-dark .cell-notes textarea{width:100%;height:26px;padding:4px 6px;background:rgba(30,41,59,.5);border:1px solid #334155;border-radius:4px;color:#cbd5e1;font-size:11px;resize:none;font-family:inherit}
.ag-theme-quartz-dark .cell-notes textarea:focus{border-color:#6366f1;outline:none}

/* Scrollbar */
.ag-theme-quartz-dark ::-webkit-scrollbar{width:10px;height:12px}
.ag-theme-quartz-dark ::-webkit-scrollbar-track{background:#1e293b;border-radius:4px}
.ag-theme-quartz-dark ::-webkit-scrollbar-thumb{background:#6366f1;border-radius:4px;border:2px solid #1e293b}
.ag-theme-quartz-dark ::-webkit-scrollbar-thumb:hover{background:#818cf8}

/* Quick Filter Input */
.ag-theme-quartz-dark .ag-filter-toolpanel-search{background:#1e293b}
.ag-theme-quartz-dark .ag-text-field-input{background:#0f172a;border-color:#334155;color:#fff}

/* Mobile Responsive */
@media(max-width:768px){
    .ag-theme-quartz-dark{--ag-font-size:11px;--ag-row-height:36px;--ag-header-height:40px}
    .ag-theme-quartz-dark .ag-header-cell{font-size:10px}
}

/* Supplements Autocomplete & Katalog */
.autocomplete-container{position:relative}
.autocomplete-results{position:absolute;top:100%;left:0;right:0;background:var(--surface-800);border:1px solid var(--surface-600);border-radius:8px;max-height:250px;overflow-y:auto;z-index:100;margin-top:4px;display:none}
.autocomplete-results.active{display:block}
.autocomplete-item{padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--surface-700);display:flex;align-items:center;gap:12px}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover{background:var(--surface-700)}
.autocomplete-item.selected{background:rgba(99,102,241,.2)}
.autocomplete-empty{padding:12px 14px;cursor:pointer;display:flex;align-items:center;gap:12px;background:rgba(99,102,241,.06);border:1px dashed rgba(99,102,241,.3);border-radius:8px;margin:4px}
.autocomplete-empty:hover{background:rgba(99,102,241,.12)}
.autocomplete-icon{font-size:20px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(99,102,241,.15);border-radius:8px}
.autocomplete-info{flex:1;min-width:0}
.autocomplete-name{font-weight:500;color:#fff;margin-bottom:2px}
.autocomplete-desc{font-size:11px;color:var(--surface-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.autocomplete-dose{background:rgba(34,197,94,.15);color:var(--green);padding:2px 6px;border-radius:4px;font-size:10px;margin-left:auto}
.supp-tabs{display:flex;gap:8px;margin-bottom:16px}
.supp-tab{padding:8px 16px;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:8px;cursor:pointer;font-size:13px;color:var(--surface-400);transition:all .15s}
.supp-tab:hover{background:var(--surface-700);color:#fff}
.supp-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
/* Catalog Filter Chips */
.catalog-chips{display:flex;gap:6px;overflow-x:auto;padding-bottom:10px;margin-bottom:12px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.catalog-chips::-webkit-scrollbar{display:none}
.catalog-chip{white-space:nowrap;padding:6px 12px;border-radius:20px;border:1px solid var(--surface-600);background:transparent;color:var(--surface-300);font-size:12px;cursor:pointer;transition:all .2s;flex-shrink:0}
.catalog-chip:hover{border-color:var(--primary);color:var(--primary-light)}
.catalog-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}
.catalog-owned{font-size:11px;color:var(--green);font-weight:500;padding:4px 10px;background:rgba(34,197,94,.1);border-radius:6px;white-space:nowrap}
.catalog-grid{display:grid;gap:12px}
.catalog-item{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:16px;cursor:pointer;transition:all .15s}
.catalog-item:hover{border-color:var(--primary);transform:translateY(-2px)}
.catalog-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.catalog-icon{font-size:24px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px}
.catalog-title{font-weight:600;color:#fff;margin-bottom:2px}
.catalog-category{font-size:10px;color:var(--surface-400);text-transform:uppercase}
.catalog-benefits{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.catalog-benefit{background:rgba(34,197,94,.1);color:var(--green);padding:3px 8px;border-radius:4px;font-size:10px}
.catalog-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--surface-700)}
.catalog-dose{font-size:11px;color:var(--surface-400)}
.catalog-add{background:var(--primary);color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer}
.catalog-add:hover{opacity:.9}
.supp-info-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:10px;margin-right:6px}
.supp-info-badge.endurance{background:rgba(59,130,246,.15);color:#60a5fa}
.supp-info-badge.strength{background:rgba(236,72,153,.15);color:#f472b6}
.supp-info-badge.recovery{background:rgba(34,197,94,.15);color:#4ade80}
.supp-info-badge.vegan{background:rgba(132,204,22,.15);color:#a3e635}
/* Language Switcher */
.lang-switch{display:flex;gap:4px;padding:2px;background:rgba(51,65,85,.4);border-radius:8px}
.lang-btn{padding:4px 8px;border:none;background:transparent;color:var(--surface-400);font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .15s}
.lang-btn:hover{color:#fff}
.lang-btn.active{background:var(--primary);color:#fff}

/* ============================================ */
/* MEINE SUPPLEMENTS - KI-ANALYSE & CARDS      */
/* ============================================ */

/* Header für Meine Supplements */
.my-supps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.my-supps-title{font-size:20px;font-weight:600;display:flex;align-items:center;gap:10px}
.my-supps-actions{display:flex;gap:8px}
.btn-search{background:rgba(51,65,85,.5);border:1px solid var(--surface-600)}
.btn-search:hover{background:rgba(51,65,85,.7)}

/* KI-Analyse Box */
.ki-analysis-box{padding:20px;margin-bottom:20px;background:linear-gradient(135deg,rgba(139,92,246,.08),rgba(59,130,246,.08));border:1px solid rgba(139,92,246,.25);border-radius:20px}
.ki-analysis-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ki-analysis-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600}
.ki-analysis-title .icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(139,92,246,.2);border-radius:10px;font-size:20px}
.ki-refresh-btn{padding:8px 14px;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);border-radius:10px;color:#a78bfa;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}
.ki-refresh-btn:hover{background:rgba(139,92,246,.25)}

/* Benefits Summary Box */
.benefits-box{padding:14px 16px;background:rgba(34,197,94,.08);border-radius:12px;border-left:4px solid var(--green);margin-bottom:16px}
.benefits-box-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--green-light);margin-bottom:8px}
.benefits-box-text{font-size:14px;color:var(--surface-300);line-height:1.7}

/* Wechselwirkungen Section */
.interactions-section{margin-bottom:16px}
.interactions-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--surface-300);margin-bottom:12px}
.interaction-item{padding:12px 14px;border-radius:10px;margin-bottom:8px;border-left:3px solid}
.interaction-positive{background:rgba(34,197,94,.08);border-left-color:var(--green)}
.interaction-warning{background:rgba(245,158,11,.08);border-left-color:var(--amber)}
.interaction-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;margin-bottom:4px}
.interaction-positive .interaction-header{color:var(--green-light)}
.interaction-warning .interaction-header{color:var(--amber)}
.interaction-text{font-size:13px;color:var(--surface-400);line-height:1.6}

/* Mehr Infos Toggle */
.more-info-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(51,65,85,.3);border:none;border-radius:10px;color:var(--surface-300);font-size:13px;font-weight:500;cursor:pointer;margin-bottom:16px;transition:all .2s}
.more-info-toggle:hover{background:rgba(51,65,85,.5)}
.more-info-toggle .arrow{font-size:10px;transition:transform .3s}
.more-info-toggle.open .arrow{transform:rotate(180deg)}
.more-info-content{display:none;animation:fadeIn .3s ease}
.more-info-content.open{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Dosierungshinweise */
.dosage-section{margin-bottom:16px}
.dosage-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--surface-300);margin-bottom:10px}
.dosage-item{padding:10px 14px;background:rgba(59,130,246,.08);border-radius:10px;margin-bottom:8px}
.dosage-item-name{font-size:13px;font-weight:600;color:#60a5fa;margin-bottom:4px}
.dosage-item-text{font-size:13px;color:var(--surface-400);line-height:1.6}

/* Timing Box */
.timing-box{padding:14px 16px;background:rgba(139,92,246,.08);border-radius:12px;margin-bottom:16px}
.timing-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#a78bfa;margin-bottom:8px}
.timing-text{font-size:13px;color:var(--surface-400);line-height:1.7}

/* Ergänzungsvorschläge */
.suggestions-section{margin-bottom:8px}
.suggestions-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--surface-300);margin-bottom:10px}
.suggestion-item{padding:12px 14px;background:rgba(51,65,85,.25);border-radius:10px;margin-bottom:8px}
.suggestion-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}
.suggestion-reason{font-size:12px;color:var(--surface-400);line-height:1.5}

/* Supplement Card */
.supp-card{background:rgba(30,41,59,.5);border:1px solid rgba(51,65,85,.4);border-radius:16px;margin-bottom:12px;overflow:hidden;transition:all .2s}
.supp-card:hover{border-color:rgba(99,102,241,.3)}
.supp-card-header{display:flex;align-items:center;gap:14px;padding:16px}
.supp-card-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.supp-card-info{flex:1;min-width:0}
.supp-card-name{font-size:16px;font-weight:600;margin-bottom:2px}
.supp-card-dose{font-size:13px;color:var(--surface-400)}
.supp-card-times{display:flex;gap:4px;margin-top:6px}
.supp-card-tip{font-size:11px;color:var(--surface-500);padding:4px 12px 0;line-height:1.3}
.supp-card-time{display:flex;align-items:center;gap:2px;padding:3px 8px;background:rgba(51,65,85,.5);border-radius:8px;font-size:12px}
.supp-card-time small{font-size:9px;color:var(--surface-400);font-weight:500}
.supp-tile-time{display:inline-flex;align-items:center;gap:2px;font-size:12px}
.supp-tile-time small{font-size:9px;color:var(--surface-400);font-weight:500}
.supp-card-actions{display:flex;gap:8px}
.supp-card-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(51,65,85,.5);border:none;border-radius:10px;cursor:pointer;font-size:16px;transition:all .2s}
.supp-card-btn:hover{background:rgba(51,65,85,.8)}
.supp-card-btn.edit{color:var(--primary-light)}
.supp-card-btn.delete{color:var(--red)}

/* Details Toggle Button */
.supp-details-toggle{display:flex;align-items:center;gap:6px;padding:10px 16px;border-top:1px solid rgba(51,65,85,.3);background:transparent;border-bottom:none;border-left:none;border-right:none;width:100%;color:var(--primary-light);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}
.supp-details-toggle:hover{background:rgba(51,65,85,.2)}
.supp-details-toggle .arrow{font-size:10px;transition:transform .3s}
.supp-details-toggle.open .arrow{transform:rotate(180deg)}
.supp-details-toggle.open{color:var(--red)}

/* Details Content */
.supp-details{display:none;padding:16px;border-top:1px solid rgba(51,65,85,.3);background:rgba(15,23,42,.3);animation:fadeIn .3s ease}
.supp-details.open{display:block}
.supp-detail-section{margin-bottom:16px}
.supp-detail-section:last-child{margin-bottom:0}
.supp-detail-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--surface-300);margin-bottom:8px}
.supp-detail-text{font-size:13px;color:var(--surface-400);line-height:1.7}
.supp-detail-list{list-style:none;padding:0;margin:0}
.supp-detail-list li{position:relative;padding-left:16px;font-size:13px;color:var(--surface-400);margin-bottom:6px;line-height:1.5}
.supp-detail-list li::before{content:'•';position:absolute;left:0;color:var(--green)}

/* Externe Links */
.supp-external-links{display:flex;gap:10px;flex-wrap:wrap;padding-top:14px;border-top:1px solid rgba(51,65,85,.3);margin-top:16px}
.supp-external-links-title{width:100%;font-size:12px;font-weight:600;color:var(--surface-500);margin-bottom:4px}
.supp-external-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;text-decoration:none;font-size:12px;font-weight:500;transition:all .2s}
.supp-external-link.wiki{background:rgba(51,65,85,.4);color:var(--surface-300)}
.supp-external-link.wiki:hover{background:rgba(51,65,85,.6)}
.supp-external-link.pubmed{background:rgba(59,130,246,.15);color:#60a5fa}
.supp-external-link.pubmed:hover{background:rgba(59,130,246,.25)}

/* KI Loading State */
.ki-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--surface-400)}
.ki-loading-spinner{width:32px;height:32px;border:3px solid var(--surface-700);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}
.ki-loading-text{font-size:13px}
.ki-error{text-align:center;padding:30px;color:var(--surface-400)}

/* ============================================ */
/* KI-SUPPLEMENT-BERATER (KATALOG)             */
/* ============================================ */

.ki-advisor-box{background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.08));border:1px solid rgba(99,102,241,.25);border-radius:16px;margin-bottom:16px;overflow:hidden}
.ki-advisor-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:rgba(99,102,241,.1);border-bottom:1px solid rgba(99,102,241,.15)}
.ki-advisor-title{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--primary-light)}
.ki-advisor-title .icon{font-size:18px}
.ki-advisor-clear{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:rgba(239,68,68,.15);border:none;border-radius:8px;color:var(--red);font-size:14px;cursor:pointer;transition:all .2s}
.ki-advisor-clear:hover{background:rgba(239,68,68,.25)}

.ki-advisor-chat{max-height:200px;overflow-y:auto;padding:12px 16px}
.ki-advisor-welcome{text-align:center;padding:20px 10px}
.ki-advisor-welcome-icon{font-size:32px;margin-bottom:8px;opacity:.7}
.ki-advisor-welcome-text{font-size:13px;color:var(--surface-400);line-height:1.6}

.ki-advisor-message{margin-bottom:12px;animation:fadeIn .3s ease}
.ki-advisor-message.user{text-align:right}
.ki-advisor-message.user .ki-msg-bubble{background:var(--primary);color:#fff;margin-left:40px}
.ki-advisor-message.ai .ki-msg-bubble{background:rgba(51,65,85,.5);color:var(--surface-300);margin-right:40px}
.ki-msg-bubble{display:inline-block;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5;max-width:100%;text-align:left}
.ki-msg-label{font-size:10px;color:var(--surface-500);margin-bottom:4px}

.ki-advisor-loading{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(51,65,85,.3);border-radius:12px;font-size:13px;color:var(--surface-400)}
.ki-advisor-loading .dots{display:flex;gap:4px}
.ki-advisor-loading .dot{width:6px;height:6px;background:var(--primary);border-radius:50%;animation:bounce .6s infinite}
.ki-advisor-loading .dot:nth-child(2){animation-delay:.1s}
.ki-advisor-loading .dot:nth-child(3){animation-delay:.2s}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

.ki-advisor-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid rgba(99,102,241,.15);background:rgba(15,23,42,.3)}
.ki-advisor-input{flex:1;background:rgba(30,41,59,.6);border-color:rgba(99,102,241,.3)}
.ki-advisor-input:focus{border-color:var(--primary)}
.ki-advisor-send{width:44px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--primary)}
.ki-advisor-send:hover{background:var(--primary-light)}
.ki-advisor-send .send-icon{font-size:16px}

/* KI Empfehlungen Banner */
.ki-recommendations-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(34,197,94,.05));border:1px solid rgba(34,197,94,.25);border-radius:12px;margin-bottom:16px}
.ki-rec-icon{font-size:18px}
.ki-rec-text{flex:1;font-size:13px;color:var(--green-light);font-weight:500}
.ki-rec-clear{padding:6px 12px;background:rgba(51,65,85,.5);border:none;border-radius:8px;color:var(--surface-300);font-size:12px;cursor:pointer;transition:all .2s}
.ki-rec-clear:hover{background:rgba(51,65,85,.7)}

/* Empfohlene Supplements hervorheben */
.catalog-item.ki-recommended{border:2px solid rgba(34,197,94,.4);background:linear-gradient(135deg,rgba(34,197,94,.08),rgba(30,41,59,.5))}
.catalog-item.ki-recommended::before{content:'✨ KI-Empfehlung';position:absolute;top:8px;right:8px;padding:4px 8px;background:rgba(34,197,94,.2);border-radius:6px;font-size:10px;font-weight:600;color:var(--green-light)}

/* KI Floating Button + Panel */
.ki-fab{position:fixed;bottom:80px;right:20px;height:44px;background:linear-gradient(135deg,var(--primary),#8b5cf6);border-radius:22px;display:flex;align-items:center;justify-content:center;gap:7px;padding:0 16px 0 12px;cursor:pointer;box-shadow:0 4px 16px rgba(99,102,241,.4);z-index:900;transition:transform .2s,box-shadow .2s}
.ki-fab:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(99,102,241,.5)}
.ki-fab:active{transform:scale(.95)}
.ki-fab-icon{font-size:20px;line-height:1}
.ki-fab-label{font-size:13px;font-weight:600;color:#fff;white-space:nowrap}
.ki-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:950;opacity:0;transition:opacity .3s}
.ki-panel-overlay.visible{opacity:1}
.ki-panel{position:fixed;bottom:0;left:0;right:0;max-height:70vh;background:var(--surface-800);border-top:1px solid var(--surface-600);border-radius:20px 20px 0 0;z-index:960;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s ease}
.ki-panel.visible{transform:translateY(0)}
.ki-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:rgba(99,102,241,.1);border-bottom:1px solid rgba(99,102,241,.15);border-radius:20px 20px 0 0}
.ki-panel .ki-advisor-chat{flex:1;max-height:none;overflow-y:auto;padding:12px 16px}
.ki-panel .ki-advisor-input-row{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--surface-700)}
.catalog-item{position:relative;transition:all .2s}

/* Aufklappbare Katalog-Details */
.catalog-item-wrapper{margin-bottom:12px}
.catalog-details-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;background:rgba(51,65,85,.3);border:none;border-top:1px solid rgba(51,65,85,.4);color:var(--surface-400);font-size:12px;cursor:pointer;transition:all .2s;margin-top:auto}
.catalog-details-toggle:hover{background:rgba(51,65,85,.5);color:var(--surface-300)}
.catalog-details-toggle .arrow{font-size:10px;transition:transform .3s}
.catalog-details-toggle.open{color:var(--primary-light)}
.catalog-details-toggle.open .arrow{transform:rotate(180deg)}

.catalog-details{display:none;padding:14px;background:rgba(15,23,42,.4);border-top:1px solid rgba(51,65,85,.3);animation:fadeIn .3s ease}
.catalog-details.open{display:block}
.catalog-detail-section{margin-bottom:14px}
.catalog-detail-section:last-child{margin-bottom:0}
.catalog-detail-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--surface-300);margin-bottom:6px}
.catalog-detail-text{font-size:12px;color:var(--surface-400);line-height:1.6}
.catalog-detail-list{list-style:none;padding:0;margin:0}
.catalog-detail-list li{position:relative;padding-left:14px;font-size:12px;color:var(--surface-400);margin-bottom:4px;line-height:1.4}
.catalog-detail-list li::before{content:'•';position:absolute;left:0;color:var(--green)}

.catalog-external-links{display:flex;gap:8px;flex-wrap:wrap;padding-top:12px;border-top:1px solid rgba(51,65,85,.3);margin-top:12px}
.catalog-external-link{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:8px;text-decoration:none;font-size:11px;font-weight:500;transition:all .2s}
.catalog-external-link.wiki{background:rgba(51,65,85,.4);color:var(--surface-300)}
.catalog-external-link.wiki:hover{background:rgba(51,65,85,.6)}
.catalog-external-link.pubmed{background:rgba(59,130,246,.15);color:#60a5fa}
.catalog-external-link.pubmed:hover{background:rgba(59,130,246,.25)}

/* ============================================ */
/* OCR LABORBEFUND UPLOAD WORKFLOW             */
/* ============================================ */

/* Upload Zone */
.ocr-upload-zone{border:2px dashed var(--surface-600);border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s}
.ocr-upload-zone:hover,.ocr-upload-zone.drag-over{border-color:var(--primary);background:rgba(34,197,94,.05)}
.ocr-upload-zone .upload-icon{font-size:48px;margin-bottom:12px}
.ocr-upload-zone .upload-title{font-weight:600;font-size:16px;margin-bottom:4px}
.ocr-upload-zone .upload-subtitle{font-size:13px;color:var(--surface-400)}

/* Datenschutz Box */
.ocr-privacy-box{background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.3);border-radius:12px;padding:14px 16px;margin-bottom:20px;display:flex;gap:12px;align-items:flex-start}
.ocr-privacy-box .privacy-icon{font-size:20px;flex-shrink:0}
.ocr-privacy-box .privacy-title{font-size:13px;font-weight:600;color:var(--surface-200);margin-bottom:2px}
.ocr-privacy-box .privacy-text{font-size:12px;color:var(--surface-400);line-height:1.5}

/* Divider mit Text */
.ocr-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:var(--surface-500);font-size:13px}
.ocr-divider::before,.ocr-divider::after{content:'';flex:1;height:1px;background:var(--surface-700)}

/* Manual Input Button */
.ocr-manual-btn{width:100%;padding:14px;background:rgba(51,65,85,.4);border:1px solid var(--surface-600);border-radius:12px;color:var(--surface-300);font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.ocr-manual-btn:hover{background:rgba(51,65,85,.6);border-color:var(--surface-500)}

/* Progress Steps */
.ocr-progress{text-align:center;padding:30px 20px}
.ocr-progress .spinner-large{width:48px;height:48px;border:4px solid var(--surface-700);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}
.ocr-progress .status-text{font-weight:600;font-size:16px;margin-bottom:8px}
.ocr-progress .detail-text{font-size:13px;color:var(--surface-400);margin-bottom:24px}

.ocr-steps{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.ocr-step{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;background:var(--surface-700);color:var(--surface-400);transition:all .2s}
.ocr-step.active{background:var(--primary);color:#fff}
.ocr-step.done{background:rgba(34,197,94,.2);color:var(--green-light)}
.ocr-step.error{background:rgba(239,68,68,.2);color:var(--red)}

/* Success View */
.ocr-success{text-align:center;padding:30px 20px}
.ocr-success .success-icon{font-size:64px;margin-bottom:16px}
.ocr-success .success-title{font-size:20px;font-weight:600;color:var(--green-light);margin-bottom:8px}
.ocr-success .success-subtitle{color:var(--surface-400);margin-bottom:24px}
.ocr-success-box{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:12px;padding:16px;margin-bottom:24px;text-align:left}
.ocr-success-box .lab-name{font-size:14px;font-weight:600;margin-bottom:6px}
.ocr-success-box .lab-details{font-size:13px;color:var(--surface-400);line-height:1.6}

/* Warning/Duplicate View */
.ocr-warning{text-align:center;padding:30px 20px}
.ocr-warning .warning-icon{font-size:64px;margin-bottom:16px}
.ocr-warning .warning-title{font-size:20px;font-weight:600;color:var(--amber);margin-bottom:8px}
.ocr-warning .warning-subtitle{color:var(--surface-400);margin-bottom:24px;line-height:1.6}
.ocr-warning-box{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);border-radius:12px;padding:16px;margin-bottom:24px;text-align:left}
.ocr-warning-box p{font-size:13px;color:var(--surface-300);line-height:1.6;margin:0}

/* Error View */
.ocr-error{text-align:center;padding:30px 20px}
.ocr-error .error-icon{font-size:64px;margin-bottom:16px}
.ocr-error .error-title{font-size:20px;font-weight:600;color:var(--red);margin-bottom:8px}
.ocr-error .error-subtitle{color:var(--surface-400);margin-bottom:24px;line-height:1.6}

/* OCR Text Preview (collapsible) */
.ocr-text-preview{margin-bottom:24px}
.ocr-text-preview summary{font-size:13px;color:var(--primary-light);cursor:pointer;padding:8px 0}
.ocr-text-preview summary:hover{text-decoration:underline}
.ocr-text-preview .preview-content{max-height:200px;overflow-y:auto;padding:12px;background:rgba(15,23,42,.5);border:1px solid var(--surface-700);border-radius:8px;font-size:12px;color:var(--surface-400);white-space:pre-wrap;line-height:1.5;margin-top:8px}

/* Manual Input Modal */
.ocr-manual-input{padding:20px}
.ocr-manual-textarea{width:100%;min-height:200px;background:rgba(15,23,42,.5);border:1px solid var(--surface-600);border-radius:12px;padding:14px;color:var(--surface-200);font-size:13px;line-height:1.6;resize:vertical}
.ocr-manual-textarea:focus{border-color:var(--primary);outline:none}
.ocr-manual-hint{font-size:12px;color:var(--surface-500);margin-top:8px;line-height:1.5}

/* Button Row */
.ocr-buttons{display:flex;gap:12px;margin-top:20px}
.ocr-buttons .btn{flex:1}
.ocr-review{padding:16px}
/* Expanded modal for review mode */
.modal-review-expanded .modal{max-width:95vw!important;width:1100px!important;height:88vh!important;transition:all .3s}
.modal-review-expanded .modal-body{flex:1;overflow:auto}
/* AG Grid dark theme overrides */
#ocr-ag-grid{width:100%;height:calc(88vh - 260px);min-height:200px;
    --ag-row-height:46px;
    --ag-header-height:40px;
    --ag-font-size:13px;
    --ag-cell-horizontal-padding:12px;
    --ag-odd-row-background-color:rgba(15,23,42,.6);
    --ag-row-hover-color:rgba(99,102,241,.08);
}
#ocr-ag-grid .ag-root-wrapper{border:none;border-radius:8px;font-family:'Inter',sans-serif}
#ocr-ag-grid .ag-header{background:#1e293b;border-bottom:1px solid #334155}
#ocr-ag-grid .ag-header-cell{color:#94a3b8;font-weight:500;font-size:12px}
#ocr-ag-grid .ag-row{background:#0f172a;border-bottom:1px solid #1e293b;font-size:13px;color:#f1f5f9}
#ocr-ag-grid .ag-row-odd{background:#0c1322}
#ocr-ag-grid .ag-row:hover:not(.ag-row-group){background:rgba(99,102,241,.06)!important}
#ocr-ag-grid .ag-row:hover:not(.ag-row-group) .ag-cell{color:#f1f5f9!important}
#ocr-ag-grid .ag-row.ag-row-warn{background:rgba(234,179,8,.06)}
#ocr-ag-grid .ag-row.ag-row-error{background:rgba(239,68,68,.08)}
#ocr-ag-grid .ag-row.ag-row-confirmed{background:rgba(34,197,94,.05)}
#ocr-ag-grid .ag-cell{display:flex;align-items:center;padding:0 10px;line-height:1.4}
#ocr-ag-grid .ag-cell-focus{border:1px solid var(--primary)!important}
#ocr-ag-grid .ag-cell-inline-editing{padding:0 4px}
#ocr-ag-grid .ag-input-field-input{background:#1e293b!important;color:#f1f5f9!important;border:1px solid #6366f1!important;border-radius:4px;padding:6px 8px;font-size:14px;font-family:'SF Mono',Menlo,Consolas,monospace}
#ocr-ag-grid .ag-body-viewport{background:#0f172a}
#ocr-ag-grid .ag-overlay-no-rows-wrapper{background:#0f172a;color:#64748b}
.ag-rv-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500}
.ag-rv-badge.normal{background:rgba(34,197,94,.15);color:#4ade80}
.ag-rv-badge.high,.ag-rv-badge.low{background:rgba(234,179,8,.15);color:#eab308}
.ag-rv-badge.critical_high,.ag-rv-badge.critical_low{background:rgba(239,68,68,.15);color:#f87171}
.ag-rv-badge.unknown{background:rgba(148,163,184,.15);color:#94a3b8}
.ag-rv-warn{cursor:help;font-size:13px;margin-left:4px}
.ag-rv-conf{font-size:10px;margin-left:6px;padding:1px 5px;border-radius:8px;font-weight:600;letter-spacing:-.3px}
.ag-rv-conf.conf-high{color:#22c55e;background:rgba(34,197,94,.1)}
.ag-rv-conf.conf-mid{color:#eab308;background:rgba(234,179,8,.1)}
.ag-rv-conf.conf-low{color:#f87171;background:rgba(248,113,113,.15)}
.gr-confidence{font-size:12px;padding:2px 7px;border-radius:10px;font-weight:600;vertical-align:middle;margin-left:6px}
.gr-confidence.conf-high{color:#22c55e;background:rgba(34,197,94,.1)}
.gr-confidence.conf-mid{color:#eab308;background:rgba(234,179,8,.1)}
.gr-confidence.conf-low{color:#f87171;background:rgba(248,113,113,.15)}
.gr-confidence-sm{font-size:9px;padding:1px 4px;border-radius:6px;font-weight:600}
.gr-confidence-sm.conf-high{color:#22c55e}
.gr-confidence-sm.conf-mid{color:#eab308}
.gr-confidence-sm.conf-low{color:#f87171}
.ag-rv-changed{background:rgba(234,179,8,.1);border-radius:4px;padding:2px 6px;border:1px solid rgba(234,179,8,.3)}
.ag-rv-sub{display:block;font-size:10px;color:#64748b;font-weight:400;line-height:1.2}
.ag-rv-check{width:26px;height:26px;border-radius:6px;border:2px solid #475569;background:none;color:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:all .12s;padding:0;vertical-align:middle}
.ag-rv-check:hover{border-color:#6366f1;background:rgba(99,102,241,.1)}
.ag-rv-check.checked{border-color:#22c55e;background:#22c55e;color:#fff}
.ag-rv-del{background:none;border:none;color:#475569;cursor:pointer;font-size:12px;padding:4px;border-radius:4px;margin-left:2px;vertical-align:middle}
.ag-rv-del:hover{color:#f87171;background:rgba(239,68,68,.1)}
/* Review footer */
.ocr-review-progress{display:flex;align-items:center;gap:12px;padding:8px 2px 0}
.ocr-review-progress-bar{flex:1;height:6px;background:var(--surface-700);border-radius:3px;overflow:hidden}
.ocr-review-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--green));border-radius:3px;transition:width .3s}
.ocr-review-progress-text{font-size:12px;color:var(--surface-400);white-space:nowrap}
.ocr-review-actions{display:flex;gap:12px;margin-top:10px;align-items:center}
.ocr-review-actions .btn{flex:1}
/* Guided Review Mode */
.ocr-mode-bar{display:flex;gap:6px;margin-bottom:14px}
.ocr-mode-btn{flex:1;padding:8px 12px;border-radius:10px;border:1px solid var(--surface-700);background:transparent;color:var(--surface-400);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;text-align:center}
.ocr-mode-btn:hover{border-color:var(--primary);color:var(--primary-light)}
.ocr-mode-btn.active{background:rgba(99,102,241,.12);border-color:var(--primary);color:var(--primary-light)}
#ocr-mode-guided.active{background:rgba(34,197,94,.15);border-color:var(--green);color:var(--green-light)}
#ocr-mode-guided:not(.active){border-color:rgba(34,197,94,.35);color:var(--green)}
#ocr-guided-container{max-height:calc(88vh - 280px);overflow-y:auto;scroll-behavior:smooth}
.gr-item{border-radius:14px;margin-bottom:6px;transition:all .3s ease;cursor:pointer;overflow:hidden;border:1px solid transparent}
.gr-item.pending{opacity:.35;padding:10px 14px;background:rgba(15,23,42,.5)}
.gr-item.done{opacity:.75;padding:10px 14px;background:rgba(34,197,94,.04);border-color:rgba(34,197,94,.15)}
.gr-item.active{opacity:1;padding:0;background:rgba(99,102,241,.04);border-color:rgba(99,102,241,.25);cursor:default}
.gr-item.pending:hover{opacity:.55}
.gr-item.done:hover{opacity:.9}
.gr-compact{display:flex;align-items:center;gap:10px}
.gr-compact-num{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.gr-item.pending .gr-compact-num{background:var(--surface-700);color:var(--surface-400)}
.gr-item.done .gr-compact-num{background:rgba(34,197,94,.2);color:var(--green)}
.gr-compact-name{font-size:13px;font-weight:600;color:#e2e8f0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gr-compact-val{font-size:13px;font-weight:600;color:var(--surface-400);font-family:'SF Mono',Menlo,Consolas,monospace}
.gr-compact-check{font-size:14px;color:var(--green)}
.gr-active-card{padding:20px}
.gr-step-label{font-size:11px;color:var(--primary-light);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.gr-step-counter{font-size:11px;color:var(--surface-500);text-transform:none;letter-spacing:0}
.gr-param-name{font-size:18px;font-weight:700;color:#fff;margin-bottom:2px}
.gr-param-sub{font-size:12px;color:var(--surface-500);margin-bottom:12px}
.gr-explanation{font-size:13px;color:var(--surface-400);line-height:1.6;padding:10px 14px;background:rgba(30,41,59,.6);border-radius:10px;margin-bottom:16px;border-left:3px solid var(--primary)}
.gr-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.gr-field label{display:block;font-size:10px;color:var(--surface-500);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;font-weight:600}
.gr-field input{width:100%;padding:8px 10px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:8px;color:#f1f5f9;font-size:14px;font-family:'SF Mono',Menlo,Consolas,monospace}
.gr-field input:focus{border-color:var(--primary);outline:none}
.gr-field select,.gr-field-select{width:100%;padding:8px 10px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:8px;color:#f1f5f9;font-size:14px;font-family:'SF Mono',Menlo,Consolas,monospace;appearance:auto;cursor:pointer}
.gr-field select:focus,.gr-field-select:focus{border-color:var(--primary);outline:none}
.gr-field select option{background:#1e293b;color:#f1f5f9}
.gr-field.full{grid-column:1/-1}
.gr-range{margin-bottom:16px}
.gr-range-bar{position:relative;height:28px;background:var(--surface-700);border-radius:8px;overflow:visible;margin:8px 0 4px}
.gr-range-fill{position:absolute;top:0;height:100%;background:rgba(34,197,94,.2);border-radius:8px}
.gr-range-marker{position:absolute;top:-4px;width:3px;height:36px;border-radius:2px;transform:translateX(-50%);z-index:2}
.gr-range-marker.normal{background:var(--green)}
.gr-range-marker.low,.gr-range-marker.high{background:var(--red)}
.gr-range-marker.borderline{background:var(--amber)}
.gr-range-marker-label{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:11px;font-weight:700;white-space:nowrap}
.gr-range-marker.normal .gr-range-marker-label{color:var(--green)}
.gr-range-marker.low .gr-range-marker-label,.gr-range-marker.high .gr-range-marker-label{color:var(--red)}
.gr-range-marker.borderline .gr-range-marker-label{color:var(--amber)}
.gr-range-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--surface-500)}
.gr-range-status{text-align:center;margin-top:4px}
.gr-nav{display:flex;gap:10px;margin-top:4px}
.gr-nav button{flex:1;padding:10px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:Inter,sans-serif;border:none}
.gr-nav-prev{background:var(--surface-700);color:var(--surface-400)}
.gr-nav-prev:hover{background:var(--surface-600);color:#fff}
.gr-nav-next{background:var(--primary);color:#fff}
.gr-nav-next:hover{background:var(--primary-light)}
.gr-nav-finish{background:var(--green);color:#fff}
.gr-nav-finish:hover{background:var(--green-light)}
.ocr-check-all-btn{font-size:12px;color:var(--surface-400);background:none;border:1px solid var(--surface-600);border-radius:8px;padding:6px 14px;cursor:pointer;white-space:nowrap;transition:all .15s}
.ocr-check-all-btn:hover{color:var(--primary);border-color:var(--primary)}
/* Mobile card layout */
#ocr-mobile-cards{display:none}
.rv-card{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:14px;margin-bottom:8px;position:relative;transition:border-color .15s}
.rv-card.card-warn{border-color:rgba(234,179,8,.3);background:rgba(234,179,8,.03)}
.rv-card.card-error{border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.04)}
.rv-card.card-confirmed{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.04)}
.rv-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.rv-card-name{font-weight:600;font-size:14px;line-height:1.3}
.rv-card-name small{display:block;font-weight:400;font-size:11px;color:var(--surface-500)}
.rv-card-actions{display:flex;gap:4px;flex-shrink:0;margin-left:8px}
.rv-card-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.rv-card-field{display:flex;flex-direction:column;gap:3px}
.rv-card-field.wide{grid-column:1/-1}
.rv-card-label{font-size:10px;color:var(--surface-500);text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.rv-card-input{background:var(--surface-900);border:1px solid var(--surface-600);border-radius:6px;padding:8px 10px;color:var(--surface-100);font-size:15px;font-family:'SF Mono',Menlo,Consolas,monospace;width:100%;box-sizing:border-box;-moz-appearance:textfield}
select.rv-card-input{appearance:auto;cursor:pointer}
select.rv-card-input option{background:#1e293b;color:#f1f5f9}
.rv-card-input::-webkit-inner-spin-button{-webkit-appearance:none}
.rv-card-input:focus{border-color:var(--primary);outline:none}
.rv-card-input.changed{border-color:#eab308;background:rgba(234,179,8,.06)}
.rv-card-input.unit-input{font-size:13px;font-family:'Inter',sans-serif}
.rv-card-foot{display:flex;align-items:center;gap:6px;margin-top:8px}
@media(max-width:768px){
.modal-review-expanded .modal{max-width:100vw!important;width:100%!important;height:100dvh!important;border-radius:0!important}
#ocr-ag-grid{display:none!important}
#ocr-mobile-cards{display:block;flex:1;overflow:auto;-webkit-overflow-scrolling:touch;padding:0 2px}
}


/* ===== TOUR SYSTEM ===== */
.tour-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9000;pointer-events:all;transition:opacity .3s;opacity:0;visibility:hidden}
.tour-overlay.active{opacity:1;visibility:visible}
.tour-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45)}
.tour-spotlight{position:absolute;border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,.45);z-index:9001;pointer-events:none;transition:all .4s ease}
.tour-tooltip{position:absolute;z-index:9002;background:var(--surface-700);border:1px solid var(--surface-600);border-radius:16px;padding:20px;max-width:380px;min-width:280px;box-shadow:0 20px 60px rgba(0,0,0,.5);transition:all .4s ease;pointer-events:all;overflow:hidden}
.tour-tooltip::before{content:'';position:absolute;width:12px;height:12px;background:var(--surface-700);border:1px solid var(--surface-600);transform:rotate(45deg)}
.tour-tooltip.arrow-top::before{top:-7px;left:30px;border-right:0;border-bottom:0}
.tour-tooltip.arrow-bottom::before{bottom:-7px;left:30px;border-left:0;border-top:0}
.tour-tooltip.arrow-left::before{left:-7px;top:20px;border-top:0;border-right:0}
.tour-step-badge{display:inline-block;background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:20px;margin-bottom:10px}
.tour-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.tour-text{font-size:13px;color:var(--surface-300);line-height:1.6;margin-bottom:16px}
.tour-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.tour-dots{display:flex;gap:3px;align-items:center;flex-wrap:wrap;max-width:120px;justify-content:center}
.tour-dot{width:6px;height:6px;border-radius:50%;background:var(--surface-500);transition:all .3s;flex-shrink:0}
.tour-dot.active{width:14px;border-radius:3px;background:var(--primary)}
.tour-btn{padding:8px 18px;border-radius:10px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all .2s}
.tour-btn-next{background:var(--primary);color:#fff}
.tour-btn-next:hover{background:#818cf8}
.tour-btn-back{background:rgba(255,255,255,.08);color:var(--surface-300)}
.tour-btn-back:hover{background:rgba(255,255,255,.12)}
.tour-btn-skip{background:none;border:none;color:var(--surface-500);font-size:12px;cursor:pointer;padding:4px 8px}
.tour-btn-skip:hover{color:var(--surface-300)}

/* Welcome splash step (centered) */
.tour-splash{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9002;background:var(--surface-700);border:1px solid var(--surface-600);border-radius:20px;padding:32px;max-width:380px;width:90%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.5);pointer-events:all}
.tour-splash-icon{font-size:56px;margin-bottom:12px}
.tour-splash .tour-title{font-size:20px}

/* ===== CONTEXT HELP ===== */
.help-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:rgba(99,102,241,.15);color:var(--primary-light);font-size:11px;font-weight:700;font-style:italic;font-family:Georgia,serif;cursor:pointer;transition:all .2s;vertical-align:middle;margin-left:6px;flex-shrink:0;user-select:none;line-height:1}
.help-icon:hover{background:rgba(99,102,241,.3);transform:scale(1.1)}
.help-popover{position:fixed;z-index:8000;background:var(--surface-700);border:1px solid var(--surface-600);border-radius:14px;padding:16px;max-width:320px;min-width:220px;box-shadow:0 12px 40px rgba(0,0,0,.5);animation:helpFadeIn .2s ease}
@keyframes helpFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.help-popover-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.help-popover-text{font-size:12px;color:var(--surface-300);line-height:1.6}
.help-popover-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--surface-400);font-size:16px;cursor:pointer;padding:2px 6px;line-height:1}
.help-popover-close:hover{color:#fff}

/* ===== RESPONSIVE: TABLET LANDSCAPE (≤1024px) ===== */
@media(max-width:1024px){
    .nav-items{max-width:600px}
    .bi-summary{gap:8px}
    .bi-summary-card .bi-count{font-size:28px}
}

/* ===== RESPONSIVE: TABLET PORTRAIT (≤768px) ===== */
@media(max-width:768px){
    /* T1: Header Tablet */
    .app-header{padding:12px 16px}
    .header-left{gap:12px}
    .header-name{font-size:16px}
    .header-right{gap:8px}
    .admin-link{padding:4px 6px}
    /* T2: Modals Tablet */
    .modal{max-width:600px}
    /* T3: Nav Tablet */
    .nav-items{max-width:560px}
    /* T4: Grids Tablet */
    .supp-tiles-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
    /* T5: Blood detail Tablet */
    .bi-summary-card .bi-count{font-size:26px}
    /* Tour: etwas schmaler */
    .tour-tooltip{max-width:340px;min-width:260px}
    .tour-splash{max-width:340px}
}

/* ===== RESPONSIVE: LARGE PHONE / SMALL TABLET (≤640px) ===== */
@media(max-width:640px){
    .header-greeting{font-size:12px}
    .header-name{font-size:15px}
    .header-right{gap:6px}
    .header-streak{padding:4px 8px;font-size:12px}
    .header-avatar{width:34px;height:34px;font-size:14px}
    .form-row{grid-template-columns:1fr}
    .form-row-3{grid-template-columns:1fr}
    .tour-tooltip{max-width:calc(100vw - 32px);min-width:240px}
    .tour-splash{max-width:calc(100vw - 40px);width:calc(100vw - 40px)}
}

/* ===== RESPONSIVE: PHONE (≤480px) ===== */
@media(max-width:480px){
    /* M2: Header Phone kompakt */
    .app-header{padding:10px 12px}
    .header-left{gap:8px}
    .header-logo{font-size:20px}
    .header-logo sup{font-size:10px}
    .header-greeting{display:none}
    .header-name{font-size:14px}
    .header-right{gap:4px}
    .header-streak{padding:3px 7px;font-size:11px;gap:3px}
    .header-avatar{width:32px;height:32px;font-size:13px}
    .admin-link{padding:3px 5px;font-size:11px}
    #tour-link{display:none}
    /* M4: Stats kompakter */
    .stats-grid{gap:8px}
    .stat-card{padding:12px 8px}
    .stat-value{font-size:22px}
    .stat-label{font-size:10px}
    /* M5: Disclaimer kompakter */
    .disclaimer-banner{padding:14px;border-radius:14px;bottom:80px}
    .disclaimer-icon{font-size:22px}
    .disclaimer-title{font-size:13px}
    .disclaimer-text{font-size:12px}
    .disclaimer-btn{padding:8px 12px;font-size:12px}
    /* M6: Forms einspaltig */
    .form-row{grid-template-columns:1fr}
    .form-row-3{grid-template-columns:1fr}
    /* Cards kompakter */
    .card{padding:16px;border-radius:16px;margin-bottom:12px}
    main{padding:12px;padding-bottom:90px}
    /* Modal Phone */
    .modal-overlay{padding:10px}
    .modal{border-radius:18px;max-height:92vh}
    .modal-header{padding:14px 16px;gap:8px}
    .modal-title{font-size:16px}
    .modal-body{padding:14px 16px}
    /* M3: Tour Phone */
    .tour-tooltip{max-width:calc(100vw - 24px);min-width:0;padding:16px;border-radius:14px}
    .tour-tooltip::before{display:none}
    .tour-title{font-size:14px}
    .tour-text{font-size:12px;margin-bottom:12px}
    .tour-btn{padding:7px 14px;font-size:12px}
    .tour-step-badge{font-size:10px;padding:2px 8px}
    .tour-splash{max-width:calc(100vw - 32px);width:calc(100vw - 32px);padding:24px 20px;border-radius:16px}
    .tour-splash-icon{font-size:44px;margin-bottom:8px}
    .tour-splash .tour-title{font-size:18px}
    /* Blutbild Phone */
    .bi-summary{gap:6px;padding:10px}
    .bi-summary-card{padding:10px 6px}
    .bi-summary-card .bi-count{font-size:22px}
    .bi-summary-card .bi-label{font-size:10px}
    /* Settings / Profil kompakter */
    .settings-item{padding:12px 14px}
    .settings-icon{width:32px;height:32px;font-size:16px;margin-right:10px}
    /* Lang-Switch kompakter */
    .lang-switch{gap:2px;padding:1px}
    .lang-btn{padding:3px 6px;font-size:10px}
    /* Profile-Switcher kompakter */
    .ps-btn{padding:4px 8px;gap:4px;font-size:12px}
    .ps-avatar{width:22px;height:22px;font-size:10px}
}

/* ===== RESPONSIVE: VERY SMALL PHONE (≤360px) ===== */
@media(max-width:360px){
    .header-logo{font-size:18px}
    .header-name{font-size:13px}
    .header-right{gap:3px}
    .header-streak{display:none}
    .lang-switch{display:none}
    .stat-value{font-size:20px}
    .card{padding:12px}
    main{padding:8px;padding-bottom:85px}
}
/* Coach Result Cards */
.cr-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.cr-avatar{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--primary),#818cf8);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.cr-greeting{font-size:17px;font-weight:600;color:#fff}
.cr-summary{color:var(--surface-400);font-size:13px;line-height:1.6;margin-top:4px}
.cr-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:20px}
.cr-stat{background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:14px;padding:14px 12px;text-align:center}
.cr-stat-icon{font-size:18px;margin-bottom:4px}
.cr-stat-val{font-size:20px;font-weight:700;color:#fff}
.cr-stat-lbl{font-size:10px;color:var(--surface-500);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.cr-section{border-radius:16px;padding:16px;margin-bottom:12px;border-left:4px solid;transition:all .2s}
.cr-section.good{background:rgba(34,197,94,.06);border-color:var(--green)}
.cr-section.warning{background:rgba(245,158,11,.06);border-color:var(--amber)}
.cr-section.critical{background:rgba(239,68,68,.06);border-color:var(--red)}
.cr-section.info{background:rgba(99,102,241,.06);border-color:var(--primary)}
.cr-sec-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.cr-sec-icon{font-size:20px;flex-shrink:0}
.cr-sec-title{font-size:15px;font-weight:600;color:#fff;flex:1}
.cr-badge{font-size:9px;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}
.cr-section.good .cr-badge{background:rgba(34,197,94,.15);color:var(--green)}
.cr-section.warning .cr-badge{background:rgba(245,158,11,.15);color:var(--amber)}
.cr-section.critical .cr-badge{background:rgba(239,68,68,.15);color:var(--red)}
.cr-section.info .cr-badge{background:rgba(99,102,241,.15);color:var(--primary-light)}
.cr-items{padding-left:28px}
.cr-item{color:var(--surface-400);font-size:13px;line-height:1.65;margin-bottom:6px;position:relative;padding-left:16px}
.cr-item::before{content:'›';position:absolute;left:0;color:var(--surface-600);font-weight:700;font-size:15px}
.cr-item strong,.cr-item b{color:#cbd5e1;font-weight:600}
.cr-actions{margin:20px 0 12px}
.cr-act-title{font-size:13px;font-weight:600;color:var(--surface-500);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}
.cr-action{display:flex;align-items:flex-start;gap:10px;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);border-radius:14px;padding:12px 14px;margin-bottom:8px}
.cr-action-num{width:24px;height:24px;border-radius:8px;background:var(--primary);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cr-action-icon{font-size:18px;flex-shrink:0}
.cr-action-text{color:#e2e8f0;font-size:13px;line-height:1.5}
.cr-disclaimer{margin-top:16px;padding:12px 14px;background:rgba(100,116,139,.1);border-radius:12px;font-size:11px;color:var(--surface-500);line-height:1.5;display:flex;align-items:flex-start;gap:8px}
.cr-key-insight{background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(139,92,246,.08));border:1px solid rgba(99,102,241,.3);border-radius:16px;padding:18px 20px;margin-bottom:20px;position:relative;overflow:hidden}
.cr-key-insight::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#a855f7,var(--primary-light))}
.cr-key-insight-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--primary-light);margin-bottom:6px}
.cr-key-insight-text{font-size:14px;color:#e2e8f0;line-height:1.6;font-weight:500}
.cr-cross{border-radius:16px;padding:16px 18px;margin-bottom:10px;border:1px solid;position:relative}
.cr-cross.good{background:rgba(34,197,94,.05);border-color:rgba(34,197,94,.2)}
.cr-cross.warning{background:rgba(245,158,11,.05);border-color:rgba(245,158,11,.2)}
.cr-cross.critical{background:rgba(239,68,68,.05);border-color:rgba(239,68,68,.2)}
.cr-cross.info{background:rgba(99,102,241,.05);border-color:rgba(99,102,241,.2)}
.cr-cross-hdr{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.cr-cross-icon{font-size:18px;flex-shrink:0}
.cr-cross-title{font-size:14px;font-weight:700;color:#fff}
.cr-cross-text{font-size:13px;color:var(--surface-400);line-height:1.6}
.cr-cross-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.cr-cross-tag{font-size:9px;padding:2px 8px;border-radius:10px;background:rgba(99,102,241,.12);color:var(--primary-light);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.cr-deep{border-radius:16px;padding:20px;margin-bottom:14px;border-left:4px solid;transition:all .2s}
.cr-deep.good{background:rgba(34,197,94,.05);border-color:var(--green)}
.cr-deep.warning{background:rgba(245,158,11,.05);border-color:var(--amber)}
.cr-deep.critical{background:rgba(239,68,68,.05);border-color:var(--red)}
.cr-deep.info{background:rgba(99,102,241,.05);border-color:var(--primary)}
.cr-deep-hdr{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.cr-deep-icon{font-size:20px;flex-shrink:0}
.cr-deep-title{font-size:15px;font-weight:700;color:#fff;flex:1}
.cr-deep-content{font-size:13px;color:#cbd5e1;line-height:1.75;margin-bottom:8px}
.cr-deep-bullets{margin-top:10px;padding-left:6px}
.cr-deep-bullet{font-size:12px;color:var(--surface-400);line-height:1.5;padding:4px 0 4px 14px;position:relative}
.cr-deep-bullet::before{content:'›';position:absolute;left:2px;color:var(--primary-light);font-weight:700}
.cr-supp-wrap{margin:20px 0}
.cr-supp-title{font-size:13px;font-weight:700;color:var(--primary-light);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.cr-supp{border-radius:14px;padding:16px;margin-bottom:10px;border:1px solid;display:flex;gap:14px;align-items:flex-start}
.cr-supp.optimal{background:rgba(34,197,94,.04);border-color:rgba(34,197,94,.2)}
.cr-supp.adjust{background:rgba(245,158,11,.04);border-color:rgba(245,158,11,.2)}
.cr-supp.add{background:rgba(99,102,241,.06);border-color:rgba(99,102,241,.25)}
.cr-supp.unnecessary{background:rgba(100,116,139,.04);border-color:rgba(100,116,139,.2)}
.cr-supp-badge{flex-shrink:0;width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}
.cr-supp.optimal .cr-supp-badge{background:rgba(34,197,94,.15)}
.cr-supp.adjust .cr-supp-badge{background:rgba(245,158,11,.15)}
.cr-supp.add .cr-supp-badge{background:rgba(99,102,241,.15)}
.cr-supp.unnecessary .cr-supp-badge{background:rgba(100,116,139,.15)}
.cr-supp-body{flex:1;min-width:0}
.cr-supp-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:2px}
.cr-supp-status{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.cr-supp.optimal .cr-supp-status{color:var(--green)}
.cr-supp.adjust .cr-supp-status{color:var(--amber)}
.cr-supp.add .cr-supp-status{color:var(--primary-light)}
.cr-supp.unnecessary .cr-supp-status{color:var(--surface-500)}
.cr-supp-dose{font-size:11px;color:var(--surface-400);margin-bottom:6px;display:flex;gap:16px;flex-wrap:wrap}
.cr-supp-dose span{display:inline-flex;align-items:center;gap:4px}
.cr-supp-reason{font-size:12px;color:var(--surface-400);line-height:1.6}
.cr-supp-timing{font-size:11px;color:#06b6d4;margin-top:6px;padding:4px 8px;background:rgba(6,182,212,.08);border-radius:6px;display:inline-block}
.cr-supp-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.cr-action-btn{font-size:11px;font-weight:600;padding:5px 12px;border-radius:8px;border:1px solid var(--surface-600);background:transparent;color:var(--surface-300);cursor:pointer;transition:all .15s;font-family:Inter,sans-serif}
.cr-action-btn:hover{background:rgba(99,102,241,.12);border-color:var(--primary);color:var(--primary-light)}
.cr-action-btn.add{background:rgba(99,102,241,.12);border-color:rgba(99,102,241,.3);color:var(--primary-light)}
.cr-action-btn.add:hover{background:rgba(99,102,241,.25)}
.cr-action-btn.adjust{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.25);color:var(--amber)}
.cr-action-btn.adjust:hover{background:rgba(245,158,11,.18)}
.cr-situation{display:flex;gap:10px;padding:10px 12px;margin:12px 0;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.15);border-radius:10px}
.cr-situation-icon{font-size:16px;flex-shrink:0}
.cr-situation-text{font-size:12px;color:var(--surface-400);line-height:1.5}
.cr-resources{margin-top:16px;margin-bottom:12px}
.cr-resources-title{font-size:12px;font-weight:700;color:var(--surface-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.cr-resource{display:flex;gap:10px;padding:10px 12px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:10px;margin-bottom:6px;transition:all .15s;cursor:pointer;text-decoration:none}
.cr-resource:hover{background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.3)}
.cr-resource-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.cr-resource-body{flex:1;min-width:0}
.cr-resource-name{font-size:12px;font-weight:600;color:var(--primary-light);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cr-resource-why{font-size:11px;color:var(--surface-500);line-height:1.4}
.strava-period-btn{background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:8px;padding:4px 10px;font-size:11px;font-weight:600;color:var(--surface-400);cursor:pointer;transition:all .15s;font-family:Inter,sans-serif}
.strava-period-btn:hover{border-color:var(--primary);color:var(--primary-light)}
.strava-period-btn.active{background:rgba(252,76,2,.15);border-color:#FC4C02;color:#FC4C02}
.cr-sport-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px;margin-bottom:16px}
.cr-sport-card{background:rgba(30,41,59,.5);border:1px solid var(--surface-700);border-radius:14px;padding:14px 16px;position:relative;overflow:hidden}
.cr-sport-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.cr-sport-card.Run::before{background:#22c55e}
.cr-sport-card.Swim::before{background:#06b6d4}
.cr-sport-card.Ride::before{background:#f59e0b}
.cr-sport-card.Workout::before,.cr-sport-card.WeightTraining::before{background:#a855f7}
.cr-sport-card-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.cr-sport-card-icon{font-size:18px}
.cr-sport-card-name{font-size:14px;font-weight:700;color:#fff;flex:1}
.cr-sport-card-count{font-size:11px;color:var(--surface-500);background:rgba(100,116,139,.15);padding:2px 8px;border-radius:6px}
.cr-sport-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}
.cr-sport-card-stat{display:flex;flex-direction:column}
.cr-sport-card-stat-val{font-size:14px;font-weight:700;color:#e2e8f0}
.cr-sport-card-stat-lbl{font-size:9px;color:var(--surface-500);text-transform:uppercase;letter-spacing:.3px}
.cr-period-label{font-size:11px;color:var(--surface-500);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.cr-cross-wrap{margin-bottom:20px}
.cr-cross-wrap-title{font-size:13px;font-weight:700;color:var(--primary-light);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.cr-next-blood{background:rgba(6,182,212,.06);border:1px solid rgba(6,182,212,.2);border-radius:14px;padding:16px;margin-top:16px;margin-bottom:12px}
.cr-next-blood-title{font-size:12px;font-weight:700;color:#06b6d4;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.cr-next-blood-item{font-size:12px;color:var(--surface-400);line-height:1.5;padding:4px 0;padding-left:16px;position:relative}
.cr-next-blood-item::before{content:'›';position:absolute;left:4px;color:#06b6d4;font-weight:700}
.cr-chart-wrap{background:rgba(30,41,59,.4);border-radius:14px;border:1px solid var(--surface-700);padding:16px;margin-bottom:16px}
.cr-chart-title{font-size:13px;font-weight:600;color:var(--surface-400);margin-bottom:12px}
.cr-bar-chart{display:flex;flex-direction:column;gap:8px}
.cr-bar-row{display:flex;align-items:center;gap:10px}
.cr-bar-label{font-size:11px;color:var(--surface-400);width:70px;text-align:right;flex-shrink:0}
.cr-bar-track{flex:1;height:20px;background:rgba(51,65,85,.4);border-radius:6px;overflow:hidden;position:relative}
.cr-bar-fill{height:100%;border-radius:6px;transition:width .6s ease}
.cr-bar-val{font-size:11px;color:var(--surface-400);width:50px;flex-shrink:0}
@media(max-width:480px){
    .cr-stats{grid-template-columns:repeat(2,1fr);gap:8px}
    .cr-stat{padding:10px 8px}
    .cr-stat-val{font-size:18px}
    .cr-items{padding-left:0}
    .cr-bar-label{width:50px;font-size:10px}
}

/* ============================================================
   SUPPLEMENT PLANNER — Day/Week/Month Views + Drag&Drop
   ============================================================ */
.sp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.sp-title{font-size:20px;font-weight:700}
.sp-period-tabs{display:flex;gap:4px;background:var(--surface-800);border-radius:10px;padding:3px;border:1px solid var(--surface-700)}
.sp-period-tab{padding:6px 14px;border-radius:8px;border:none;background:transparent;color:var(--surface-400);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.sp-period-tab.active{background:var(--primary);color:#fff}
.sp-period-tab:hover:not(.active){background:var(--surface-700);color:#fff}
/* Unified mobile tabs — hidden on desktop */
.sp-unified-tabs{display:none;gap:4px;background:var(--surface-800);border-radius:12px;padding:3px;border:1px solid var(--surface-700)}
.sp-uni-tab{padding:7px 12px;border-radius:9px;border:none;background:transparent;color:var(--surface-400);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.sp-uni-tab.active{background:var(--primary);color:#fff}
.sp-uni-tab:hover:not(.active){background:var(--surface-700);color:#fff}
.sp-date-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.sp-date-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--surface-700);background:var(--surface-800);color:var(--surface-300);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.sp-date-btn:hover{background:var(--surface-700);color:#fff}
.sp-date-label{font-size:15px;font-weight:600;color:#fff;flex:1;text-align:center}
.sp-date-today{padding:6px 12px;border-radius:8px;border:1px solid var(--primary);background:rgba(99,102,241,.1);color:var(--primary-light);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.sp-date-today:hover{background:rgba(99,102,241,.2)}

/* Day View: 3 Columns */
.sp-day-grid{display:flex;flex-direction:column;gap:0}
/* Day Progress Bar */
.sp-day-progress{margin-bottom:16px}
.sp-day-progress-text{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--surface-300);margin-bottom:6px}
.sp-day-progress-bar{height:8px;background:var(--surface-700);border-radius:4px;overflow:hidden}
.sp-day-progress-fill{height:100%;border-radius:4px;transition:width .5s ease}
/* Vertical Timeline */
.sp-timeline{display:flex;flex-direction:column;gap:0}
.sp-tl-slot{display:flex;gap:16px;position:relative}
.sp-tl-line{display:flex;flex-direction:column;align-items:center;width:44px;flex-shrink:0}
.sp-tl-dot{width:44px;height:44px;border-radius:50%;background:var(--surface-800);border:2px solid var(--surface-600);display:flex;align-items:center;justify-content:center;font-size:20px;z-index:1;transition:all .2s}
.sp-tl-dot.done{border-color:var(--green);background:rgba(34,197,94,.1)}
.sp-tl-connector{width:2px;flex:1;min-height:20px;background:var(--surface-600)}
.sp-tl-content{flex:1;padding-bottom:20px;min-width:0}
.sp-tl-header{display:flex;align-items:center;justify-content:space-between;height:44px;margin-bottom:8px}
.sp-tl-label{font-size:15px;font-weight:600;color:#fff}
.sp-tl-count{font-size:12px;font-weight:600}
.sp-tl-empty{padding:12px 16px;border:1px dashed var(--surface-600);border-radius:12px;text-align:center;font-size:13px;cursor:pointer;transition:all .2s}
.sp-tl-empty:hover{border-color:var(--primary);background:rgba(99,102,241,.05)}
.sp-tl-items{display:flex;flex-direction:column;gap:6px}
.sp-tl-items.drag-over{background:rgba(99,102,241,.06);border-radius:12px;outline:2px dashed var(--primary);outline-offset:4px}
.sp-tl-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:14px;cursor:grab;transition:all .2s;user-select:none;-webkit-user-select:none}
.sp-tl-card:hover{border-color:var(--surface-600);background:rgba(30,41,59,.8)}
.sp-tl-card.taken{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.06)}
.sp-tl-card.skipped{opacity:.5;border-style:dashed}
.sp-tl-card.dragging{opacity:.4;transform:scale(.95)}
.sp-tl-check{width:32px;height:32px;border-radius:50%;border:2px solid var(--surface-600);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;flex-shrink:0;color:var(--surface-500)}
.sp-tl-check:hover{border-color:var(--green);background:rgba(34,197,94,.1)}
.sp-tl-check.checked{border-color:var(--green);background:var(--green);color:#fff}
.sp-tl-card-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.sp-tl-card-info{flex:1;min-width:0}
.sp-tl-card-name{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-tl-card-name.done{text-decoration:line-through;opacity:.6}
.sp-tl-card-dose{font-size:12px;color:var(--surface-400);margin-top:2px}
.sp-tl-card-tip{font-size:11px;color:var(--surface-500);margin-top:3px;line-height:1.3}
.sp-tl-card-menu{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--surface-500);font-size:18px;border-radius:6px;flex-shrink:0}
.sp-tl-card-menu:hover{background:var(--surface-700);color:#fff}
.sp-tl-add{text-align:center;padding:6px;margin-top:6px;color:var(--primary-light);font-size:11px;font-weight:500;cursor:pointer;opacity:.5;transition:opacity .2s}
.sp-tl-add:hover{opacity:1}
/* Empty State */
.sp-empty-state{text-align:center;padding:40px 20px}
.sp-empty-icon{font-size:56px;margin-bottom:16px;opacity:.6}
.sp-empty-title{font-size:18px;font-weight:700;color:#fff;margin-bottom:8px}
.sp-empty-text{font-size:13px;color:var(--surface-400);line-height:1.6;max-width:300px;margin:0 auto 20px}
.sp-empty-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.sp-empty-tip{font-size:12px;color:var(--surface-500);font-style:italic}

/* Supplement Card in Slot */
.sp-card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:12px;cursor:grab;transition:all .2s;user-select:none;-webkit-user-select:none;position:relative}
.sp-card:hover{border-color:var(--surface-600);background:rgba(30,41,59,.8)}
.sp-card.taken{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.06)}
.sp-card.skipped{opacity:.5;border-style:dashed}
.sp-card.dragging{opacity:.4;transform:scale(.95)}
.sp-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sp-card-info{flex:1;min-width:0}
.sp-card-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-card-dose{font-size:11px;color:var(--surface-400)}
.sp-card-check{width:28px;height:28px;border-radius:8px;border:2px solid var(--surface-600);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s;flex-shrink:0;color:transparent}
.sp-card-check:hover{border-color:var(--green);background:rgba(34,197,94,.1)}
.sp-card.taken .sp-card-check{border-color:var(--green);background:var(--green);color:#fff}
.sp-card-menu{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--surface-500);font-size:16px;border-radius:6px;flex-shrink:0}
.sp-card-menu:hover{background:var(--surface-700);color:#fff}

/* Context Menu */
.sp-context{position:fixed;z-index:1000;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:6px;box-shadow:0 8px 32px rgba(0,0,0,.4);min-width:180px}
.sp-context-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--surface-300);transition:background .1s}
.sp-context-item:hover{background:var(--surface-700);color:#fff}
.sp-context-item.danger{color:var(--red)}
.sp-context-item.danger:hover{background:rgba(239,68,68,.1)}
.sp-context-sep{height:1px;background:var(--surface-700);margin:4px 0}

/* Daily Summary */
.sp-summary{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:16px;padding:16px;margin-top:12px}
.sp-summary-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.sp-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.sp-summary-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(30,41,59,.5);border-radius:8px}
.sp-summary-item-icon{font-size:16px;flex-shrink:0}
.sp-summary-item-name{font-size:12px;color:var(--surface-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-summary-item-dose{font-size:12px;font-weight:600;color:#fff;margin-left:auto;white-space:nowrap}
.sp-compliance{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;margin-top:12px}
.sp-compliance-bar{flex:1;height:8px;background:var(--surface-700);border-radius:4px;overflow:hidden}
.sp-compliance-fill{height:100%;border-radius:4px;transition:width .5s ease}
.sp-compliance-text{font-size:13px;font-weight:600;white-space:nowrap;min-width:45px;text-align:right}

/* AI Advisor Box */
.sp-ai{background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.06));border:1px solid rgba(99,102,241,.2);border-radius:16px;padding:16px;margin-top:12px}
.sp-ai-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;cursor:pointer}
.sp-ai-title{font-size:14px;font-weight:600;color:var(--primary-light)}
.sp-ai-toggle{margin-left:auto;font-size:12px;color:var(--surface-400);transition:transform .2s}
.sp-ai-body{overflow:hidden;transition:max-height .3s ease}
.sp-ai-loading{text-align:center;padding:16px;color:var(--surface-400);font-size:13px}
.sp-ai-item{display:flex;gap:10px;padding:10px;border-radius:10px;margin-bottom:6px;font-size:12px;line-height:1.6}
.sp-ai-item.warning{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.15)}
.sp-ai-item.positive{background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.12)}
.sp-ai-item.suggestion{background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12)}
.sp-ai-item-icon{font-size:16px;flex-shrink:0;padding-top:1px}
.sp-ai-item-text{flex:1;color:var(--surface-300)}
.sp-ai-item-title{font-weight:600;color:#fff;margin-bottom:2px}
.sp-ai-item-action{margin-top:6px}
.sp-ai-item-action button{padding:4px 10px;border-radius:6px;border:1px solid var(--primary);background:rgba(99,102,241,.1);color:var(--primary-light);font-size:11px;cursor:pointer}

/* Week View */
.sp-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
@media(max-width:600px){.sp-week-grid{grid-template-columns:repeat(7,1fr);gap:3px}}
.sp-week-day{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;padding:10px 6px;text-align:center;cursor:pointer;transition:all .2s;min-height:100px}
.sp-week-day:hover{border-color:var(--surface-600)}
.sp-week-day.today{border-color:var(--primary);box-shadow:0 0 0 1px rgba(99,102,241,.3)}
.sp-week-day-label{font-size:11px;color:var(--surface-500);font-weight:600;margin-bottom:4px}
.sp-week-day-num{font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.sp-week-day-slots{display:flex;flex-direction:column;gap:4px}
.sp-week-slot{display:flex;align-items:center;justify-content:center;gap:3px;font-size:10px;padding:3px 4px;border-radius:4px;background:rgba(30,41,59,.5)}
.sp-week-slot-icon{font-size:11px}
.sp-week-slot .done{color:var(--green);font-weight:700}
.sp-week-slot .total{color:var(--surface-500)}
.sp-week-dot{width:8px;height:8px;border-radius:50%;margin:2px auto}
.sp-week-compliance{font-size:10px;font-weight:600;margin-top:4px}

/* Month View */
.sp-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.sp-month-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.sp-month-header span{text-align:center;font-size:11px;font-weight:600;color:var(--surface-500);padding:4px}
.sp-month-cell{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:8px;padding:3px 2px;text-align:center;cursor:pointer;transition:all .15s;min-height:64px;display:flex;flex-direction:column;align-items:center}
.sp-month-cell:hover{border-color:var(--surface-500);background:rgba(30,41,59,.8)}
.sp-month-cell.today{border-color:var(--primary);box-shadow:0 0 0 1px rgba(99,102,241,.15)}
.sp-month-cell.empty{background:transparent;border-color:transparent;cursor:default;min-height:0}
.sp-month-cell-day{font-size:10px;font-weight:700;color:#fff;margin-bottom:1px;line-height:1.2}
/* Combined cell: pills + ring */
.sp-mc-pills{display:flex;gap:2px;justify-content:center;margin-top:1px}
.sp-mc-pill{width:12px;height:5px;border-radius:3px;transition:opacity .2s}
.sp-mc-pill.taken{box-shadow:0 0 3px rgba(34,197,94,.3)}
.sp-mc-ring{margin-top:1px;flex-shrink:0}
.sp-mc-future{font-size:7px;color:var(--surface-600);margin-top:2px;font-weight:500}
.sp-mc-pill-legend{display:inline-block;width:14px;height:5px;border-radius:3px}
/* Month stats row */
.sp-month-stats-row{display:flex;gap:8px;margin-top:8px;padding:10px;background:rgba(30,41,59,.5);border-radius:10px}
.sp-month-stat{flex:1;text-align:center}
.sp-month-stat-val{font-size:18px;font-weight:700;line-height:1.2}
.sp-month-stat-label{font-size:10px;color:var(--surface-400);margin-top:2px}
@media(max-width:480px){.sp-month-cell{min-height:52px;padding:2px 1px}.sp-month-cell-day{font-size:9px}.sp-mc-pill{width:8px;height:4px}.sp-mc-ring{width:18px;height:18px}.sp-mc-ring text{font-size:6px!important}.sp-month-stats-row{gap:4px;padding:8px}}
/* Month Legend */
.sp-month-legend{display:flex;flex-wrap:wrap;gap:10px;padding:10px 0;font-size:11px;color:var(--surface-400)}
.sp-month-legend-item{display:flex;align-items:center;gap:4px}
.sp-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.sp-month-stats{font-size:12px;color:var(--surface-400);padding-top:4px}

/* Planner Add/Edit Modal: Timeslot Dosing */
.sp-timeslot-row{border:1px solid var(--surface-700);border-radius:12px;padding:12px;margin-bottom:8px;transition:all .2s;background:rgba(30,41,59,.3)}
.sp-timeslot-row.active{border-color:rgba(99,102,241,.3);background:rgba(99,102,241,.04)}
.sp-timeslot-header{display:flex;align-items:center;gap:10px;cursor:pointer}
.sp-timeslot-toggle{width:22px;height:22px;border-radius:6px;border:2px solid var(--surface-600);display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;color:transparent;flex-shrink:0}
.sp-timeslot-row.active .sp-timeslot-toggle{border-color:var(--primary);background:var(--primary);color:#fff}
.sp-timeslot-icon{font-size:18px}
.sp-timeslot-label{font-size:13px;font-weight:600;color:var(--surface-300)}
.sp-timeslot-row.active .sp-timeslot-label{color:#fff}
.sp-timeslot-fields{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--surface-700)}
.sp-timeslot-row.active .sp-timeslot-fields{display:flex;gap:8px;align-items:center}
.sp-timeslot-fields input{flex:1;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:8px;color:#fff;padding:8px 10px;font-size:13px}
.sp-timeslot-fields select{width:70px;background:var(--surface-700);border:1px solid var(--surface-600);border-radius:8px;color:#fff;padding:8px 6px;font-size:12px}
.sp-timeslot-use-default{font-size:11px;color:var(--primary-light);cursor:pointer;margin-left:auto;white-space:nowrap}
.sp-timeslot-use-default:hover{text-decoration:underline}
.sp-default-dose{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.15);border-radius:10px;margin-bottom:12px}
.sp-default-dose label{font-size:12px;color:var(--surface-400);white-space:nowrap}
.sp-default-dose input{flex:1;max-width:100px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:8px;color:#fff;padding:8px 10px;font-size:13px;text-align:center}
.sp-default-dose select{width:70px;background:var(--surface-700);border:1px solid var(--surface-600);border-radius:8px;color:#fff;padding:8px 6px;font-size:12px}
.sp-default-dose .hint{font-size:10px;color:var(--surface-500)}
@media(max-width:480px){.sp-default-dose{flex-wrap:wrap}.sp-default-dose .hint{width:100%}}

/* Drag ghost */
.sp-drag-ghost{position:fixed;z-index:9999;pointer-events:none;opacity:.85;transform:rotate(2deg);box-shadow:0 8px 24px rgba(0,0,0,.4)}

/* Supplement main tabs (Planner / My Supplements / Catalog) */
.sp-main-tabs{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.sp-main-tabs::-webkit-scrollbar{display:none}
.sp-main-tab{padding:8px 14px;background:var(--surface-800);border:1px solid var(--surface-700);border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;color:var(--surface-400);transition:all .15s;white-space:nowrap;flex-shrink:0}
.sp-main-tab:hover{background:var(--surface-700);color:#fff}
.sp-main-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}


/* Week View Full Planner */
.sp-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
@media(max-width:900px){.sp-week-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.sp-week-grid{grid-template-columns:repeat(2,1fr)}}
.sp-week-day-full{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:12px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column;cursor:pointer}
.sp-week-day-full:hover{border-color:var(--surface-500);background:rgba(30,41,59,.8)}
.sp-week-day-full.today{border-color:var(--primary);box-shadow:0 0 0 1px rgba(99,102,241,.2)}
.sp-week-day-full.future{opacity:.6}
.sp-week-day-header{display:flex;align-items:center;gap:6px;padding:10px 12px;background:rgba(30,41,59,.5);border-bottom:1px solid var(--surface-700);flex-shrink:0}
.sp-week-day-body{flex:1;min-height:160px;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--surface-600) transparent}
.sp-week-day-body::-webkit-scrollbar{width:4px}
.sp-week-day-body::-webkit-scrollbar-thumb{background:var(--surface-600);border-radius:2px}
.sp-week-day-body::-webkit-scrollbar-track{background:transparent}
.sp-week-day-name{font-size:12px;font-weight:700;color:#fff}
.sp-week-day-date{font-size:11px;color:var(--surface-400);flex:1}
.sp-week-day-pct{font-size:11px;font-weight:700}
.sp-week-slot-full{padding:8px 10px;border-bottom:1px solid rgba(51,65,85,.4)}
.sp-week-slot-full:last-child{border-bottom:none}
.sp-week-slot-label{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--surface-400);margin-bottom:4px;font-weight:600}
.sp-week-slot-count{font-size:11px;color:var(--surface-500)}
.sp-week-slot-count.done{color:var(--green);font-weight:700}
.sp-week-item{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:6px;font-size:12px;color:var(--surface-300);line-height:1.3}
.sp-week-item.taken{color:var(--green);text-decoration:line-through;opacity:.7}
.sp-week-item-icon{font-size:14px;flex-shrink:0}
.sp-week-item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* Schedule Selectors */
.sched-section{margin-top:2px}
.sched-label{font-size:11px;color:var(--surface-400);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.sched-label span.sched-hint{font-size:10px;color:var(--surface-500);font-weight:400}
.sched-row{display:flex;gap:4px;flex-wrap:wrap}
.sched-chip{display:flex;align-items:center;justify-content:center;min-width:36px;height:32px;padding:0 8px;border-radius:8px;border:1px solid var(--surface-700);background:rgba(30,41,59,.4);color:var(--surface-400);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;user-select:none}
.sched-chip:hover{border-color:var(--surface-500);color:var(--surface-300)}
.sched-chip.selected{background:rgba(99,102,241,.15);border-color:var(--primary);color:var(--primary-light)}
.sched-all{font-size:10px;color:var(--primary-light);cursor:pointer;margin-left:auto}
.sched-all:hover{text-decoration:underline}
.sched-summary{font-size:11px;color:var(--surface-400);margin-top:6px;padding:6px 10px;background:rgba(99,102,241,.06);border-radius:8px;border-left:2px solid var(--primary)}
.sched-summary:empty{display:none}
.freq-select{width:100%;padding:8px 12px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:12px;color:var(--surface-300);font-size:13px;font-family:Inter,sans-serif;cursor:pointer;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 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%2394a3b8' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.freq-select:focus{border-color:var(--primary);outline:none}
.freq-detail{margin-top:8px;display:none}
.freq-detail.visible{display:block}
.freq-interval-row{display:flex;align-items:center;gap:8px}
.freq-interval-input{width:60px;padding:8px;background:rgba(30,41,59,.6);border:1px solid var(--surface-700);border-radius:10px;color:var(--surface-300);font-size:14px;font-weight:600;text-align:center;font-family:Inter,sans-serif}
.freq-interval-input:focus{border-color:var(--primary);outline:none}
.freq-interval-label{color:var(--surface-400);font-size:13px}
.freq-interval-hint{font-size:10px;color:var(--surface-500);margin-top:4px}


/* ═══ SUPPLEMENT RADAR ═══ */
.btn-radar{background:rgba(99,102,241,.15)!important;color:var(--primary-light)!important;border:1px solid rgba(99,102,241,.25)!important}
.btn-radar:hover{background:rgba(99,102,241,.25)!important}
#radar-panel{background:var(--surface-800);border:1px solid var(--surface-600);border-radius:20px;padding:0;margin-bottom:16px;overflow:hidden;animation:radarSlideIn .3s ease}
@keyframes radarSlideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.radar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:rgba(99,102,241,.06);border-bottom:1px solid var(--surface-700)}
.radar-header-title{font-size:15px;font-weight:700;color:#fff}
.radar-close{background:none;border:none;color:var(--surface-400);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:8px}
.radar-close:hover{background:rgba(255,255,255,.05);color:#fff}
#radar-content{padding:16px}
.radar-score{display:flex;align-items:center;gap:14px;padding:12px 16px;background:rgba(30,41,59,.5);border-radius:14px;margin-bottom:16px;border:1px solid var(--surface-700)}
.radar-score-ring{flex-shrink:0}
.radar-score-title{font-size:14px;font-weight:700;color:#fff}
.radar-score-sub{font-size:11px;color:var(--surface-400);margin-top:2px}
.radar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.radar-cell{display:flex;flex-direction:column;align-items:center;gap:4px}
.radar-icon-wrap{position:relative;width:64px;height:64px;border-radius:16px;overflow:hidden;background:rgba(30,41,59,.6);border:2px solid #334155;transition:all .4s}
.radar-fill{position:absolute;bottom:0;left:0;right:0;transition:height .6s cubic-bezier(.34,1.56,.64,1);border-radius:0 0 14px 14px}
.radar-emoji{position:relative;z-index:1;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;transition:all .4s}
.radar-emoji.inactive{filter:grayscale(1) opacity(.25)}
.radar-badge{position:absolute;top:3px;right:3px;color:#fff;font-size:9px;font-weight:800;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2}
.radar-pct{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);opacity:.8;z-index:2}
.radar-label{font-size:9px;font-weight:600;text-align:center;line-height:1.2;transition:color .3s}
.radar-detail-title{font-size:12px;font-weight:700;color:var(--surface-400);margin-bottom:8px}
.radar-mapping{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.radar-map-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(30,41,59,.4);border:1px solid var(--surface-700);border-radius:10px;font-size:12px}
.radar-map-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.radar-map-name{font-weight:600;color:#fff;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.radar-map-cats{display:flex;gap:4px;flex-shrink:0}
.radar-map-cat{font-size:11px;padding:2px 4px;border-radius:6px}
.radar-tip{display:flex;align-items:flex-start;gap:6px;padding:10px 12px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12);border-radius:10px;font-size:11px;color:var(--surface-400);line-height:1.5}
@media(max-width:480px){.radar-grid{grid-template-columns:repeat(3,1fr);gap:8px}.radar-icon-wrap{width:56px;height:56px;border-radius:14px}.radar-emoji{font-size:24px}.radar-label{font-size:8px}.radar-map-item{padding:5px 8px;font-size:11px}}

/* ═══ SUPPLEMENT INTERACTIONS / DEPENDENCIES ═══ */
.btn-deps{background:rgba(34,197,94,.12)!important;color:#4ade80!important;border:1px solid rgba(34,197,94,.2)!important}
.btn-deps:hover{background:rgba(34,197,94,.2)!important}
.si-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.si-header-left{flex:1;min-width:200px}
.si-title{font-size:20px;font-weight:700;margin:0}
.si-subtitle{font-size:11px;color:var(--surface-500);margin-top:2px}
.si-header-actions{display:flex;gap:6px;flex-wrap:wrap}
.si-stats{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;padding-bottom:4px}
.si-stat{flex:1;text-align:center;padding:8px 6px;background:rgba(30,41,59,.5);border-radius:10px;border:1px solid var(--surface-700);min-width:60px}
.si-stat-val{font-size:18px;font-weight:800}
.si-stat-lbl{font-size:9px;color:var(--surface-500);margin-top:1px}
.si-layout{display:flex;gap:0;border:1px solid var(--surface-700);border-radius:16px;overflow:hidden;background:var(--surface-800);height:calc(100vh - 220px);min-height:400px;max-height:800px}
.si-list-panel{width:280px;flex-shrink:0;border-right:1px solid var(--surface-700);display:flex;flex-direction:column;min-height:0}
.si-search-wrap{padding:8px 10px;border-bottom:1px solid var(--surface-700)}
.si-search{font-size:12px!important;padding:7px 10px!important}
.si-list{overflow-y:auto;flex:1;min-height:0}
.si-list-empty{padding:20px;text-align:center;color:var(--surface-500);font-size:12px}
.si-list-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;border-bottom:1px solid #0f172a;border-left:3px solid transparent;transition:all .15s}
.si-list-item:hover{background:rgba(30,41,59,.4)}
.si-list-item.active{background:rgba(99,102,241,.1);border-left-color:var(--primary)}
.si-li-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.si-li-info{flex:1;min-width:0}
.si-li-name{font-size:11px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.si-li-cat{font-size:9px;color:var(--surface-500)}
.si-li-badges{display:flex;gap:3px;flex-shrink:0}
.si-badge-pos{font-size:9px;font-weight:700;color:#22c55e;background:rgba(34,197,94,.1);padding:1px 5px;border-radius:4px}
.si-badge-neg{font-size:9px;font-weight:700;color:#ef4444;background:rgba(239,68,68,.1);padding:1px 5px;border-radius:4px}
.si-detail-panel{flex:1;overflow-y:auto;padding:14px 16px;min-height:0}
.si-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:300px;color:var(--surface-500)}
.si-detail-empty-icon{font-size:40px;margin-bottom:8px}
.si-detail-empty-title{font-size:14px;font-weight:700}
.si-detail-empty-text{font-size:12px;margin-top:4px;text-align:center;max-width:240px}
.si-det-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.si-det-icon{font-size:28px}
.si-det-name{font-size:16px;font-weight:700;color:#fff}
.si-det-meta{font-size:11px;color:var(--surface-500)}
.si-add-btn{width:100%;padding:9px;background:rgba(99,102,241,.06);border:1px dashed rgba(99,102,241,.25);border-radius:10px;color:#818cf8;font-size:12px;font-weight:600;cursor:pointer;margin-bottom:14px;transition:all .2s}
.si-add-btn:hover{background:rgba(99,102,241,.12)}
.si-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #1e293b;margin-bottom:8px;font-size:13px;font-weight:700}
.si-section-pos{color:#22c55e;border-color:rgba(34,197,94,.2)}
.si-section-neg{color:#ef4444;border-color:rgba(239,68,68,.2)}
.si-section-count{font-size:11px;font-weight:600;padding:1px 8px;border-radius:8px;background:rgba(255,255,255,.05)}
.si-empty-section{padding:16px;text-align:center;color:#334155;font-size:12px;font-style:italic}
.si-card{background:rgba(30,41,59,.35);border-radius:12px;margin-bottom:8px;overflow:hidden;border-left:3px solid var(--primary)}
.si-card-top{display:flex;justify-content:space-between;align-items:center;padding:7px 12px;background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.03)}
.si-card-pair{display:flex;align-items:center;gap:6px;cursor:pointer}
.si-card-pair:hover .si-card-oname{text-decoration:underline}
.si-card-oicon{font-size:14px}
.si-card-oname{font-size:12px;font-weight:700;color:#fff}
.si-card-nav{font-size:9px;color:var(--surface-500)}
.si-card-badges{display:flex;align-items:center;gap:5px}
.si-card-sev{font-size:9px;padding:2px 6px;border-radius:5px;font-weight:600}
.si-card-type{display:inline-block;font-size:10px;padding:3px 8px;border-radius:6px;font-weight:600;margin:8px 12px 4px}
.si-card-desc{font-size:12px;color:#cbd5e1;line-height:1.6;padding:0 12px 4px}
.si-card-rec{font-size:11px;color:#4ade80;background:rgba(34,197,94,.05);padding:7px 10px;border-radius:8px;line-height:1.5;margin:4px 12px 8px}
.si-card-footer{display:flex;justify-content:space-between;align-items:center;padding:4px 12px 8px}
.si-card-source{font-size:9px;color:#334155}
.si-card-actions{display:flex;gap:4px}
.si-tiny-btn{padding:2px 6px;border-radius:5px;font-size:9px;font-weight:600;cursor:pointer;border:none;transition:opacity .2s}
.si-btn-verify{background:rgba(34,197,94,.12);color:#4ade80}
.si-btn-del{background:rgba(239,68,68,.1);color:#f87171}
/* Form */
.si-form{background:rgba(99,102,241,.03);border:1px solid rgba(99,102,241,.12);border-radius:12px;padding:14px;margin-bottom:14px}
.si-form-title{font-size:13px;font-weight:700;color:#a5b4fc;margin-bottom:10px}
.si-form-group{margin-bottom:10px}
.si-form-label{display:block;font-size:10px;font-weight:600;color:#64748b;margin-bottom:3px}
.si-form-sublabel{font-size:9px;font-weight:700;margin-bottom:3px}
.si-form-row{display:flex;gap:8px;margin-bottom:10px}
.si-form-half{flex:1}
.si-type-row{display:flex;gap:3px;flex-wrap:wrap}
.si-type-btn,.si-sev-btn{padding:5px 8px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;border:1px solid #334155;background:rgba(30,41,59,.4);color:#64748b;transition:all .15s}
.si-sev-row{display:flex;gap:3px}
.si-sev-btn{flex:1;text-align:center}
.si-target-pill{display:flex;align-items:center;gap:6px;padding:7px 10px;background:rgba(30,41,59,.6);border-radius:8px;border:1px solid #334155;font-size:12px}
.si-dropdown{position:absolute;top:100%;left:0;right:0;background:#1e293b;border:1px solid #334155;border-radius:8px;max-height:180px;overflow-y:auto;z-index:20;box-shadow:0 8px 20px rgba(0,0,0,.4)}
.si-dd-item{display:flex;align-items:center;gap:6px;padding:7px 10px;cursor:pointer;border-bottom:1px solid #0f172a;font-size:11px}
.si-dd-item:hover{background:rgba(99,102,241,.1)}
.si-dd-empty{padding:10px;color:#475569;font-size:11px;text-align:center}
.si-form-group{position:relative}
.si-target-search{font-size:12px!important}
.si-bidi-notice{padding:7px 10px;background:rgba(99,102,241,.05);border-radius:8px;font-size:10px;color:#818cf8;line-height:1.5;margin-bottom:10px}
.si-form-actions{display:flex;gap:6px;justify-content:flex-end}
/* Inline in supplement details */
.si-inline-section{margin-top:12px;padding-top:10px;border-top:1px solid var(--surface-700)}
.si-inline-title{font-size:13px;font-weight:700;color:#818cf8;margin-bottom:8px}
.si-inline-item{padding:8px 10px;border-radius:8px;margin-bottom:6px;font-size:12px;line-height:1.5}
.si-inline-pos{background:rgba(34,197,94,.04);border:1px solid rgba(34,197,94,.12)}
.si-inline-neg{background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.12)}
.si-inline-pair{font-size:12px;color:#fff;margin-bottom:2px}
.si-inline-type{font-size:10px;font-weight:600;margin-bottom:4px}
.si-inline-desc{font-size:11px;color:var(--surface-400);line-height:1.5}
.si-inline-rec{font-size:11px;color:#4ade80;margin-top:4px}
/* Mobile */
@media(max-width:640px){.si-layout{flex-direction:column;height:calc(100vh - 200px);max-height:none}.si-list-panel{width:100%;max-height:200px;flex-shrink:0;border-right:none;border-bottom:1px solid var(--surface-700)}.si-type-row{gap:2px}.si-type-btn,.si-sev-btn{padding:4px 6px;font-size:9px}.si-form-row{flex-direction:column;gap:6px}}
/* Bug 6: Fixed tour close button - always visible */
.tour-close-fixed{position:fixed;top:16px;right:16px;z-index:9010;background:rgba(30,41,59,.85);border:1px solid var(--surface-600);color:#fff;font-size:13px;font-weight:600;padding:6px 14px;border-radius:10px;cursor:pointer;display:none;backdrop-filter:blur(6px)}
.tour-close-fixed:hover{background:var(--surface-600)}
.tour-overlay.active .tour-close-fixed{display:block}

/* ═══ MOBILE MENU – Smart Avatar-Pill Bottom Sheet ═══ */
.mobile-sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}
.mobile-sheet-overlay.open{opacity:1;pointer-events:all}
.mobile-sheet{position:fixed;bottom:0;left:0;right:0;z-index:201;background:var(--surface-800);border-top-left-radius:20px;border-top-right-radius:20px;border:1px solid var(--surface-700);border-bottom:none;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);max-height:85vh;overflow-y:auto;padding-bottom:max(16px,env(safe-area-inset-bottom))}
.mobile-sheet.open{transform:translateY(0)}
.ms-handle{display:flex;justify-content:space-between;align-items:center;padding:10px 18px 6px}
.ms-handle-bar{width:36px;height:4px;border-radius:2px;background:var(--surface-600)}
.ms-close-x{background:none;border:none;color:var(--surface-400);font-size:22px;cursor:pointer;padding:4px 8px;border-radius:8px;line-height:1}
.ms-close-x:active{background:rgba(255,255,255,.05)}
.ms-body{padding:0 18px 12px}
/* User header */
.ms-user{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--surface-700);margin-bottom:12px}
.ms-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#3b82f6);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}
.ms-user-info{flex:1;min-width:0}
.ms-user-name{font-size:15px;font-weight:700;color:#fff}
.ms-user-email{font-size:11px;color:var(--surface-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ms-role-badge{font-size:9px;font-weight:700;color:#fff;padding:3px 8px;border-radius:6px;flex-shrink:0}
/* Streak bar */
.ms-streak-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.12);border-radius:12px;margin-bottom:14px}
.ms-streak-flame{font-size:20px}
.ms-streak-val{font-size:22px;font-weight:800;color:#fbbf24}
.ms-streak-label{font-size:12px;color:var(--surface-400)}
/* Section labels */
.ms-section-label{font-size:10px;font-weight:700;color:var(--surface-500);text-transform:uppercase;letter-spacing:.5px;padding:6px 0 4px}
/* Language */
.ms-lang-row{display:flex;gap:6px;margin-bottom:14px}
.ms-lang-btn{flex:1;padding:10px;border-radius:10px;border:1px solid var(--surface-700);background:rgba(30,41,59,.4);color:var(--surface-400);font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s}
.ms-lang-btn.active{background:rgba(99,102,241,.12);border-color:var(--primary);color:#fff}
/* Profiles */
.ms-profiles{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.ms-profile{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;border:none;background:rgba(30,41,59,.3);color:#cbd5e1;font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:all .15s}
.ms-profile.active{background:rgba(99,102,241,.1);color:#fff}
.ms-profile-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.ms-profile-check{margin-left:auto;color:var(--primary-light);font-size:14px;font-weight:700}
/* Actions */
.ms-actions{display:flex;flex-direction:column;gap:2px}
.ms-action{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;border:none;background:transparent;color:#cbd5e1;font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:all .15s;width:100%}
.ms-action:active{background:rgba(99,102,241,.1)}
.ms-action-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}
.ms-action-text{flex:1}
.ms-action-danger{color:#f87171}
.ms-action-danger:active{background:rgba(239,68,68,.1)}

/* ═══ MOBILE HEADER CLEANUP ═══ */
@media(max-width:520px){
    /* Hide utilities from header — they live in the bottom sheet now */
    .header-right .lang-switch,
    .header-right .profile-switcher,
    .header-right .admin-link,
    .header-right .header-streak{display:none!important}
    /* Avatar gets a hamburger indicator */
    .header-avatar{position:relative;box-shadow:0 0 0 2px rgba(99,102,241,.4)}
    .header-avatar::after{content:'≡';position:absolute;bottom:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--primary);border:2px solid var(--surface-900);font-size:9px;line-height:12px;text-align:center;color:#fff;font-weight:700}
    /* Permanent pulse animation on mobile avatar */
    .header-avatar::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--primary);animation:avatarPulse 2s ease-in-out infinite}

    /* ─── Supplements: Unified Mobile Layout ─── */
    /* Hide the two separate tab rows — replaced by unified bar */
    .sp-main-tabs{display:none!important}
    #supps-planner > div:first-child{display:none!important}
    /* Masterdata button */
    #btn-supp-masterdata{display:none!important}
    
    /* Unified tab bar */
    .sp-unified-tabs{display:flex!important;gap:3px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0;margin-bottom:4px}
    .sp-unified-tabs::-webkit-scrollbar{display:none}
    
    /* Header compact */
    .sp-header{margin-bottom:4px;gap:3px}
    .sp-title{font-size:15px}
    .sp-title .help-icon{display:none}
    .my-supps-actions{gap:3px}
    .my-supps-actions .btn{padding:5px 8px!important;min-width:0;border-radius:8px;font-size:14px}
    .my-supps-actions .btn span{display:none}
    
    /* Date nav: compact */
    .sp-date-nav{margin-bottom:6px;gap:3px}
    .sp-date-btn{width:26px;height:26px;font-size:12px;border-radius:7px}
    .sp-date-label{font-size:12px}
    .sp-date-today{padding:3px 7px;font-size:10px}
    
    /* Progress bar: tighter */
    .sp-day-progress{margin-bottom:8px}
    .sp-day-progress-text{font-size:11px;margin-bottom:3px}
    .sp-day-progress-bar{height:6px}
}
/* Desktop: hide bottom sheet entirely */
@media(min-width:521px){
    .mobile-sheet-overlay,.mobile-sheet{display:none!important}
}
@keyframes avatarPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}
