.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:50}.sidebar-header{padding:var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border);-webkit-app-region:drag}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{color:var(--color-accent);filter:drop-shadow(0 0 8px var(--color-accent))}.logo-text{font-size:1.25rem;font-weight:700;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-badge{font-size:.625rem;font-weight:700;padding:2px 6px;background:var(--gradient-accent);color:#fff;border-radius:var(--radius-sm);letter-spacing:.1em}.sidebar-profile{padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary)}.profile-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;box-shadow:var(--shadow-glow)}.profile-info{display:flex;flex-direction:column}.profile-name{font-weight:600;font-size:1rem}.profile-weight{font-size:.875rem;color:var(--color-text-muted);font-family:var(--font-mono)}.sidebar-nav{flex:1;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-accent-light);color:var(--color-accent)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.status-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-text-muted);margin-left:auto}.status-dot.connected{background:var(--color-success);box-shadow:0 0 8px var(--color-success);animation:pulse 2s infinite}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.bt-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:var(--color-bg-tertiary);font-size:.75rem;color:var(--color-text-muted)}.bt-status.connected{color:var(--color-success);background:#22c55e1a}.bt-status.connected svg{filter:drop-shadow(0 0 4px var(--color-success))}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .3s ease;width:280px;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-header{-webkit-app-region:no-drag}.sidebar-profile{padding:var(--spacing-md)}.profile-avatar{width:40px;height:40px;font-size:1rem}.profile-name{font-size:.875rem}.nav-item{padding:var(--spacing-md)}.nav-item span{font-size:.9rem}}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}@media (max-width: 1400px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 800px){.dashboard-stats{grid-template-columns:1fr}}.dashboard-stats .stat-card{display:flex;gap:var(--spacing-md);align-items:flex-start;animation:slideUp var(--transition-slow) ease-out backwards}.dashboard-stats .stat-card:nth-child(1){animation-delay:0ms}.dashboard-stats .stat-card:nth-child(2){animation-delay:50ms}.dashboard-stats .stat-card:nth-child(3){animation-delay:.1s}.dashboard-stats .stat-card:nth-child(4){animation-delay:.15s}.stat-card.featured{background:linear-gradient(145deg,var(--color-bg-card),rgba(20,184,166,.1));border-color:#14b8a64d}.stat-card.alert{background:linear-gradient(145deg,var(--color-bg-card),rgba(245,158,11,.1));border-color:#f59e0b4d}.stat-icon{width:40px;height:40px;padding:var(--spacing-sm);background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-md);flex-shrink:0}.stat-card.alert .stat-icon{background:#f59e0b26;color:var(--color-warning)}.stat-content{flex:1;display:flex;flex-direction:column;gap:2px}.stat-value-text{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.stat-sub{font-size:.75rem;color:var(--color-text-muted)}.stat-badge{font-size:.75rem;font-weight:600}.stat-alert{font-size:.75rem;color:var(--color-warning);font-weight:600}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media (max-width: 1200px){.quick-actions{grid-template-columns:1fr}}.action-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:left;transition:all var(--transition-normal)}.action-card:hover{border-color:var(--color-accent);background:var(--color-accent-light);transform:translate(4px)}.action-card.connected{border-color:var(--color-success)}.action-card.connected:hover{background:#22c55e1a}.action-card.alert{border-color:var(--color-warning);animation:pulse 2s infinite}.action-card svg:first-child{color:var(--color-accent);flex-shrink:0}.action-card.connected svg:first-child{color:var(--color-success)}.action-card.alert svg:first-child{color:var(--color-warning)}.action-content{flex:1;display:flex;flex-direction:column;gap:2px}.action-title{font-weight:600;color:var(--color-text-primary)}.action-desc{font-size:.875rem;color:var(--color-text-muted)}.action-card svg:last-child{color:var(--color-text-muted);transition:transform var(--transition-fast)}.action-card:hover svg:last-child{transform:translate(4px);color:var(--color-accent)}.indices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media (max-width: 1000px){.indices-grid{grid-template-columns:1fr}}.index-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);position:relative}.index-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);gap:var(--spacing-sm);flex-wrap:wrap}.index-name{font-size:.75rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.05em}.index-pill{font-size:.65rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-sm);white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.index-pill.floating{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:inline-block;text-align:left;max-width:120px}.index-value{font-size:1.75rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text-primary);margin-bottom:4px}.index-desc{font-size:.75rem;color:var(--color-text-muted)}.index-card.deprecated{opacity:.7;border-style:dashed}.index-card.deprecated .index-value{background:linear-gradient(135deg,var(--color-warning),#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.recent-measurements{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.measurement-row{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);animation:slideUp var(--transition-slow) ease-out backwards}.measurement-row:last-child{border-bottom:none}.measurement-row:hover{background:var(--color-bg-hover)}.measurement-date{width:120px;font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize}.measurement-values{flex:1;display:flex;gap:var(--spacing-lg);align-items:center}.measurement-weight{font-size:1.125rem;font-weight:600;font-family:var(--font-mono);color:var(--color-accent)}.measurement-detail{font-size:.875rem;color:var(--color-text-muted)}.measurement-source{width:24px;display:flex;justify-content:center}.measurement-source svg{color:var(--color-accent);opacity:.5}.profile-content{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-xl);max-width:1000px}@media (max-width: 900px){.profile-content{grid-template-columns:1fr}}.profile-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:center;height:fit-content;position:sticky;top:var(--spacing-xl)}.profile-avatar-large{width:120px;height:120px;margin:0 auto var(--spacing-lg);border-radius:var(--radius-full);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:#fff;box-shadow:var(--shadow-glow)}.profile-avatar-large svg{opacity:.5}.profile-summary{display:flex;justify-content:center;gap:var(--spacing-lg)}.profile-age,.profile-sex{font-size:.875rem;color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.form-section h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.form-hint{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.activity-levels{display:flex;flex-direction:column;gap:var(--spacing-sm)}.activity-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.activity-option:hover,.activity-option.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.activity-option input{display:none}.activity-option:before{content:"";width:20px;height:20px;border:2px solid var(--color-border);border-radius:var(--radius-full);flex-shrink:0;transition:all var(--transition-fast)}.activity-option.selected:before{border-color:var(--color-accent);background:var(--color-accent);box-shadow:inset 0 0 0 4px var(--color-bg-card)}.activity-content{display:flex;flex-direction:column}.activity-label{font-weight:500;color:var(--color-text-primary)}.activity-desc{font-size:.75rem;color:var(--color-text-muted)}.form-actions{display:flex;justify-content:flex-end}.form-actions .btn{min-width:200px}.measurements-actions{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-lg)}.date-cell{text-transform:capitalize;white-space:nowrap}.weight-cell{font-weight:600;font-family:var(--font-mono);color:var(--color-accent)}.empty-cell{color:var(--color-text-muted)}.source-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;padding:2px 8px;border-radius:var(--radius-full)}.source-badge.bt{background:var(--color-accent-light);color:var(--color-accent)}.source-badge.manual{background:var(--color-bg-hover);color:var(--color-text-muted)}.delete-btn{padding:var(--spacing-xs);color:var(--color-text-muted);border-radius:var(--radius-sm)}.delete-btn:hover{color:var(--color-danger);background:#ef44441a}.form-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--color-text-muted);font-size:.875rem}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}textarea{resize:vertical;min-height:60px}.indices-warning{text-align:center;padding:var(--spacing-2xl);background:var(--gradient-card);border:1px solid var(--color-warning);border-radius:var(--radius-xl);max-width:500px;margin:0 auto}.indices-warning svg{color:var(--color-warning);margin-bottom:var(--spacing-md)}.indices-warning h3{margin-bottom:var(--spacing-sm)}.indices-warning p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.indices-warning ul{list-style:none;text-align:left;display:inline-block}.indices-warning li{padding:var(--spacing-xs) 0;color:var(--color-text-muted)}.indices-loading{text-align:center;padding:var(--spacing-2xl)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--spacing-md)}.indices-main-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}@media (max-width: 1200px){.indices-main-grid{grid-template-columns:1fr}}.index-card-large{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.index-card-large:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md)}.index-card-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.index-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-md)}.index-names{display:flex;flex-direction:column}.index-abbr{font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.index-full{font-size:.75rem;color:var(--color-text-muted)}.index-card-body{padding:var(--spacing-xl);display:flex;align-items:center;justify-content:space-between}.index-value-large{font-size:3rem;font-weight:700;font-family:var(--font-mono);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.index-level{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-weight:600;font-size:.875rem;border:1px solid}.index-card-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.index-interpretation{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.index-details{display:flex;flex-direction:column;gap:var(--spacing-sm)}.index-detail{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:.75rem;color:var(--color-text-muted)}.index-detail svg{flex-shrink:0;margin-top:2px}.index-reference{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;padding-top:var(--spacing-sm);border-top:1px dashed var(--color-border)}.reference-label{color:var(--color-text-muted)}.reference-value{font-family:var(--font-mono);color:var(--color-accent)}.indices-info-section{margin-top:var(--spacing-2xl)}.indices-info-section h3{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.info-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.info-card h4{font-size:1rem;margin-bottom:var(--spacing-sm);color:var(--color-accent)}.info-card p{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7}.info-card.recommended{border-left:3px solid var(--color-success)}.info-card.recommended h4{color:var(--color-success)}.info-card.warning{border-left:3px solid var(--color-warning);background:#f59e0b0d}.info-card.warning h4{color:var(--color-warning)}.index-card-large.deprecated{opacity:.85;border-style:dashed}.index-card-large.deprecated .index-icon{background:#f59e0b26;color:var(--color-warning)}.deprecated-badge{display:flex;align-items:center;gap:4px;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;background:#f59e0b26;color:var(--color-warning);border-radius:var(--radius-full)}.deprecated-note{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-md);background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);font-size:.75rem;color:var(--color-warning)}.deprecated-note svg{flex-shrink:0;margin-top:2px}.indices-tips{margin-top:var(--spacing-2xl)}.indices-tips h3{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.tips-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media (max-width: 1000px){.tips-grid{grid-template-columns:1fr}}.tip-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.tip-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gradient-accent);color:#fff;border-radius:var(--radius-full);font-weight:700;flex-shrink:0}.tip-content strong{display:block;margin-bottom:4px;color:var(--color-text-primary)}.tip-content p{font-size:.875rem;color:var(--color-text-muted);line-height:1.5;margin:0}.charts-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}@media (max-width: 1000px){.charts-stats{grid-template-columns:repeat(2,1fr)}}.chart-stat{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-direction:column;gap:4px}.chart-stat .stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.chart-stat .stat-value{font-size:1.25rem;font-weight:600;font-family:var(--font-mono);display:flex;align-items:center;gap:var(--spacing-sm)}.chart-stat .stat-value.positive{color:var(--color-success)}.chart-stat .stat-value.negative{color:var(--color-danger)}.trend-icon{display:flex;align-items:center}.charts-controls{display:flex;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}@media (max-width: 800px){.charts-controls{flex-direction:column;gap:var(--spacing-md)}}.control-group{display:flex;align-items:center;gap:var(--spacing-md)}.control-group label{font-size:.875rem;color:var(--color-text-muted);white-space:nowrap}.btn-group{display:flex;gap:2px;background:var(--color-bg-primary);border-radius:var(--radius-md);padding:2px}.btn-group .btn{padding:var(--spacing-xs) var(--spacing-md);font-size:.75rem;border-radius:var(--radius-sm);color:var(--color-text-muted);background:transparent}.btn-group .btn:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.btn-group .btn.active{color:var(--color-accent);background:var(--color-accent-light)}.chart-container{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg);min-height:450px}.chart-subheader{margin-bottom:var(--spacing-md)}.chart-subheader h3{margin:0}.chart-subheader p{margin:4px 0 0;color:var(--color-text-muted);font-size:.9rem}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:var(--color-text-muted)}.chart-empty svg{margin-bottom:var(--spacing-md);opacity:.3}.chart-empty h3{color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.chart-tooltip{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-md)}.chart-tooltip .tooltip-date{font-size:.75rem;color:var(--color-text-muted);margin-bottom:4px;text-transform:capitalize}.chart-tooltip p{font-size:.875rem;margin:2px 0}.index-legend{margin-top:var(--spacing-md);display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.index-legend-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.85rem}.index-badge{width:12px;height:12px;border-radius:999px;display:inline-block}.index-legend-range{color:var(--color-text-muted);font-family:var(--font-mono)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--color-border)}.recharts-legend-item-text{color:var(--color-text-secondary)!important}.mounjaro-status{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media (max-width: 1200px){.mounjaro-status{grid-template-columns:1fr 1fr}.mounjaro-status .status-card.main{grid-column:span 2}}@media (max-width: 700px){.mounjaro-status{grid-template-columns:1fr}.mounjaro-status .status-card.main{grid-column:span 1}}.status-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.status-card.main{padding:var(--spacing-xl)}.status-card.clickable{cursor:pointer;transition:all var(--transition-fast)}.status-card.clickable:hover{border-color:var(--color-accent);background:var(--color-accent-light)}.status-card.alert{border-color:var(--color-warning);background:#f59e0b1a}.status-card.alert svg{color:var(--color-warning)}.status-card.overdue{border-color:var(--color-danger);background:#ef44441a}.status-card.overdue svg,.status-card.overdue .status-value{color:var(--color-danger)}.status-card.today{border-color:var(--color-success);background:#22c55e1a}.status-card.today svg{color:var(--color-success)}.status-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-lg);flex-shrink:0}.status-card.overdue .status-icon{background:#ef444426;color:var(--color-danger)}.status-card svg{color:var(--color-accent);flex-shrink:0}.status-content{flex:1;display:flex;flex-direction:column;gap:2px}.status-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.status-value{font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.status-detail{font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize}.quick-add{flex-shrink:0}.quick-add-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background:linear-gradient(135deg,#14b8a626,#14b8a60d);border:1px solid var(--color-accent);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);animation:pulse 2s infinite}.banner-content{display:flex;align-items:center;gap:var(--spacing-md);font-weight:500}.banner-content svg{color:var(--color-accent)}.doses-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.dose-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.dose-item:hover{border-color:var(--color-accent)}.dose-date{display:flex;flex-direction:column;align-items:center;min-width:50px}.dose-day{font-size:1.5rem;font-weight:700;line-height:1;color:var(--color-text-primary)}.dose-month{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.dose-info{flex:1;display:flex;flex-direction:column;gap:2px}.dose-dosage{font-weight:600;font-family:var(--font-mono);color:var(--color-accent)}.dose-notes{font-size:.875rem;color:var(--color-text-muted)}.dose-interval{font-size:.75rem;color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-primary);border-radius:var(--radius-sm)}.dose-interval.late{color:var(--color-warning);background:#f59e0b1a}.dose-interval.early{color:var(--color-info);background:#3b82f61a}.dosage-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.dosage-option{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.dosage-option:hover{border-color:var(--color-accent)}.dosage-option.selected{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.toggle-label{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer}.toggle-label input{display:none}.toggle-switch{width:44px;height:24px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);position:relative;transition:all var(--transition-fast)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--color-text-muted);border-radius:var(--radius-full);transition:all var(--transition-fast)}.toggle-label input:checked+.toggle-switch{background:var(--color-accent);border-color:var(--color-accent)}.toggle-label input:checked+.toggle-switch:after{transform:translate(20px);background:#fff}.bt-status-card{display:flex;align-items:center;gap:var(--spacing-xl);padding:var(--spacing-xl);background:var(--gradient-card);border:2px dashed var(--color-border);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);transition:all var(--transition-normal)}.bt-status-card.connected{border-style:solid;border-color:var(--color-success);background:linear-gradient(145deg,var(--color-bg-card),rgba(34,197,94,.1))}.bt-status-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border-radius:var(--radius-lg);color:var(--color-text-muted)}.bt-status-card.connected .bt-status-icon{background:#22c55e26;color:var(--color-success)}.bt-status-info{flex:1}.bt-status-info h2{font-size:1.5rem;margin-bottom:var(--spacing-xs)}.bt-device-name{color:var(--color-text-secondary)}.live-weight-card{background:linear-gradient(145deg,#14b8a626,#14b8a60d);border:1px solid var(--color-accent);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;margin-bottom:var(--spacing-xl)}.live-weight-label{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--color-accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-md)}.live-weight-value{font-family:var(--font-mono);margin-bottom:var(--spacing-md)}.weight-number{font-size:5rem;font-weight:700;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.weight-unit{font-size:2rem;color:var(--color-text-muted);margin-left:var(--spacing-sm)}.weight-waiting{font-size:1.5rem;color:var(--color-text-muted)}.live-weight-status{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--color-success)}.live-weight-status svg{animation:pulse 1.5s infinite}.devices-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.device-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.device-item:hover{border-color:var(--color-accent)}.device-item.connected{border-color:var(--color-success);background:#22c55e1a}.device-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);border-radius:var(--radius-md);color:var(--color-accent)}.device-info{flex:1;display:flex;flex-direction:column}.device-name{font-weight:600}.device-id{font-size:.75rem;font-family:var(--font-mono);color:var(--color-text-muted)}.device-signal{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;font-family:var(--font-mono);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-bg-primary)}.device-signal.excellent{color:var(--color-success)}.device-signal.good{color:var(--color-accent)}.device-signal.fair{color:var(--color-warning)}.device-signal.weak{color:var(--color-danger)}.device-connected-badge{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:500;color:var(--color-success);padding:var(--spacing-xs) var(--spacing-md);background:#22c55e26;border-radius:var(--radius-full)}.bt-instructions{margin-top:var(--spacing-2xl)}.bt-instructions h3{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.instructions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media (max-width: 1200px){.instructions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 700px){.instructions-grid{grid-template-columns:1fr}}.instruction-item{display:flex;gap:var(--spacing-md)}.instruction-number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-accent);color:#fff;border-radius:var(--radius-full);font-weight:700;flex-shrink:0}.instruction-content h4{font-size:.875rem;margin-bottom:4px}.instruction-content p{font-size:.75rem;color:var(--color-text-muted);line-height:1.5}.bt-note{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-lg);font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.bt-note svg{flex-shrink:0;color:#3b82f6}.bt-note strong{color:var(--color-text-primary)}.bt-warning{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl)}.bt-warning svg{flex-shrink:0;color:var(--color-warning)}.bt-warning strong{display:block;color:var(--color-warning);margin-bottom:var(--spacing-xs)}.bt-warning p{font-size:.875rem;color:var(--color-text-secondary);margin:0}.bt-error{color:var(--color-danger);font-size:.875rem;margin-top:var(--spacing-xs)}.bt-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.bt-buttons .btn-ghost{font-size:.75rem;opacity:.7}.live-weight-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.auto-save-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.875rem;color:var(--color-text-secondary)}.auto-save-toggle input{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer}.weight-history{display:flex;flex-direction:column;gap:var(--spacing-xs)}.weight-history-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.wh-weight{font-family:var(--font-mono);font-weight:600;color:var(--color-accent)}.wh-time{font-size:.75rem;font-family:var(--font-mono);color:var(--color-text-muted)}.bt-specs{padding:var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.bt-specs h4{font-size:.875rem;margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.bt-specs ul{list-style:none;padding:0;margin:0;font-size:.8rem;font-family:var(--font-mono)}.bt-specs li{padding:var(--spacing-xs) 0;border-bottom:1px solid var(--color-border);color:var(--color-text-muted)}.bt-specs li:last-child{border-bottom:none}.bt-specs li strong{color:var(--color-text-secondary)}@media (max-width: 768px){.bt-status-card{flex-direction:column;text-align:center;gap:var(--spacing-lg)}.bt-status-icon{width:64px;height:64px}.bt-status-icon svg{width:32px;height:32px}.bt-status-info h2{font-size:1.25rem}.live-weight-card{padding:var(--spacing-xl)}.weight-number{font-size:3.5rem}.weight-unit{font-size:1.5rem}.live-weight-header{flex-direction:column;gap:var(--spacing-sm)}.instructions-grid{grid-template-columns:1fr}}.settings-page{max-width:800px}.settings-section{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.section-header-inline{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.section-header-inline svg{color:var(--color-accent)}.section-header-inline h3{font-size:1.125rem;margin:0}.section-desc{color:var(--color-text-muted);font-size:.875rem;margin-bottom:var(--spacing-lg)}.theme-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.theme-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative}.theme-option:hover{border-color:var(--color-accent)}.theme-option.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.theme-preview{width:80px;height:60px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.theme-preview.dark{background:linear-gradient(145deg,#0f1616,#182222);color:#14b8a6;border:1px solid #243333}.theme-preview.light{background:linear-gradient(145deg,#fff,#f1f5f5);color:#f97316;border:1px solid #d1dede}.theme-name{font-weight:500;font-size:.875rem}.check-icon{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);color:var(--color-accent)}.color-options{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}@media (max-width: 600px){.color-options{grid-template-columns:repeat(2,1fr)}}.color-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{border-color:var(--preview-color)}.color-option.selected{border-color:var(--preview-color);background:color-mix(in srgb,var(--preview-color) 10%,transparent)}.color-preview{width:48px;height:48px;border-radius:var(--radius-full);background:var(--preview-color);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--preview-color) 40%,transparent)}.color-name{font-size:.75rem;color:var(--color-text-secondary)}.preview-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.preview-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.preview-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff}.preview-info{display:flex;flex-direction:column}.preview-title{font-weight:600}.preview-subtitle{font-size:.875rem;color:var(--color-text-muted);font-family:var(--font-mono)}.preview-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.preview-stat{display:flex;flex-direction:column;align-items:center;flex:1}.preview-stat-value{font-size:1.25rem;font-weight:700;font-family:var(--font-mono);color:var(--color-accent)}.preview-stat-label{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.preview-btn{width:100%}.app-info h3{margin-bottom:var(--spacing-md)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.info-item{display:flex;flex-direction:column;gap:2px}.info-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.info-value{font-size:.875rem;color:var(--color-text-secondary)}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-primary)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.app{display:flex;min-height:100vh}.main-content{flex:1;margin-left:280px;padding:var(--spacing-xl);max-width:calc(100vw - 280px);overflow-x:hidden}.main-content:before{content:"";display:block;height:32px;-webkit-app-region:drag}.page{animation:slideUp var(--transition-slow) ease-out}.page-header{margin-bottom:var(--spacing-xl)}.page-header h1{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xs);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{color:var(--color-text-secondary);font-size:1rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg)}@media (max-width: 1400px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1200px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--color-text-secondary);font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%}.form-row{display:flex;gap:var(--spacing-md)}.form-row .form-group{flex:1}.input-with-unit{position:relative}.input-with-unit input{padding-right:50px}.input-with-unit .unit{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:.875rem;pointer-events:none}.stat-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm)}.stat-card .stat-label{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-value{font-size:2.5rem;font-weight:700;font-family:var(--font-mono);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card .stat-unit{font-size:1rem;font-weight:400;opacity:.7}.stat-card .stat-change{font-size:.875rem;display:flex;align-items:center;gap:var(--spacing-xs)}.stat-card .stat-change.positive{color:var(--color-success)}.stat-card .stat-change.negative{color:var(--color-danger)}.section{margin-bottom:var(--spacing-2xl)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-title{font-size:1.25rem;font-weight:600}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted)}.empty-state svg{width:64px;height:64px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}table{width:100%;border-collapse:collapse}th,td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}th{background:var(--color-bg-tertiary);font-weight:600;font-size:.875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}tr:last-child td{border-bottom:none}tr:hover td{background:var(--color-bg-hover)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn var(--transition-fast)}.modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-normal)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.modal-header h2{font-size:1.5rem}.modal-close{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.modal-close:hover{background:var(--color-bg-hover)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.toast-container{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);z-index:200;display:flex;flex-direction:column;gap:var(--spacing-sm)}.toast{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-lg);animation:slideUp var(--transition-normal);display:flex;align-items:center;gap:var(--spacing-md)}.toast.success{border-color:var(--color-success)}.toast.error{border-color:var(--color-danger)}.mobile-menu-toggle{display:none;position:fixed;top:var(--spacing-md);left:var(--spacing-md);z-index:60;width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-bg-card);border:1px solid var(--color-border);align-items:center;justify-content:center;color:var(--color-text-primary);box-shadow:var(--shadow-md)}.mobile-menu-toggle svg{width:24px;height:24px}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:40}@media (max-width: 768px){.mobile-menu-toggle{display:flex}.sidebar-overlay.active{display:block}.main-content{margin-left:0;max-width:100vw;padding:var(--spacing-md);padding-top:70px}.main-content:before{display:none}.page-header h1{font-size:1.5rem}.page-header p{font-size:.875rem}.form-row{flex-direction:column}.table-container{margin:0 calc(-1 * var(--spacing-md));border-radius:0;border-left:none;border-right:none}th,td{padding:var(--spacing-sm);font-size:.875rem}.stat-card .stat-value{font-size:1.75rem}.modal{width:100%;max-width:100%;margin:var(--spacing-md);border-radius:var(--radius-lg)}.modal-overlay{padding:var(--spacing-md)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.toast-container{top:var(--spacing-xl);bottom:auto;left:var(--spacing-md);right:var(--spacing-md)}}@media (max-width: 480px){.main-content{padding:var(--spacing-sm);padding-top:60px}.stat-card{padding:var(--spacing-md)}.stat-card .stat-value{font-size:1.5rem}.btn{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}}:root{--palette-teal-500: #14b8a6;--palette-teal-600: #0d9488;--palette-teal-400: #2dd4bf;--palette-teal-light: rgba(20, 184, 166, .15);--palette-teal-glow: rgba(20, 184, 166, .3);--palette-blue-500: #3b82f6;--palette-blue-600: #2563eb;--palette-blue-400: #60a5fa;--palette-blue-light: rgba(59, 130, 246, .15);--palette-blue-glow: rgba(59, 130, 246, .3);--palette-purple-500: #a855f7;--palette-purple-600: #9333ea;--palette-purple-400: #c084fc;--palette-purple-light: rgba(168, 85, 247, .15);--palette-purple-glow: rgba(168, 85, 247, .3);--palette-orange-500: #f97316;--palette-orange-600: #ea580c;--palette-orange-400: #fb923c;--palette-orange-light: rgba(249, 115, 22, .15);--palette-orange-glow: rgba(249, 115, 22, .3)}[data-theme=dark]{--color-bg-primary: #0a0f0f;--color-bg-secondary: #0f1616;--color-bg-tertiary: #141d1d;--color-bg-card: #182222;--color-bg-hover: #1e2a2a;--color-border: #243333;--color-border-light: #2d4040;--color-text-primary: #e8f5f5;--color-text-secondary: #9eb8b8;--color-text-muted: #6b8888;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5)}[data-theme=light]{--color-bg-primary: #f8fafa;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f5;--color-bg-card: #ffffff;--color-bg-hover: #e8eeee;--color-border: #d1dede;--color-border-light: #e5ebeb;--color-text-primary: #1a2626;--color-text-secondary: #4a5e5e;--color-text-muted: #7a9090;--color-success: #16a34a;--color-warning: #d97706;--color-danger: #dc2626;--color-info: #2563eb;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12)}[data-accent=teal]{--color-accent: var(--palette-teal-500);--color-accent-hover: var(--palette-teal-600);--color-accent-light: var(--palette-teal-light);--gradient-accent: linear-gradient(135deg, var(--palette-teal-500), var(--palette-teal-600));--shadow-glow: 0 0 40px var(--palette-teal-glow)}[data-accent=blue]{--color-accent: var(--palette-blue-500);--color-accent-hover: var(--palette-blue-600);--color-accent-light: var(--palette-blue-light);--gradient-accent: linear-gradient(135deg, var(--palette-blue-500), var(--palette-blue-600));--shadow-glow: 0 0 40px var(--palette-blue-glow)}[data-accent=purple]{--color-accent: var(--palette-purple-500);--color-accent-hover: var(--palette-purple-600);--color-accent-light: var(--palette-purple-light);--gradient-accent: linear-gradient(135deg, var(--palette-purple-500), var(--palette-purple-600));--shadow-glow: 0 0 40px var(--palette-purple-glow)}[data-accent=orange]{--color-accent: var(--palette-orange-500);--color-accent-hover: var(--palette-orange-600);--color-accent-light: var(--palette-orange-light);--gradient-accent: linear-gradient(135deg, var(--palette-orange-500), var(--palette-orange-600));--shadow-glow: 0 0 40px var(--palette-orange-glow)}[data-theme=dark] body:before{background:radial-gradient(ellipse at center,var(--color-accent-light),transparent 70%),repeating-linear-gradient(0deg,transparent,transparent 100px,var(--color-accent-light) 100px,var(--color-accent-light) 101px),repeating-linear-gradient(90deg,transparent,transparent 100px,var(--color-accent-light) 100px,var(--color-accent-light) 101px);opacity:.3}[data-theme=light] body:before{background:radial-gradient(ellipse at top right,var(--color-accent-light),transparent 50%),radial-gradient(ellipse at bottom left,var(--color-accent-light),transparent 50%);opacity:.5}[data-theme=light] .card,[data-theme=light] .stat-card,[data-theme=light] .index-card-large,[data-theme=light] .action-card,[data-theme=light] .device-item,[data-theme=light] .dose-item{box-shadow:var(--shadow-sm)}[data-theme=light] .gradient-card{background:var(--color-bg-card)}[data-theme=light] .sidebar{background:var(--color-bg-secondary);box-shadow:2px 0 8px #0000000d}[data-theme=light] ::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--color-border)}:root{--gradient-card: linear-gradient(145deg, var(--color-bg-card), var(--color-bg-tertiary));--font-sans: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:var(--gradient-glow),repeating-linear-gradient(0deg,transparent,transparent 100px,rgba(20,184,166,.02) 100px,rgba(20,184,166,.02) 101px),repeating-linear-gradient(90deg,transparent,transparent 100px,rgba(20,184,166,.02) 100px,rgba(20,184,166,.02) 101px);pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}::selection{background:var(--color-accent);color:var(--color-bg-primary)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,textarea:focus,select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light);outline:none}input::placeholder{color:var(--color-text-muted)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast)}.btn-primary{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-hover);border:1px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-accent);background:var(--color-accent-light)}.btn-ghost{background:transparent}.btn-ghost:hover{background:var(--color-bg-hover)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-success{background:#22c55e26;color:var(--color-success)}.badge-warning{background:#f59e0b26;color:var(--color-warning)}.badge-danger{background:#ef444426;color:var(--color-danger)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}
