:root{--bg-primary:#0a0a0f;--bg-secondary:#0e0e16;--surface-color:#1a1a2e;--surface-color-light:#25253a;--surface-hover:#2a2a42;--input-bg:#12121f;--input-border:#ffffff14;--input-border-focus:var(--primary);--bg-color:var(--bg-primary);--primary:#00d4aa;--primary-light:#00e8bb;--primary-dark:#00b494;--primary-rgb:0, 212, 170;--primary-gradient:linear-gradient(135deg, #00d4aa 0%, #00b4d8 100%);--primary-gradient-hover:linear-gradient(135deg, #00e8bb 0%, #00c4e8 100%);--secondary:#f59e0b;--secondary-rgb:245, 158, 11;--success:#10b981;--success-rgb:16, 185, 129;--danger:#ef4444;--danger-rgb:239, 68, 68;--info:#3b82f6;--text-primary:#f8f8f2;--text-secondary:#8b8b9e;--text-tertiary:#4a4a5e;--text-on-primary:#000;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:15px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:22px;--font-size-2xl:28px;--font-size-3xl:34px;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-xs:4px;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 12px #0006, 0 2px 4px #00000040;--shadow-lg:0 10px 30px #00000080, 0 4px 8px #0000004d;--shadow-xl:0 20px 50px #0009;--shadow-glow:0 0 20px rgba(var(--primary-rgb), .35), 0 0 60px rgba(var(--primary-rgb), .1);--shadow-glow-sm:0 0 10px rgba(var(--primary-rgb), .25);--glass-bg:#1a1a2e8c;--glass-bg-strong:#1a1a2ebf;--glass-border:#ffffff0f;--glass-border-light:#ffffff1a;--glass-blur:16px;--glass-blur-strong:24px;--safe-area-top:env(safe-area-inset-top,0px);--safe-area-bottom:env(safe-area-inset-bottom,0px);--safe-area-left:env(safe-area-inset-left,0px);--safe-area-right:env(safe-area-inset-right,0px);--nav-height:56px;--header-padding:max(var(--space-5), var(--safe-area-top));--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{height:100%;overflow:hidden}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;background-image:radial-gradient(100% 60% at 50% 0,#00b4d80a 0%,#0000 70%);width:100vw;height:100dvh;overflow:hidden}#app{flex-direction:column;width:100%;height:100%;display:flex;position:relative}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);color:var(--text-primary);line-height:var(--line-height-tight);letter-spacing:-.02em}h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-md)}p{color:var(--text-secondary);line-height:var(--line-height-relaxed)}a{color:var(--primary);transition:opacity var(--duration-fast) var(--ease-smooth);text-decoration:none}a:active{opacity:.7}small{color:var(--text-secondary);font-size:var(--font-size-sm)}.mono,[data-mono]{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-color-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:rgba(var(--primary-rgb), .3);color:var(--text-primary)}@media (width>=769px){body{background-image:radial-gradient(50% 40% at 50% 0,#00b4d80f 0%,#0000 70%),radial-gradient(30% 50% at 80% 100%,#00d4aa08 0%,#0000 70%);justify-content:center;display:flex}#app{border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);max-width:480px;box-shadow:0 0 80px #0000004d}}@media (width>=1024px){#app{max-width:520px}}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-full);font-family:var(--font-family);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);cursor:pointer;letter-spacing:-.01em;min-width:44px;min-height:44px;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-normal) var(--ease-smooth), background var(--duration-normal) var(--ease-smooth), opacity var(--duration-fast);-webkit-user-select:none;user-select:none;border:none;outline:none;padding:12px 22px;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";transition:background var(--duration-fast);border-radius:inherit;pointer-events:none;background:#fff0;position:absolute;inset:0}.btn:hover:after{background:#ffffff0f}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary-gradient);color:var(--text-on-primary);box-shadow:var(--shadow-glow-sm)}.btn-primary:hover{background:var(--primary-gradient-hover);box-shadow:var(--shadow-glow)}.btn-primary:active{box-shadow:0 0 8px rgba(var(--primary-rgb), .3)}.btn-secondary{background:var(--surface-color-light);color:var(--text-primary);border:1px solid var(--glass-border-light)}.btn-secondary:hover{background:var(--surface-hover);border-color:#ffffff26}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 14px}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0a}.btn-ghost[title=Refresh][style*="opacity: 0.5"]{color:var(--primary);animation:.8s linear infinite refreshSpin;opacity:1!important}@keyframes refreshSpin{to{transform:rotate(360deg)}}.btn-danger{background:rgba(var(--danger-rgb), .15);color:var(--danger);border:1px solid rgba(var(--danger-rgb), .3)}.btn-danger:hover{background:rgba(var(--danger-rgb), .25)}.btn-outline{color:var(--primary);border:1.5px solid rgba(var(--primary-rgb), .4);background:0 0}.btn-outline:hover{background:rgba(var(--primary-rgb), .08);border-color:rgba(var(--primary-rgb), .6)}.btn-large{width:100%;font-size:var(--font-size-lg);border-radius:var(--radius-md);padding:16px}.btn-sm{font-size:var(--font-size-sm);min-height:36px;font-weight:var(--font-weight-medium);padding:6px 14px}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-3);transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-normal) var(--ease-smooth), border-color var(--duration-normal);position:relative;overflow:hidden}.card:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff14 30% 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.card:active{transform:scale(.985)}.card h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.card h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.card--accent{border-color:rgba(var(--primary-rgb), .2);box-shadow:inset 0 0 30px rgba(var(--primary-rgb), .03)}.card-divider{background:var(--glass-border-light);height:1px;margin:var(--space-4) 0;border:none}.bottom-nav{height:var(--nav-height);-webkit-backdrop-filter:blur(var(--glass-blur-strong));border-top:1px solid var(--glass-border);z-index:100;background:#0a0a0fe0;justify-content:space-around;align-items:center;padding-bottom:4px;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width>=769px){.bottom-nav{border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);max-width:480px;left:50%;transform:translate(-50%)}}@media (width>=1024px){.bottom-nav{max-width:520px}}.nav-item{color:var(--text-tertiary);min-height:48px;transition:color var(--duration-normal) var(--ease-smooth);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:2px 0;text-decoration:none;display:flex;position:relative}.nav-item .icon{transition:transform var(--duration-normal) var(--ease-spring);margin-bottom:0;font-size:22px;line-height:1}.nav-item .label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.02em}.nav-item.active{color:var(--primary)}.nav-item.active .icon{filter:drop-shadow(0 0 6px rgba(var(--primary-rgb), .5));transform:scale(1.1)}.nav-item.active:after{content:"";background:var(--primary);border-radius:var(--radius-full);width:4px;height:4px;box-shadow:0 0 6px rgba(var(--primary-rgb), .6);position:absolute;bottom:0;left:50%;transform:translate(-50%)}.form-group{margin-bottom:var(--space-4)}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-bottom:var(--space-2);letter-spacing:.02em;text-transform:uppercase;display:block}.form-control{background:var(--input-bg);border:1.5px solid var(--input-border);width:100%;color:var(--text-primary);border-radius:var(--radius-sm);padding:12px var(--space-4);font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);min-height:48px;transition:border-color var(--duration-normal) var(--ease-smooth), box-shadow var(--duration-normal) var(--ease-smooth), background var(--duration-normal);appearance:none;outline:none}.form-control::placeholder{color:var(--text-tertiary)}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb), .12);background:#12121fe6}select.form-control{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238B8B9E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.rating-btn{border:2px solid var(--glass-border-light);background:var(--surface-color-light);width:36px;height:36px;color:var(--text-secondary);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);cursor:pointer;transition:all var(--duration-fast);-webkit-tap-highlight-color:transparent;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.rating-btn--active{background:var(--primary-gradient);color:var(--text-on-primary);box-shadow:var(--shadow-glow-sm);border-color:#0000;transform:scale(1.05)}.rating-btn:active{transform:scale(.9)}.color-picker-grid{gap:var(--space-2);margin-top:var(--space-2);grid-template-columns:repeat(6,1fr);display:grid}.color-swatch{aspect-ratio:1;cursor:pointer;transition:transform var(--duration-fast), border-color var(--duration-fast);border:2px solid #0000;border-radius:50%;box-shadow:0 2px 4px #0003}.color-swatch.active{border-color:var(--text-primary);transform:scale(1.15);box-shadow:0 0 8px #fff6}.color-swatch:hover{transform:scale(1.1)}.progress-bar-container{background:var(--surface-color-light);border-radius:var(--radius-full);width:100%;height:6px;margin-top:8px;overflow:hidden}.progress-bar-fill{background:var(--primary-gradient);border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-out)}.progress-bar-fill.danger{background:var(--danger);box-shadow:0 0 8px rgba(var(--danger-rgb), .4)}.progress-bar-striped{border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-out);background-image:repeating-linear-gradient(45deg,#ffffff26 0 10px,#ffffff0d 10px 20px);background-size:28px 28px;animation:2s linear infinite progressStripes}@keyframes progressStripes{0%{background-position:0 0}to{background-position:28px 0}}.weight-entry{padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--glass-border-light);transition:background var(--duration-fast);justify-content:space-between;align-items:center;display:flex}.weight-entry:hover{background:#ffffff05}.weight-entry .delete-weight-btn{opacity:0;transition:all var(--duration-fast);color:var(--danger);transform:translate(10px)}.weight-entry:hover .delete-weight-btn{opacity:1;transform:translate(0)}@media (hover:none){.weight-entry .delete-weight-btn{opacity:1;transform:translate(0)}}textarea.form-control{resize:vertical;min-height:80px;line-height:var(--line-height-relaxed)}input[type=date].form-control::-webkit-calendar-picker-indicator{filter:invert()brightness(.7);cursor:pointer}input[type=range].form-control{appearance:none;background:0 0;border:none;min-height:44px;padding:0}input[type=range].form-control::-webkit-slider-runnable-track{background:var(--surface-color-light);border-radius:var(--radius-full);width:100%;height:6px}input[type=range].form-control::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary-gradient);cursor:pointer;width:22px;height:22px;box-shadow:var(--shadow-glow-sm);border:2px solid #fff3;border-radius:50%;margin-top:-8px}input[type=range]:focus{box-shadow:none}input[type=checkbox]{appearance:none;background:var(--input-bg);border:2px solid var(--input-border);border-radius:var(--radius-xs);cursor:pointer;vertical-align:middle;width:22px;height:22px;margin-right:var(--space-2);transition:background var(--duration-fast), border-color var(--duration-fast), transform var(--duration-fast) var(--ease-spring);flex-shrink:0;position:relative}input[type=checkbox]:checked{background:var(--primary-gradient);animation:checkboxPop .3s var(--ease-spring);border-color:#0000}input[type=checkbox]:checked:after{content:"";border:2.5px solid #000;border-width:0 2.5px 2.5px 0;width:7px;height:12px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}input[type=checkbox]:active{transform:scale(.9)}.modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:1000;animation:overlayFadeIn .25s var(--ease-smooth) forwards;background:#0000008c;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-content.bottom-sheet{background:var(--surface-color);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);width:100%;padding:var(--space-6);padding-bottom:calc(var(--space-8) + var(--safe-area-bottom));max-height:92vh;box-shadow:var(--shadow-xl);animation:bottomSheetSlideUp .4s var(--ease-out) forwards;position:relative;overflow-y:auto}.modal-content.bottom-sheet:before{content:"";border-radius:var(--radius-full);width:36px;height:4px;margin:0 auto var(--space-5);background:#ffffff26;display:block}.modal-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.btn-close{background:var(--surface-color-light);border:1px solid var(--glass-border-light);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-full);width:36px;height:36px;transition:all var(--duration-fast);justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex}.btn-close:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-icon-container{margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.modal-icon{background:rgba(var(--secondary-rgb), .1);border:2px solid rgba(var(--secondary-rgb), .3);width:64px;height:64px;box-shadow:0 0 20px rgba(var(--secondary-rgb), .15);border-radius:50%;justify-content:center;align-items:center;font-size:32px;display:flex}.modal-icon.danger{background:rgba(var(--danger-rgb), .1);border-color:rgba(var(--danger-rgb), .3);box-shadow:0 0 20px rgba(var(--danger-rgb), .15)}.modal-footer{gap:var(--space-3);margin-top:var(--space-6);display:flex}.modal-footer .btn{border-radius:var(--radius-md);flex:1}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.04em;text-transform:uppercase;align-items:center;padding:3px 10px;line-height:1.4;display:inline-flex}.badge-primary{background:rgba(var(--primary-rgb), .15);color:var(--primary)}.badge-blend{background:var(--primary-gradient);color:var(--text-on-primary)}.badge-time{background:var(--surface-color-light);color:var(--text-secondary);border:1px solid var(--glass-border-light)}.badge-warning{background:rgba(var(--secondary-rgb), .12);color:var(--secondary);border:1px solid rgba(var(--secondary-rgb), .2)}.badge-danger{background:rgba(var(--danger-rgb), .12);color:var(--danger);border:1px solid rgba(var(--danger-rgb), .2)}.badge-success{background:rgba(var(--success-rgb), .12);color:var(--success)}.empty-state{text-align:center;padding:var(--space-12) var(--space-5);color:var(--text-secondary)}.empty-state .icon{margin-bottom:var(--space-4);opacity:.4;filter:grayscale(.3);font-size:56px;display:block}.empty-state p{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);max-width:280px;margin:0 auto}.skeleton{background:linear-gradient(90deg, var(--surface-color) 25%, var(--surface-color-light) 50%, var(--surface-color) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite skeletonShimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-card{height:80px;margin-bottom:var(--space-4);border-radius:var(--radius-md)}.toast-container{top:calc(var(--safe-area-top) + var(--space-4));left:var(--space-4);right:var(--space-4);z-index:2000;gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(var(--glass-blur-strong));border:1px solid var(--glass-border-light);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-lg);animation:toastSlideIn .4s var(--ease-out) forwards;pointer-events:auto;align-items:center;gap:var(--space-2);display:flex}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--primary)}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.text-primary{color:var(--text-primary)!important}.text-secondary{color:var(--text-secondary)!important}.text-tertiary{color:var(--text-tertiary)!important}.text-accent{color:var(--primary)!important}.text-danger{color:var(--danger)!important}.text-success{color:var(--success)!important}.text-warning{color:var(--secondary)!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.float-anim{animation:3s ease-in-out infinite float}@keyframes slideDownFade{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:1000px;transform:translateY(0)}}.slide-down-fade{animation:slideDownFade .4s var(--ease-out) forwards}@keyframes pulseHighlight{0%{box-shadow:0 0 0 0 rgba(var(--primary-rgb), .7)}70%{box-shadow:0 0 0 10px rgba(var(--primary-rgb), 0)}to{box-shadow:0 0 0 0 rgba(var(--primary-rgb), 0)}}.pulse-anim{animation:2s infinite pulseHighlight}.view-container{padding:var(--space-5);padding-top:calc(var(--header-padding) + var(--space-3));padding-bottom:calc(var(--nav-height) + var(--space-5));-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scroll-behavior:smooth;flex:1;overflow:hidden auto}.ptr-indicator{text-align:center;height:0;transition:height .3s var(--ease-spring);color:var(--primary);font-size:var(--font-size-sm);justify-content:center;align-items:center;gap:var(--space-2);display:flex;overflow:hidden}.ptr-indicator.ptr-visible{height:60px}.ptr-indicator .spinner{border:2px solid rgba(var(--primary-rgb), .3);border-top-color:var(--primary);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite ptrSpin;display:inline-block}@keyframes ptrSpin{to{transform:rotate(360deg)}}.login-screen{padding:var(--space-10) var(--space-5);background:radial-gradient(ellipse 60% 40% at 50% 35%, rgba(var(--primary-rgb), .06) 0%, transparent 70%);flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:100dvh;display:flex}.login-screen .logo{text-align:center;margin-bottom:var(--space-12)}.login-screen .logo .icon{margin-bottom:var(--space-4);filter:drop-shadow(0 0 30px rgba(var(--primary-rgb), .25));font-size:80px;animation:4s ease-in-out infinite floatIcon;display:block}.login-screen .logo h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);background:var(--primary-gradient);-webkit-text-fill-color:transparent;margin-bottom:var(--space-2);letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text}.login-screen .logo p{font-size:var(--font-size-base);color:var(--text-secondary);font-weight:var(--font-weight-light);letter-spacing:.04em}.login-screen .btn-primary{width:100%;max-width:320px;font-size:var(--font-size-lg);border-radius:var(--radius-md);padding:16px}.login-screen .setup-notice{margin-top:var(--space-10);padding:var(--space-4);background:rgba(var(--secondary-rgb), .06);border:1px solid rgba(var(--secondary-rgb), .15);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center;max-width:380px;line-height:var(--line-height-relaxed)}.view-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.view-header h2{font-size:var(--font-size-2xl);letter-spacing:-.03em}.view-header h3{font-size:var(--font-size-lg);color:var(--text-primary)}.view-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1);font-weight:var(--font-weight-normal)}.date-nav{align-items:center;gap:var(--space-2);margin-top:var(--space-1);display:flex}.date-nav-arrow{min-width:36px;min-height:36px;font-size:var(--font-size-md);padding:4px 8px!important}.date-nav-label{color:var(--text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast);white-space:nowrap;background:0 0;border:none;padding:4px 8px}.date-nav-label:hover{background:#ffffff0a}.date-picker-hidden{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.past-day-badge{margin-top:var(--space-2);display:inline-block}.dose-card{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.dose-card-info{flex:1;min-width:0}.dose-card-info h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);letter-spacing:-.01em;margin-bottom:1px}.dose-card-meta{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-secondary);flex-wrap:wrap;display:flex}.dose-amount{font-family:var(--font-mono);font-weight:var(--font-weight-medium);color:var(--text-primary);font-size:var(--font-size-sm)}.dose-mcg{font-family:var(--font-mono);color:var(--text-secondary);font-size:var(--font-size-xs)}.dose-card .btn{flex-shrink:0;min-width:88px}.dose-card .btn-taken{background:rgba(var(--success-rgb), .12);color:var(--success);border:1px solid rgba(var(--success-rgb), .2);pointer-events:none}.quick-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.quick-actions .btn{font-size:var(--font-size-xs);gap:var(--space-1);padding:6px 12px}.compound-card-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.compound-card-header h3{font-size:var(--font-size-lg)}.compound-card-header .short-name{color:var(--text-tertiary);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal)}.compound-protocol{font-size:var(--font-size-sm);color:var(--text-secondary);padding:var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:#ffffff05}.compound-protocol strong{color:var(--text-primary);font-weight:var(--font-weight-medium)}.compound-divider{margin:var(--space-4) 0;background:var(--glass-border-light);border:none;height:1px}.compound-notes{min-height:60px;font-size:var(--font-size-sm)!important;background:#12121f99!important}.inventory-group-header{margin-top:var(--space-5);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid rgba(var(--primary-rgb), .15);align-items:center;gap:var(--space-2);display:flex}.inventory-group-header h3{color:var(--primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);letter-spacing:-.01em}.inventory-group-header .count-badge{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-tertiary);background:var(--surface-color-light);border-radius:var(--radius-full);padding:2px 8px}.inventory-card{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.inventory-card h4{font-family:var(--font-mono);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.inventory-card-meta{font-size:var(--font-size-sm);color:var(--text-secondary)}.supply-card{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.supply-quantity{font-family:var(--font-mono);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--text-primary)}.supply-unit{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-normal);margin-left:var(--space-1)}.chart-container{width:100%;height:200px;padding:var(--space-2) 0;position:relative}.chart-container canvas{width:100%!important;height:100%!important}.section-label{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.journal-card{margin-bottom:var(--space-3)}.journal-card h4{font-size:var(--font-size-base);margin-bottom:var(--space-2);font-weight:var(--font-weight-semibold)}.journal-metrics{gap:var(--space-4);font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.journal-metrics span{align-items:center;gap:4px;display:inline-flex}.journal-crash-warning{color:var(--danger);font-size:var(--font-size-xs);margin-bottom:var(--space-2);align-items:center;gap:var(--space-1);display:flex}.journal-notes{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--text-secondary)}.heatmap-container{text-align:center;color:var(--text-secondary);padding:var(--space-3) 0;font-size:var(--font-size-sm)}.heatmap-day{aspect-ratio:1;border-radius:var(--radius-xs);transition:transform var(--duration-fast), box-shadow var(--duration-fast);cursor:pointer}.heatmap-day:hover{box-shadow:0 0 8px rgba(var(--primary-rgb), .4);z-index:1;transform:scale(1.15)}.heatmap-day:active{transform:scale(.95)}.cycle-history-group{margin-bottom:var(--space-5);border:1px solid var(--glass-border-light);border-radius:var(--radius-md);padding:var(--space-4);background:#ffffff05}.cycle-history-header{margin-bottom:var(--space-3);align-items:center;gap:var(--space-2);display:flex}.cycle-history-header h4{font-size:var(--font-size-md);color:var(--primary);letter-spacing:-.01em}.cycle-history-list{gap:var(--space-2);flex-direction:column;display:flex}.cycle-history-item{padding:var(--space-3);background:var(--surface-color-light);border-radius:var(--radius-sm);transition:background var(--duration-fast);border:1px solid #0000;justify-content:space-between;align-items:center;display:flex}.cycle-history-item.current{background:rgba(var(--primary-rgb), .06);border-color:rgba(var(--primary-rgb), .2)}.cycle-title{font-weight:var(--font-weight-medium);color:var(--text-primary);font-size:var(--font-size-sm)}.cycle-dates{align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--text-secondary);display:flex}.cycle-duration{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-tertiary);border-radius:var(--radius-sm);background:#0003;padding:4px 8px}.cycle-raw-events{margin-top:var(--space-3)}.cycle-raw-events summary{padding:var(--space-2) 0;cursor:pointer;color:var(--text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;-webkit-user-select:none;user-select:none;border-top:1px dashed var(--glass-border-light);transition:color var(--duration-fast);justify-content:space-between;align-items:center;display:flex}.cycle-raw-events summary:hover{color:var(--text-primary)}.cycle-raw-events summary::-webkit-details-marker{display:none}.cycle-raw-events[open] summary .icon{transform:rotate(180deg)}.cycle-raw-events-content{margin-top:var(--space-2);padding:var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--glass-border-light);background:#0003}.raw-event-item{padding:var(--space-2) 0;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex}.raw-event-item:last-child{border-bottom:none;padding-bottom:0}.raw-event-info{align-items:center;gap:var(--space-2);display:flex}.raw-event-date{font-size:var(--font-size-xs);color:var(--text-tertiary)}.raw-event-actions{gap:var(--space-1);display:flex}.dose-history-item{padding:var(--space-2) 0;border-bottom:1px solid var(--glass-border-light);transition:background var(--duration-fast);justify-content:space-between;align-items:center;display:flex}.dose-history-item:hover{background:#ffffff05}.dose-history-item:last-child{border-bottom:none}.weight-val{font-family:var(--font-mono);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--text-primary)}.order-card{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.order-card h4{font-size:var(--font-size-base);margin-bottom:2px}.order-meta{font-size:var(--font-size-xs);color:var(--text-secondary)}.order-cost{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--primary)}.chart-timeframe-toggle{gap:4px;display:flex}.timeframe-btn{color:var(--text-secondary);border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border:1px solid var(--glass-border-light);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);background:0 0;min-height:28px;padding:4px 12px}.timeframe-btn:hover{background:#ffffff0a;border-color:#ffffff26}.timeframe-btn.active{background:rgba(var(--primary-rgb), .12);color:var(--primary);border-color:rgba(var(--primary-rgb), .3)}.settings-row{padding:var(--space-4) 0;justify-content:space-between;align-items:center;display:flex}.settings-row+.settings-row{border-top:1px solid var(--glass-border)}.settings-label{flex-direction:column;gap:2px;display:flex}.settings-label strong{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary)}.settings-label span{font-size:var(--font-size-xs);color:var(--text-secondary)}.section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3);margin-top:var(--space-8);color:var(--text-primary)}.section-title:first-child{margin-top:0}.cycle-summary{gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.cycle-badge{align-items:center;gap:var(--space-2);border:1px solid var(--glass-border-light);border-radius:var(--radius-full);font-size:var(--font-size-xs);background:#ffffff08;padding:4px 10px;display:flex}.cycle-badge-name{color:var(--text-primary);font-weight:var(--font-weight-medium);white-space:nowrap}.cycle-badge-label{color:var(--text-secondary);font-family:var(--font-mono);white-space:nowrap}.cycle-badge-bar{background:var(--surface-color-light);border-radius:var(--radius-full);width:40px;height:4px;overflow:hidden}.cycle-badge-fill{border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-out)}.cycle-alert-banner{justify-content:space-between;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-2);animation:fadeIn .3s var(--ease-out);display:flex}.cycle-alert-content{gap:var(--space-2);font-size:var(--font-size-sm);line-height:var(--line-height-normal);flex:1;align-items:flex-start;display:flex}.cycle-alert-dismiss{color:var(--text-tertiary);font-size:var(--font-size-lg);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;line-height:1}.cycle-alert-dismiss:hover{color:var(--text-primary)}.compound-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.compound-card-summary{cursor:pointer}.compound-expandable{transition:max-height var(--duration-slow) var(--ease-out)}.accordion-header{margin-top:var(--space-8);margin-bottom:var(--space-3);cursor:pointer;justify-content:space-between;align-items:center;display:flex}.accordion-body.collapsed{display:none}.cycle-timeline-row{margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--glass-border-light)}.cycle-timeline-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.cycle-timeline-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cycle-compound-title{align-items:center;gap:8px;display:flex}.cycle-compound-title strong{color:var(--text-primary);font-size:1.05rem}.cycle-compound-title.off-cycle strong{color:var(--text-secondary)}.cycle-progress-label{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:600}.cycle-progress-label.off-cycle{color:var(--text-secondary)}.cycle-meta-row{justify-content:space-between;align-items:flex-end;margin-top:4px;display:flex}.cycle-meta-info{flex-direction:column;gap:2px;display:flex}.cycle-timeline-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-weekday{text-align:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-tertiary);padding:var(--space-2) 0;text-transform:uppercase}#cal-days-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast);flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:4px;display:flex;position:relative}.calendar-day:hover{background:#ffffff0a}.calendar-day--today{border:2px solid var(--primary);box-shadow:0 0 8px rgba(var(--primary-rgb), .3)}.calendar-day--outside{pointer-events:none}.calendar-day--empty .calendar-day-num{color:var(--text-tertiary)}.calendar-day-num{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);line-height:1}.calendar-dots{flex-wrap:wrap;justify-content:center;gap:2px;min-height:6px;display:flex}.calendar-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.calendar-dot-overflow{color:var(--text-tertiary);font-size:8px;line-height:1}.log-item-card{background:var(--surface-color-light);border:1px solid var(--glass-border-light);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2);justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.log-item-card.missed{opacity:.6;background:#0003;border-style:dashed}.log-item-card.missed .log-item-name{text-decoration:line-through}.log-item-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes bottomSheetSlideUp{0%{opacity:0;transform:translateY(100%)}60%{opacity:1;transform:translateY(-3%)}80%{transform:translateY(1%)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}@keyframes checkboxPop{0%{transform:scale(1)}40%{transform:scale(1.2)}70%{transform:scale(.92)}to{transform:scale(1)}}@keyframes skeletonShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulseRing{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes breatheGlow{0%,to{box-shadow:0 0 20px rgba(var(--primary-rgb), .25)}50%{box-shadow:0 0 35px rgba(var(--primary-rgb), .4)}}@keyframes numberFlash{0%{color:var(--primary-light);transform:scale(1.05)}to{color:var(--text-primary);transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes cardEntrance{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.fade-in{animation:fadeIn .4s var(--ease-out) both}.scale-in{animation:scaleIn .35s var(--ease-out) both}.slide-in-right{animation:slideInRight .35s var(--ease-out) both}.stagger-enter>.card:first-child{animation:cardEntrance .4s var(--ease-out) 50ms both}.stagger-enter>.card:nth-child(2){animation:cardEntrance .4s var(--ease-out) .1s both}.stagger-enter>.card:nth-child(3){animation:cardEntrance .4s var(--ease-out) .15s both}.stagger-enter>.card:nth-child(4){animation:cardEntrance .4s var(--ease-out) .2s both}.stagger-enter>.card:nth-child(5){animation:cardEntrance .4s var(--ease-out) .25s both}.stagger-enter>.card:nth-child(n+6){animation:cardEntrance .4s var(--ease-out) .3s both}.glow{box-shadow:var(--shadow-glow);animation:3s ease-in-out infinite breatheGlow}.pulse{position:relative}.pulse:after{content:"";border-radius:inherit;background:var(--primary);pointer-events:none;width:100%;height:100%;animation:2s ease-out infinite pulseRing;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spinner{border:2.5px solid var(--glass-border-light);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.transition-all{transition:all var(--duration-normal) var(--ease-smooth)}.transition-fast{transition:all var(--duration-fast) var(--ease-smooth)}.transition-colors{transition:color var(--duration-normal), background-color var(--duration-normal), border-color var(--duration-normal)}@media (hover:hover){.hover-lift:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}}.press-active:active{transition:transform .1s var(--ease-out);transform:scale(.97)}
