:root{--bg:#0e1117;--bg-card:#171b22;--bg-elevated:#1f242d;--border:#252b35;--text:#e5e7eb;--text-dim:#94a3b8;--text-muted:#64748b;--accent:#6b7fb8;--danger:#c95f5f;--success:#5a9a72;--warning:#c4a04a}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}code{background:var(--bg-elevated);border-radius:4px;padding:2px 6px;font-family:ui-monospace,Menlo,monospace;font-size:12px}.muted{color:var(--text-muted)}.center{text-align:center}.page-loading{min-height:100vh;color:var(--text-dim);justify-content:center;align-items:center;font-size:14px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;transition:filter .15s,background .15s,border-color .15s;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--text-muted)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 22px;font-size:16px}.btn-block{width:100%}.landing{max-width:1100px;margin:0 auto;padding:22px 18px 60px}.landing-header{justify-content:space-between;align-items:center;margin-bottom:60px;display:flex}.brand{letter-spacing:-.3px;font-size:18px;font-weight:700}.logo{letter-spacing:-.3px;align-items:center;gap:8px;font-weight:700;display:inline-flex}.logo-word{color:var(--text);font-size:17px}a.logo:hover .logo-word{color:var(--text)}a.logo,a.logo:hover{text-decoration:none}.landing-nav{gap:10px;display:flex}.hero{text-align:center;padding:40px 0 60px}.hero h1{letter-spacing:-1px;max-width:760px;margin:0 auto 18px;font-size:clamp(28px,5vw,48px);font-weight:700;line-height:1.1}.hero-sub{color:var(--text-dim);max-width:600px;margin:0 auto 32px;font-size:clamp(15px,2vw,18px)}.hero-cta{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.features{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:40px;display:grid}.feature{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px}.feature h3{margin-bottom:8px;font-size:15px;font-weight:600}.feature p{color:var(--text-dim);font-size:13px}.landing-footer{border-top:1px solid var(--border);text-align:center;color:var(--text-muted);margin-top:80px;padding-top:24px;font-size:12px}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:420px;padding:28px}.auth-card h1{letter-spacing:-.4px;margin-bottom:6px;font-size:22px;font-weight:700}.auth-logo{margin-bottom:18px;display:inline-block}.auth-logo:hover{text-decoration:none}.auth-sub{color:var(--text-dim);margin-bottom:22px;font-size:13px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-form label{color:var(--text-dim);flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.auth-form input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:7px;padding:10px 12px;font-family:inherit;font-size:14px}.auth-form input:focus{border-color:var(--accent);outline:none}.password-wrap{position:relative}.password-wrap input{padding-right:42px}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;padding:6px;font-family:inherit;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.password-toggle:hover{color:var(--text);background:var(--bg-elevated)}.password-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-error{color:#df8a8a;background:#c95f5f1a;border:1px solid #c95f5f4d;border-radius:7px;padding:10px 12px;font-size:13px}.auth-foot{color:var(--text-dim);text-align:center;margin-top:20px;font-size:13px}.app-shell{min-height:100vh}.app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.app-header-right{align-items:center;gap:8px;display:flex}.bell-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:color .15s,border-color .15s;display:flex}.bell-btn:hover{color:var(--text);border-color:var(--text-muted)}.bell-wrap,.bell-btn{position:relative}.bell-badge{background:var(--danger);color:#fff;border:2px solid var(--bg);border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.bell-dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:100;border-radius:10px;width:320px;max-width:calc(100vw - 24px);position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 10px 30px #0006}.bell-dropdown-head{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);padding:12px 14px;font-size:11px;font-weight:600}.bell-list{max-height:360px;overflow-y:auto}.bell-item{border-bottom:1px solid var(--border);padding:14px}.bell-item:last-child{border-bottom:none}.bell-item-title{color:var(--text);margin-bottom:4px;font-size:13px;font-weight:600}.bell-item-body{color:var(--text-dim);font-size:12px;line-height:1.45}.bell-empty{text-align:center;color:var(--text-muted);padding:30px 14px;font-size:13px}.welcome-modal{text-align:center;max-width:460px}.welcome-mark{justify-content:center;margin-bottom:14px;display:flex}.welcome-modal h3{margin-bottom:14px;font-size:20px;font-weight:700;display:block}.welcome-body{color:var(--text-dim);text-align:left;margin-bottom:12px;font-size:14px;line-height:1.55}.welcome-body strong{color:var(--text)}.welcome-body.muted{color:var(--text-muted)}.app-main{max-width:1100px;margin:0 auto;padding:28px 20px 60px}.app-main h2{margin-bottom:14px;font-size:18px;font-weight:600}.placeholder-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:28px}.placeholder-card h2{margin-bottom:12px}.placeholder-card p{color:var(--text-dim);margin-bottom:10px;font-size:14px}.placeholder-card p.muted{font-size:12px}.admin-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:auto hidden}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px}.admin-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.container{max-width:900px;margin:0 auto;padding:24px 18px 80px}nav.tabs{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;gap:2px;margin-bottom:24px;padding:4px;display:flex}.tab{cursor:pointer;color:var(--text-dim);background:0 0;border:none;border-radius:7px;flex:1;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:500}.tab.active{background:var(--bg-elevated);color:var(--text);font-weight:600}.tab:not(.active):hover{color:var(--text)}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-size:12px;font-weight:600}.today-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;margin-bottom:28px;padding:20px}.today-date{color:var(--text-dim);text-transform:capitalize;margin-bottom:18px;font-size:13px}.time-row{align-items:flex-start;gap:18px;margin-bottom:16px;display:flex}.time-row:last-child{margin-bottom:0}.time-label{color:var(--text-muted);letter-spacing:1px;flex-shrink:0;width:40px;padding-top:10px;font-size:11px;font-weight:700}.time-pills{flex-wrap:wrap;flex:1;gap:8px;display:flex}.pill{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:999px;align-items:center;gap:9px;padding:9px 14px 9px 11px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.pill:hover{border-color:var(--text-muted);background:#232934}.pill-dot{background:var(--color);border-radius:50%;flex-shrink:0;width:9px;height:9px}.pill-dose{color:var(--text-dim);font-size:12px;font-weight:500}.pill.done{opacity:.45}.pill.done .pill-name:after{content:" ✓";color:var(--success)}.empty-time{color:var(--text-muted);padding:10px 0;font-size:13px;font-style:italic}.next-shot{text-align:center;border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:14px}.next-shot-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:4px;font-size:10px;font-weight:600}.next-shot-when{letter-spacing:-.3px;color:var(--text);font-size:20px;font-weight:700;line-height:1.1}.next-shot-when .when-date{color:var(--text-dim);letter-spacing:0;margin-left:8px;font-size:12px;font-weight:500}.next-shot-info{color:var(--text-dim);flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:6px;font-size:12px;display:flex}.next-shot-info .pep{color:var(--text);align-items:center;gap:6px;font-weight:600;display:inline-flex}.next-shot-info .pep:before{content:"";background:var(--color,var(--accent));border-radius:50%;width:8px;height:8px}.next-shot-info .sep{color:var(--border)}.next-shot-cta{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:10px;display:flex}.next-shot-cta .btn{padding:8px 14px;font-size:12px}.next-shot-empty{color:var(--text-dim);padding:4px 0;font-size:12px}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{color:#df8a8a;background:#c95f5f1f;border:1px solid #c95f5f40}.btn-danger:hover{background:#c95f5f33}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:6px 8px;font-family:inherit;font-size:17px}.icon-btn:hover{background:var(--bg-elevated);color:var(--danger)}.protocol-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.protocol-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:16px;transition:border-color .15s;position:relative}.protocol-card:hover{border-color:var(--text-muted)}.protocol-card.has-missed{border-left:3px solid var(--danger)}.protocol-card-head{align-items:center;gap:8px;margin-bottom:4px;display:flex}.protocol-dot{background:var(--color);border-radius:50%;flex-shrink:0;width:10px;height:10px}.protocol-card h3{font-size:15px;font-weight:600}.protocol-card .cat{color:var(--text-muted);margin-bottom:14px;margin-left:18px;font-size:12px}.progress-track{background:#ffffff0d;border-radius:99px;height:5px;margin:0 0 8px;overflow:hidden}.progress-bar{background:var(--color);border-radius:99px;height:100%;transition:width .3s}.progress-text{color:var(--text-dim);justify-content:space-between;font-size:12px;display:flex}.status-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;margin-top:10px;padding:3px 9px;font-size:10px;font-weight:600;display:inline-block}.status-active{color:#6dbe87;background:#5a9a721f}.status-warning{color:#d8b566;background:#c4a04a24}.status-stop{color:#df8a8a;background:#c95f5f24}.status-off{color:var(--text-dim);background:#64748b24}.back-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:7px;align-items:center;gap:6px;margin-bottom:18px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.back-btn:hover{color:var(--text);border-color:var(--text-muted)}.detail-header{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--color);border-radius:12px;margin-bottom:16px;padding:22px}.detail-header-top{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.detail-title{align-items:center;gap:10px;display:flex}.detail-title .dot{background:var(--color);border-radius:50%;width:12px;height:12px}.detail-header h2{font-size:24px;font-weight:600}.detail-header .cat{color:var(--text-dim);margin-top:2px;margin-left:22px;font-size:13px}.detail-stats{flex-wrap:wrap;gap:28px;display:flex}.detail-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.detail-stat-value{margin-top:3px;font-size:19px;font-weight:600}.big-log-btn{background:var(--color);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-bottom:18px;padding:15px;font-family:inherit;font-size:14px;font-weight:600;transition:filter .15s}.big-log-btn:hover{filter:brightness(1.08)}.cycle-progress-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:20px}.cycle-progress-top{justify-content:space-between;align-items:flex-end;margin-bottom:14px;display:flex}.cycle-day-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:600}.cycle-day-value{letter-spacing:-.5px;font-size:30px;font-weight:700;line-height:1}.cycle-day-value .of{color:var(--text-muted);font-size:22px;font-weight:500}.cycle-sub-text{color:var(--text-dim);margin-top:8px;font-size:13px}.cycle-sub-text strong{color:var(--text);font-weight:600}.cycle-pct-big{font-variant-numeric:tabular-nums;color:var(--color);font-size:26px;font-weight:700}.big-progress{background:#ffffff0a;border-radius:99px;height:10px;overflow:hidden}.big-progress-fill{background:var(--color);border-radius:99px;height:100%;transition:width .3s}.cycle-dates{color:var(--text-dim);flex-wrap:wrap;justify-content:space-between;gap:8px;margin-top:12px;font-size:12px;display:flex}.cycle-dates strong{color:var(--text);font-weight:600}.month-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;margin-bottom:14px;padding:12px 14px}.month-card-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.month-card-title{text-transform:capitalize;color:var(--text);font-size:13px;font-weight:600}.month-card-nav{gap:2px;display:flex}.month-nav-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-family:inherit;font-size:13px;display:inline-flex}.month-nav-btn:hover{color:var(--text);border-color:var(--text-muted)}.month-weekdays{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px;display:grid}.month-weekday{text-align:center;color:var(--text-muted);letter-spacing:.3px;font-size:9px;font-weight:600}.month-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.mcell{aspect-ratio:1;min-height:34px;color:var(--text-dim);cursor:pointer;background:#ffffff05;border:1px solid #0000;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;padding:2px;transition:filter .12s;display:flex}.mcell.empty{cursor:default;background:0 0}.mcell:not(.empty):hover{filter:brightness(1.18)}.mcell.has-shots{color:var(--text);background:#6b7fb81a}.mcell.has-shots.many{background:#6b7fb838}.mcell.has-shots.lots{background:#6b7fb857}.mcell.partial{color:#d8b566;background:#c4a04a24}.mcell.missed{color:#df8a8a;background:#c95f5f24}.mcell.future{color:var(--text-muted);border:1px dashed #ffffff24}.mcell.today{outline:2px solid var(--accent);outline-offset:-2px;color:var(--text);font-weight:700}.mcell-num{font-size:13px;font-weight:600;line-height:1}.mcell-count{color:var(--text-muted);margin-top:2px;font-size:9px;font-weight:600;line-height:1}.mcell.has-shots .mcell-count{color:var(--accent)}.mcell.partial .mcell-count{color:#d8b566}.mcell.missed .mcell-count{color:#df8a8a}.month-legend{color:var(--text-muted);flex-wrap:wrap;gap:10px;margin-top:10px;font-size:10px;display:flex}.month-legend-item{align-items:center;gap:5px;display:inline-flex}.month-legend-sw{border-radius:3px;width:10px;height:10px;display:inline-block}.protocols-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.protocols-header .section-title{margin-bottom:0}.protocol-row{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:14px;margin-bottom:8px;padding:14px 16px;display:flex}.protocol-row-dot{background:var(--color);border-radius:50%;flex-shrink:0;width:14px;height:14px}.protocol-row-info{flex:1;min-width:0}.protocol-row-name{font-size:14px;font-weight:600}.protocol-row-meta{color:var(--text-dim);margin-top:3px;font-size:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.show{display:flex}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;width:100%;max-width:460px;max-height:95vh;padding:16px;overflow-y:auto}.modal h3{align-items:center;gap:9px;margin-bottom:12px;font-size:16px;font-weight:600;display:flex}.modal .dot{border-radius:50%;width:10px;height:10px}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:18px}form .form-row,.modal .form-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:12px;display:grid}.modal label,.form-card label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px;font-weight:600;display:block}.app-shell input,.app-shell select,.app-shell textarea,.modal input,.modal select,.modal textarea,.form-card input,.form-card select,.form-card textarea{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:7px;padding:10px 12px;font-family:inherit;font-size:14px}.app-shell input:focus,.app-shell select:focus,.modal input:focus,.modal select:focus{border-color:var(--accent);outline:none}.app-shell label,.calc-card label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px;font-weight:600;display:block}.color-picker{flex-wrap:wrap;gap:6px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px}.color-swatch.selected{border-color:var(--text);transform:scale(1.08)}.titration-block{margin-bottom:12px}.titration-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.titration-row .t-input{width:70px;padding:6px 8px;font-size:13px}.titration-row .t-arrow{color:var(--text-muted);font-size:13px}.titration-row .t-label{color:var(--text-dim);width:36px;font-size:12px}.titration-row .t-unit{color:var(--text-dim);font-size:12px}.titration-row .t-del{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;width:26px;height:26px;margin-left:auto;padding:0;font-family:inherit;font-size:14px}.titration-row .t-del:hover{color:var(--danger);border-color:var(--danger)}.titration-banner{color:var(--text-dim);background:#6b7fb814;border:1px solid #6b7fb833;border-radius:8px;margin-bottom:14px;padding:10px 12px;font-size:13px}.titration-banner strong{color:var(--text)}.body-picker{background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:8px}.body-picker-svg{width:100%;max-width:100px;max-height:180px;margin:0 auto;display:block}.body-silhouette{fill:#ffffff0b;stroke:#ffffff2e;stroke-width:1px;stroke-linejoin:round}.site-hit{cursor:pointer}.site-hit .site-circle{fill:var(--text-muted);stroke:var(--bg);stroke-width:1.5px;transition:fill .12s}.site-hit:hover .site-circle{fill:var(--text)}.site-hit .site-circle.recommended{fill:#5a9a72}.site-hit .site-circle.recent{fill:#c4a04a}.site-hit .site-circle.very-recent{fill:#c95f5f}.site-hit.selected .site-circle{fill:var(--accent);stroke:var(--text);stroke-width:2px}.site-selected-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;font-size:13px;display:flex}.site-selected-name{color:var(--text);font-weight:600}.site-selected-meta{color:var(--text-dim);font-size:12px}.site-suggestion{color:#7bb892;border-left:3px solid var(--success);background:#5a9a7214;border-radius:6px;margin-top:8px;padding:8px 10px;font-size:12px}.site-warning{color:#d8b566;border-left:3px solid var(--warning);background:#c4a04a14;border-radius:6px;margin-top:8px;padding:8px 10px;font-size:12px}.feeling-picker{grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:4px;display:grid}.feeling-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:7px;padding:8px 0;font-family:inherit;font-size:15px;font-weight:700}.feeling-btn:hover{color:var(--text)}.feeling-btn.selected{background:var(--c,var(--accent));color:#fff;border-color:#0000}.feeling-scale-labels{color:var(--text-muted);justify-content:space-between;margin-bottom:10px;padding:0 2px;font-size:10px;display:flex}.day-log-list{flex-direction:column;gap:8px;display:flex}.day-log-item{background:var(--bg-elevated);border:1px solid var(--border);border-left:3px solid var(--color);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;display:flex}.day-log-item.missed{border-left-color:var(--danger);opacity:.78}.day-log-item.pending{border-left-color:var(--warning)}.day-log-info{flex:1;min-width:0}.day-log-name{font-size:14px;font-weight:600}.day-log-meta{color:var(--text-dim);margin-top:2px;font-size:12px}.day-log-notes{color:var(--text-muted);margin-top:3px;font-size:11px;font-style:italic}.history-list{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;overflow:hidden}.history-header{border-bottom:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:14px 16px;font-size:12px;font-weight:600}.history-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:12px 16px;display:flex}.history-item:last-child{border-bottom:none}.history-dot{background:var(--color);border-radius:50%;flex-shrink:0;width:8px;height:8px}.history-info{flex:1;min-width:0}.history-when{font-size:13px;font-weight:500}.history-dose{color:var(--text-dim);margin-top:1px;font-size:12px}.history-notes{color:var(--text-muted);margin-top:3px;font-size:11px;font-style:italic}.history-site{color:var(--text-muted);margin-top:2px;font-size:11px}.alert{background:#ffffff05;border-left:3px solid;border-radius:8px;margin-bottom:14px;padding:12px 14px;font-size:13px}.alert-warning{border-color:var(--warning);color:#d8b566}.alert-danger{border-color:var(--danger);color:#df8a8a}.alert-info{border-color:var(--accent);color:#a3afd6}.alert-success{border-color:var(--success);color:#7bb892}.stats-summary{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;display:grid}.stat-tile{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:10px;padding:12px 8px}.stat-tile-value{color:var(--text);letter-spacing:-.4px;font-size:22px;font-weight:700;line-height:1}.stat-tile-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:6px;font-size:10px}.stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:14px}.stats-mode-toggle{background:var(--bg);border:1px solid var(--border);border-radius:8px;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:12px;padding:3px;display:grid}.stats-mode-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 10px;font-family:inherit;font-size:12px;font-weight:600}.stats-mode-btn.active{background:var(--bg-elevated);color:var(--text)}.heatmap-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.heatmap-title{text-transform:capitalize;color:var(--text);font-size:13px;font-weight:600}.heatmap-weekdays{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px;display:grid}.heatmap-weekday{text-align:center;color:var(--text-muted);font-size:9px;font-weight:600}.heatmap-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.hm-cell{aspect-ratio:1;cursor:pointer;min-height:34px;color:var(--text-dim);background:#ffffff08;border-radius:6px;justify-content:center;align-items:center;font-size:11px;font-weight:600;transition:filter .12s;display:flex}.hm-cell.empty{cursor:default;background:0 0}.hm-cell:not(.empty):hover{filter:brightness(1.3)}.hm-cell-num{line-height:1}.hm-cell[class*=lvl-],.hm-cell[class*=fl-]{color:var(--text)}.hm-cell.today{outline:1.5px solid var(--accent);outline-offset:-1px}.hm-cell.lvl-1{background:#6b7fb840}.hm-cell.lvl-2{background:#6b7fb873}.hm-cell.lvl-3{background:#6b7fb8a6}.hm-cell.lvl-4{background:#6b7fb8d9}.hm-cell.lvl-5{background:#6b7fb8}.hm-cell.fl-1{background:#c95f5fd9}.hm-cell.fl-2{background:#c4a04abf}.hm-cell.fl-3{background:#94a3b88c}.hm-cell.fl-4{background:#7ab892bf}.hm-cell.fl-5{background:#5a9a72f2}.hm-legend{color:var(--text-muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-top:12px;font-size:10px;display:flex}.hm-legend-cell{border-radius:3px;width:12px;height:12px;display:inline-block}.weight-chart-wrap{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px 8px 6px}.weight-chart-svg{width:100%;height:220px;display:block}.weight-line{fill:none;stroke:var(--accent);stroke-width:2px;vector-effect:non-scaling-stroke}.weight-area{fill:#6b7fb81a}.weight-point{fill:var(--accent)}.weight-grid-line{stroke:#ffffff0d;stroke-width:1px;vector-effect:non-scaling-stroke}.weight-axis-label{fill:var(--text-muted);font-size:9px}.weight-x-axis{height:18px;margin-top:6px;padding:0 8px;position:relative}.weight-x-axis span{color:var(--text-muted);white-space:nowrap;font-size:10px;position:absolute;top:0;transform:translate(-50%)}.weight-x-axis span:first-child{transform:translate(0)}.weight-x-axis span:last-child{transform:translate(-100%)}.weight-stats-row{color:var(--text-dim);flex-wrap:wrap;justify-content:space-between;gap:8px;margin-bottom:10px;font-size:12px;display:flex}.weight-stats-row strong{color:var(--text);font-weight:600}.calc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:20px}.calc-card h3{margin-bottom:4px;font-size:16px;font-weight:600}.calc-card .subtitle{color:var(--text-dim);margin-bottom:16px;font-size:12px}.calc-result{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;margin-top:14px;padding:18px}.calc-result-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.calc-result-value{color:var(--accent);letter-spacing:-.5px;margin:6px 0;font-size:28px;font-weight:700}.calc-result-note{color:var(--text-dim);font-size:12px}.syringe-toggle{gap:8px;margin-top:6px;display:flex}.syringe-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:7px;flex:1;padding:10px;font-family:inherit;font-size:13px;font-weight:500}.syringe-btn.active{border-color:var(--accent);color:var(--text);background:#6b7fb81a}.empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}
