@charset "UTF-8";@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap);@font-face{font-display:swap;font-family:Monument Extended;font-weight:400 900;src:local("Monument Extended"),local("MonumentExtended")}:root{--kyx-black:#090a0f;--kyx-carbon:#0d0e14;--kyx-slate:#13151c;--kyx-surface:#1a1c25;--kyx-elevated:#22252f;--kyx-hover:#2a2d38;--kyx-cyan:#00d8e0;--kyx-cyan-bright:#00f0f8;--kyx-cyan-dim:#00a8ae;--kyx-cyan-glow:#00d8e04d;--kyx-cyan-subtle:#00d8e01a;--kyx-violet:#a45cff;--kyx-violet-bright:#b87aff;--kyx-violet-dim:#8040d8;--kyx-violet-glow:#a45cff4d;--kyx-violet-subtle:#a45cff1a;--kyx-magenta:#ff3ef4;--kyx-magenta-bright:#ff6af7;--kyx-magenta-dim:#d830c8;--kyx-magenta-glow:#ff3ef44d;--kyx-success:#00e087;--kyx-success-dim:#00b86e;--kyx-success-glow:#00e0874d;--kyx-warning:#ffb020;--kyx-warning-dim:#e09d1c;--kyx-warning-glow:#ffb0204d;--kyx-danger:#ff4757;--kyx-danger-dim:#e03d4c;--kyx-danger-glow:#ff47574d;--kyx-info:#00d8e0;--kyx-text-primary:#f3f7fa;--kyx-text-secondary:#a0a8b8;--kyx-text-tertiary:#6b7280;--kyx-text-muted:#4a5160;--kyx-text-inverse:#090a0f;--kyx-border-subtle:#ffffff0f;--kyx-border-default:#ffffff1a;--kyx-border-strong:#ffffff26;--kyx-border-focus:var(--kyx-cyan);--bg-primary:var(--kyx-black);--bg-secondary:var(--kyx-carbon);--card-bg:var(--kyx-surface);--hover-bg:var(--kyx-hover);--bg-hover:var(--kyx-hover);--text-primary:var(--kyx-text-primary);--text-secondary:var(--kyx-text-secondary);--text-tertiary:var(--kyx-text-tertiary);--text-muted:var(--kyx-text-muted);--border-color:var(--kyx-border-default);--border-subtle:var(--kyx-border-subtle);--primary-color:var(--kyx-cyan);--primary-hover:var(--kyx-cyan-bright);--primary-text:var(--kyx-cyan);--primary-glow:var(--kyx-cyan-glow);--accent-color:var(--kyx-violet);--success-color:var(--kyx-success);--success-hover:var(--kyx-success-dim);--success-text:var(--kyx-success);--danger-color:var(--kyx-danger);--danger-hover:var(--kyx-danger-dim);--danger-text:var(--kyx-danger);--warning-color:var(--kyx-warning);--warning-hover:var(--kyx-warning-dim);--warning-text:var(--kyx-warning);--info-color:var(--kyx-info);--gradient-brand:linear-gradient(90deg,#00d8e0,#a45cff 50%,#ff3ef4);--gradient-cyan-violet:linear-gradient(135deg,#00d8e0,#a45cff);--gradient-glow:radial-gradient(ellipse at top,#00d8e026 0%,#0000 50%);--gradient-pk-curve:linear-gradient(90deg,#00d8e0,#a45cff 60%,#ff3ef4);--gradient-start:#00d8e0;--gradient-end:#a45cff;--shadow:0 1px 3px #0006,0 1px 2px #0000004d;--shadow-hover:0 4px 6px #0006,0 2px 4px #0000004d;--shadow-lg:0 10px 15px #0006,0 4px 6px #0000004d;--shadow-glow-cyan:0 0 20px var(--kyx-cyan-glow);--shadow-glow-violet:0 0 20px var(--kyx-violet-glow);--chart-grid:#ffffff14;--chart-text:var(--kyx-text-secondary);--chart-color-1:#00d8e0;--chart-color-2:#a45cff;--chart-color-3:#ff3ef4;--chart-color-4:#00e087;--chart-color-5:#ffb020;--chart-color-6:#00b8c0;--chart-color-7:#b87aff;--chart-color-8:#ff6af7;--scrollbar-track:var(--kyx-carbon);--scrollbar-thumb:var(--kyx-elevated);--scrollbar-thumb-hover:var(--kyx-hover);--font-display:"Monument Extended","Inter",system-ui,sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","SF Mono","Fira Code",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.5rem;--text-5xl:3.5rem;--text-display:4.5rem;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--font-extrabold:800;--leading-tight:1.1;--leading-snug:1.25;--leading-normal:1.5;--leading-relaxed:1.6;--tracking-tight:-0.02em;--tracking-normal:0;--tracking-wide:0.05em;--tracking-wider:0.1em;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-8:3rem;--space-10:4rem;--space-12:5rem;--space-16:8rem;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--transition-fast:0.15s ease;--transition-normal:0.2s ease;--transition-slow:0.3s ease;--transition-slower:0.5s ease;--z-dropdown:100;--z-sticky:200;--z-overlay:500;--z-modal:1000;--z-toast:9999;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}[data-theme=light]{--kyx-black:#f8fafc;--kyx-carbon:#f1f5f9;--kyx-slate:#e2e8f0;--kyx-surface:#fff;--kyx-elevated:#fff;--kyx-hover:#f1f5f9;--kyx-text-primary:#0f172a;--kyx-text-secondary:#475569;--kyx-text-tertiary:#64748b;--kyx-text-muted:#94a3b8;--kyx-text-inverse:#f8fafc;--kyx-cyan:#0891b2;--kyx-cyan-bright:#06b6d4;--kyx-cyan-dim:#0e7490;--kyx-cyan-glow:#0891b233;--kyx-cyan-subtle:#0891b214;--kyx-violet:#7c3aed;--kyx-violet-bright:#8b5cf6;--kyx-violet-dim:#6d28d9;--kyx-success:#059669;--kyx-warning:#d97706;--kyx-danger:#dc2626;--kyx-border-subtle:#0000000a;--kyx-border-default:#00000014;--kyx-border-strong:#0000001f;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-hover:0 4px 6px #0000001a,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--shadow-glow-cyan:0 0 20px #0891b226;--shadow-glow-violet:0 0 20px #7c3aed26;--chart-grid:#0000000f;--chart-text:var(--kyx-text-secondary);--chart-color-1:#0891b2;--chart-color-2:#7c3aed;--chart-color-3:#db2777;--chart-color-4:#059669;--chart-color-5:#d97706;--scrollbar-track:var(--kyx-slate);--scrollbar-thumb:#cbd5e1;--scrollbar-thumb-hover:#94a3b8}@media (prefers-color-scheme:light){[data-theme=system]{--kyx-black:#f8fafc;--kyx-carbon:#f1f5f9;--kyx-slate:#e2e8f0;--kyx-surface:#fff;--kyx-elevated:#fff;--kyx-hover:#f1f5f9;--kyx-text-primary:#0f172a;--kyx-text-secondary:#475569;--kyx-text-tertiary:#64748b;--kyx-text-muted:#94a3b8;--kyx-text-inverse:#f8fafc;--kyx-cyan:#0891b2;--kyx-cyan-bright:#06b6d4;--kyx-cyan-dim:#0e7490;--kyx-cyan-glow:#0891b233;--kyx-cyan-subtle:#0891b214;--kyx-violet:#7c3aed;--kyx-violet-bright:#8b5cf6;--kyx-violet-dim:#6d28d9;--kyx-success:#059669;--kyx-warning:#d97706;--kyx-danger:#dc2626;--kyx-border-subtle:#0000000a;--kyx-border-default:#00000014;--kyx-border-strong:#0000001f;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-hover:0 4px 6px #0000001a,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--shadow-glow-cyan:0 0 20px #0891b226;--shadow-glow-violet:0 0 20px #7c3aed26;--chart-grid:#0000000f;--chart-text:var(--kyx-text-secondary);--scrollbar-track:var(--kyx-slate);--scrollbar-thumb:#cbd5e1;--scrollbar-thumb-hover:#94a3b8}}.btn-kyx-primary{background:#00d8e0;background:var(--kyx-cyan);border:none;border-radius:12px;border-radius:var(--radius-lg);color:#090a0f;color:var(--kyx-text-inverse);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-weight:600;font-weight:var(--font-semibold);padding:12px 24px;transition:all .2s ease;transition:all var(--transition-normal)}.btn-kyx-primary:hover{background:#00f0f8;background:var(--kyx-cyan-bright);box-shadow:0 0 20px #00d8e04d;box-shadow:var(--shadow-glow-cyan)}.btn-kyx-secondary{background:#0000;border:1px solid #00d8e0;border:1px solid var(--kyx-cyan);border-radius:12px;border-radius:var(--radius-lg);color:#00d8e0;color:var(--kyx-cyan);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-weight:600;font-weight:var(--font-semibold);padding:12px 24px;transition:all .2s ease;transition:all var(--transition-normal)}.btn-kyx-secondary:hover{background:#00d8e01a;background:var(--kyx-cyan-subtle);box-shadow:0 0 20px #00d8e04d;box-shadow:var(--shadow-glow-cyan)}.btn-kyx-ghost{background:#0000;border:none;border-radius:12px;border-radius:var(--radius-lg);color:#a0a8b8;color:var(--kyx-text-secondary);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-weight:500;font-weight:var(--font-medium);padding:12px 24px;transition:all .2s ease;transition:all var(--transition-normal)}.btn-kyx-ghost:hover{background:#2a2d38;background:var(--kyx-hover);color:#f3f7fa;color:var(--kyx-text-primary)}.card-kyx{background:#1a1c25;background:var(--kyx-surface);border:1px solid #ffffff1a;border:1px solid var(--kyx-border-default);border-radius:16px;border-radius:var(--radius-xl);overflow:hidden;padding:1.5rem;padding:var(--space-5);position:relative}.card-kyx:before{background:linear-gradient(135deg,#00d8e0,#a45cff);background:var(--gradient-cyan-violet);content:"";height:1px;left:0;opacity:.5;position:absolute;right:0;top:0}.input-kyx{background:#0d0e14;background:var(--kyx-carbon);border:1px solid #ffffff1a;border:1px solid var(--kyx-border-default);border-radius:8px;border-radius:var(--radius-md);color:#f3f7fa;color:var(--kyx-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--text-base);padding:12px 16px;transition:all .2s ease;transition:all var(--transition-normal)}.input-kyx:focus{border-color:#00d8e0;border-color:var(--kyx-cyan);box-shadow:0 0 0 3px #00d8e01a;box-shadow:0 0 0 3px var(--kyx-cyan-subtle);outline:none}.input-kyx::placeholder{color:#4a5160;color:var(--kyx-text-muted)}.badge-kyx{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);gap:6px;padding:4px 10px}.badge-kyx-cyan{background:#00d8e01a;background:var(--kyx-cyan-subtle);color:#00d8e0;color:var(--kyx-cyan)}.badge-kyx-violet{background:#a45cff1a;background:var(--kyx-violet-subtle);color:#a45cff;color:var(--kyx-violet)}.badge-kyx-success{background:#00e0871a;color:#00e087;color:var(--kyx-success)}.badge-kyx-warning{background:#ffb0201a;color:#ffb020;color:var(--kyx-warning)}.badge-kyx-danger{background:#ff47571a;color:#ff4757;color:var(--kyx-danger)}.metric-kyx{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-family:var(--font-mono);font-weight:600;font-weight:var(--font-semibold);letter-spacing:-.02em;letter-spacing:var(--tracking-tight)}.metric-kyx-lg{font-size:2.5rem;font-size:var(--text-4xl)}.metric-kyx-md{font-size:1.5rem;font-size:var(--text-2xl)}.metric-kyx-sm{font-size:1.125rem;font-size:var(--text-lg)}.unit-kyx{color:#6b7280;color:var(--kyx-text-tertiary);font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:.6em;margin-left:4px}.heading-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#00d8e0,#a45cff 50%,#ff3ef4);background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text}.text-glow-cyan{text-shadow:0 0 20px #00d8e04d;text-shadow:0 0 20px var(--kyx-cyan-glow)}.text-glow-violet{text-shadow:0 0 20px #a45cff4d;text-shadow:0 0 20px var(--kyx-violet-glow)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);line-height:var(--leading-normal)}code{font-family:var(--font-mono)}.loading{align-items:center;color:var(--text-secondary);display:flex;font-size:1.2rem;justify-content:center;padding:2rem}.error{padding:1rem;text-align:center}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.card{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-hover)}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:space-between;margin-bottom:var(--space-xl)}.page-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);margin:0}.page-header h1,.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}.text-warning{color:var(--warning-color)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.icon-button,.touch-target{align-items:center;display:inline-flex;justify-content:center;min-height:44px;min-width:44px}.icon-button{background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;padding:10px;transition:all var(--transition-fast)}.icon-button:hover{background:var(--hover-bg);color:var(--text-primary)}.icon-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}[role=button],a,button,input[type=checkbox],input[type=radio],select{min-height:44px}a.inline-link{min-height:auto}@media (max-width:639px){.btn,[role=button],button{min-height:48px;padding:12px 16px}.icon-button{min-height:48px;min-width:48px}}.skip-link{background:var(--primary-color);border-radius:var(--radius-md);color:#fff;left:50%;padding:12px 24px;position:absolute;top:-100px;transform:translateX(-50%);transition:top .2s;z-index:10000}.skip-link:focus{top:16px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){:root{--kyx-text-primary:#fff;--kyx-text-secondary:#e5e5e5;--kyx-border-default:#ffffff4d;--kyx-surface:#000;--text-primary:#fff;--text-secondary:#e5e5e5;--border-color:#ffffff4d;--card-bg:#000}}label{color:var(--text-primary);display:block;font-weight:var(--font-medium);margin-bottom:var(--space-xs)}.required:after{color:var(--danger-color);content:" *"}.input-error{border-color:var(--danger-color)!important}.error-message{font-size:var(--text-sm);margin-top:var(--space-xs)}.visually-hidden{clip:rect(0,0,0,0)!important;border:0!important;height:1px!important;margin:-1px!important;overflow:hidden!important;padding:0!important;position:absolute!important;white-space:nowrap!important;width:1px!important}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:.5rem;justify-content:center;overflow:hidden;position:relative;text-decoration:none;transition:all .2s ease;white-space:nowrap}.btn:focus{box-shadow:0 0 0 3px var(--blue-4);outline:none}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.btn-small{font-size:.875rem;min-height:36px;padding:.5rem 1rem}.btn-medium{font-size:.95rem;min-height:44px;padding:.75rem 1.5rem}.btn-large{font-size:1rem;min-height:52px;padding:1rem 2rem}.btn-primary{box-shadow:var(--shadow)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--hover-bg)}.btn-secondary:hover:not(:disabled){background:var(--border-color);border-color:var(--text-secondary)}.btn-danger{background:var(--danger-color);box-shadow:var(--shadow);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.btn-success{background:var(--success-color);box-shadow:var(--shadow)}.btn-success:hover:not(:disabled){background:var(--success-hover);transform:translateY(-2px)}.btn-ghost{background:#0000;color:var(--primary-color)}.btn-ghost:hover:not(:disabled){background:var(--blue-3)}.btn-link{background:#0000;min-height:auto;padding:.25rem .5rem;text-decoration:underline}.btn-link:hover:not(:disabled){color:var(--primary-hover);text-decoration:none}.btn-link:focus{box-shadow:none}.btn-full-width{width:100%}.btn-icon-only{aspect-ratio:1;padding:.75rem}.btn-icon-only.btn-small{padding:.5rem}.btn-icon-only.btn-large{padding:1rem}.btn-icon{align-items:center;display:flex;font-size:1.1em;justify-content:center}.btn-loading .btn-text{opacity:.7}.btn-spinner{animation:btn-spin .8s linear infinite;height:1.2em;width:1.2em}.btn-spinner svg{height:100%;width:100%}@keyframes btn-spin{to{transform:rotate(1turn)}}.btn-group{display:flex;flex-wrap:wrap;gap:.75rem}.btn-group-tight{gap:.5rem}[data-theme=dark] .btn-secondary{background:var(--slate-3);border-color:var(--border-color)}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:var(--slate-4)}[data-theme=dark] .btn-ghost:hover:not(:disabled){background:var(--blue-4)}@media (max-width:480px){.btn-medium{font-size:.9rem;padding:.65rem 1.25rem}.btn-large{font-size:.95rem;padding:.875rem 1.5rem}}.toast-container{bottom:var(--space-xl);flex-direction:column;max-width:400px;pointer-events:none;position:fixed;right:var(--space-xl);z-index:9999}.toast,.toast-container{display:flex;gap:var(--space-sm)}.toast{align-items:flex-start;animation:toast-slide-in var(--transition-normal);background:var(--card-bg);border-left:4px solid;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-md);pointer-events:all}@keyframes toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-success{border-left-color:var(--success-color)}.toast-success .toast-icon{background:var(--green-3);color:var(--success-color)}.toast-error{border-left-color:var(--danger-color)}.toast-error .toast-icon{background:var(--red-3);color:var(--danger-color)}.toast-warning{border-left-color:var(--warning-color)}.toast-warning .toast-icon{background:var(--amber-3);color:var(--amber-11)}.toast-info{border-left-color:var(--info-color)}.toast-info .toast-icon{background:var(--blue-3);color:var(--info-color)}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}.toast-content{flex:1 1;min-width:0}.toast-title{color:var(--text-primary);display:block;font-size:.95rem;margin-bottom:4px}.toast-message{word-wrap:break-word;color:var(--text-secondary);font-size:.875rem;line-height:1.4;margin:0}.toast-close{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:24px;justify-content:center;margin:-4px -4px -4px 0;transition:all .2s;width:24px}.toast-close:hover{background:var(--hover-bg);color:var(--text-primary)}[data-theme=dark] .toast{box-shadow:var(--shadow-lg)}@media (max-width:480px){.toast-container{bottom:16px;left:16px;max-width:none;right:16px}.toast{padding:14px}.toast-icon{font-size:12px;height:24px;width:24px}}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.loading-full-page{min-height:60vh}.loading-overlay{background:#ffffffe6;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}[data-theme=dark] .loading-overlay{background:#1a1a2ee6}.loading-spinner{animation:rotate 1.4s linear infinite}.loading-spinner svg{display:block}.loading-spinner circle{stroke:var(--primary-color);stroke-dasharray:80,200;stroke-dashoffset:0;animation:dash 1.4s ease-in-out infinite}@keyframes rotate{to{transform:rotate(1turn)}}@keyframes dash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}to{stroke-dasharray:89,200;stroke-dashoffset:-124}}.loading-small .loading-spinner{height:24px;width:24px}.loading-small .loading-text{font-size:.875rem}.loading-medium .loading-spinner{height:40px;width:40px}.loading-medium .loading-text{font-size:1rem}.loading-large .loading-spinner{height:56px;width:56px}.loading-large .loading-text{font-size:1.125rem}.loading-text{color:var(--text-secondary);font-weight:500;margin:0}.skeleton{background:linear-gradient(90deg,var(--hover-bg) 25%,var(--border-color) 50%,var(--hover-bg) 75%)}.skeleton-card{border-radius:12px;box-shadow:0 2px 8px var(--shadow);display:flex;flex-direction:column;gap:.75rem;padding:1.25rem}.skeleton-row td{padding:1rem}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a 50%,#ffffff0d 75%);background-size:200% 100%}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem}.empty-state-small{padding:1.5rem 1rem}.empty-state-small .empty-state-icon{height:48px;margin-bottom:.75rem;width:48px}.empty-state-small .empty-state-title{font-size:1rem}.empty-state-small .empty-state-description{font-size:.8rem}.empty-state-medium .empty-state-icon{height:72px;margin-bottom:1rem;width:72px}.empty-state-medium .empty-state-title{font-size:1.25rem}.empty-state-large .empty-state-icon{height:96px;margin-bottom:1.5rem;width:96px}.empty-state-large .empty-state-title{font-size:1.5rem}.empty-state-large .empty-state-description{font-size:1rem}.empty-state-icon{color:var(--text-secondary);opacity:.5;transition:all .3s ease}.empty-state-icon svg{height:100%;width:100%}.empty-state-title{color:var(--text-primary);font-weight:600;margin:0 0 .5rem}.empty-state-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 1.5rem;max-width:300px}.empty-state-action{align-items:center;background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease}.empty-state-action:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.empty-state:hover .empty-state-icon{opacity:.7;transform:scale(1.05)}.empty-state-card{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--shadow)}.empty-state-inline{flex-direction:row;gap:1rem;padding:1rem;text-align:left}.empty-state-inline .empty-state-icon{height:40px;margin-bottom:0;width:40px}.empty-state-inline .empty-state-description{margin-bottom:0}.modal-overlay{animation:fadeIn .15s ease-out;padding:var(--space-md,1rem);z-index:var(--z-modal,1000)}.modal{animation:slideUp .2s ease-out;background:#fff;background:var(--card-bg,#fff);border-radius:12px;border-radius:var(--radius-lg,12px);box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:calc(100vh - 2rem);overflow:hidden}.modal-small{max-width:400px;width:100%}.modal-medium{max-width:600px;width:100%}.modal-large{max-width:900px;width:100%}.modal-fullscreen{height:calc(100vh - 2rem);max-width:none;width:calc(100vw - 2rem)}.modal-header{border-bottom:1px solid #ddd;border-bottom:1px solid var(--border-color,#ddd);padding:var(--space-lg,1.5rem)}.modal-title{color:#2c3e50;color:var(--text-primary,#2c3e50);font-size:1.25rem;font-size:var(--text-xl,1.25rem);font-weight:600;font-weight:var(--font-semibold,600);margin:0}.modal-close-btn{align-items:center;border-radius:4px;border-radius:var(--radius-sm,4px);color:#7f8c8d;color:var(--text-secondary,#7f8c8d);display:flex;justify-content:center;padding:.25rem;padding:var(--space-xs,.25rem);transition:color .15s ease,background-color .15s ease}.modal-close-btn:hover{background-color:#f8f9fa;background-color:var(--hover-bg,#f8f9fa);color:#2c3e50;color:var(--text-primary,#2c3e50)}.modal-body{flex:1 1;overflow-y:auto;padding:1.5rem;padding:var(--space-lg,1.5rem)}.modal-footer{align-items:center;background:#f8f9fa;background:var(--bg-secondary,#f8f9fa);border-top:1px solid #ddd;border-top:1px solid var(--border-color,#ddd);display:flex;gap:.5rem;gap:var(--space-sm,.5rem);justify-content:flex-end;padding:1rem 1.5rem;padding:var(--space-md,1rem) var(--space-lg,1.5rem)}.modal-danger .modal-header{background:#dc3545;background:var(--danger-color,#dc3545);border-bottom:none;color:#fff}.modal-danger .modal-title{color:#fff}.modal-danger .modal-close-btn{color:#fffc}.modal-danger .modal-close-btn:hover{background-color:#ffffff1a;color:#fff}.modal-warning .modal-header{background:#ffc107;background:var(--warning-color,#ffc107);border-bottom:none}.confirm-dialog{align-items:center;display:flex;flex-direction:column;padding:1rem;padding:var(--space-md,1rem);text-align:center}.confirm-icon{margin-bottom:1rem;margin-bottom:var(--space-md,1rem)}.confirm-icon.danger{color:#dc3545;color:var(--danger-color,#dc3545)}.confirm-icon.warning{color:#ffc107;color:var(--warning-color,#ffc107)}.confirm-icon.success{color:#28a745;color:var(--success-color,#28a745)}.confirm-icon.info{color:#17a2b8;color:var(--info-color,#17a2b8)}.confirm-icon.default{color:#667eea;color:var(--primary-color,#667eea)}.confirm-title{color:#2c3e50;color:var(--text-primary,#2c3e50);font-size:1.125rem;font-size:var(--text-lg,1.125rem);font-weight:600;font-weight:var(--font-semibold,600);margin:0 0 .5rem;margin:0 0 var(--space-sm,.5rem) 0}.confirm-message{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);line-height:1.5;margin:0 0 1.5rem;margin:0 0 var(--space-lg,1.5rem) 0}.confirm-actions{gap:.5rem;gap:var(--space-sm,.5rem);width:100%}.confirm-actions .btn{border-radius:var(--radius-md,8px);font-weight:var(--font-medium,500);padding:.5rem 1rem;padding:var(--space-sm,.5rem) var(--space-md,1rem);transition:transform .15s ease,box-shadow .15s ease}.confirm-actions .btn:hover:not(:disabled){transform:translateY(-1px)}.confirm-actions .btn:disabled{cursor:not-allowed;opacity:.6}.confirm-actions .btn-secondary{background:#f8f9fa;background:var(--bg-secondary,#f8f9fa);border:1px solid #ddd;border:1px solid var(--border-color,#ddd);color:#2c3e50;color:var(--text-primary,#2c3e50)}.confirm-actions .btn-secondary:hover:not(:disabled){background:#e9ecef;background:var(--hover-bg,#e9ecef)}.confirm-actions .btn-primary{background:#667eea;background:var(--primary-color,#667eea)}.confirm-actions .btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea40}.confirm-actions .btn-danger{background:#dc3545;background:var(--danger-color,#dc3545);border:none;color:#fff}.confirm-actions .btn-danger:hover:not(:disabled){box-shadow:0 4px 12px #dc354540}@media (max-width:640px){.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:12px 12px 0 0;border-radius:var(--radius-lg,12px) var(--radius-lg,12px) 0 0;max-height:90vh;width:100%}.modal,.modal-large,.modal-medium,.modal-small{max-width:none}.confirm-actions{flex-direction:column-reverse}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{border:0;-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;line-height:normal;position:relative}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{line-height:0;z-index:1}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}h2.react-datepicker__current-month{margin:0;padding:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.3rem;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.3rem;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.3rem;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + .85rem);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;text-align:center;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__day--disabled,.react-datepicker__day-name--disabled,.react-datepicker__time-name--disabled{color:#ccc;cursor:default}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{background-color:#333;border-radius:4px;bottom:70%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__input-container{display:inline-block;position:relative;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.5rem;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:3rem;width:3rem}@media (max-height:550px),(max-width:400px){.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:2rem;width:2rem}}.react-datepicker__portal .react-datepicker-time__header,.react-datepicker__portal .react-datepicker__current-month{font-size:1.44rem}.react-datepicker__children-container{height:auto;margin:.4rem;padding-left:.2rem;padding-right:.2rem;width:13.8rem}.react-datepicker__aria-live{border:0;-webkit-clip-path:circle(0);clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.datetime-picker-wrapper{width:100%}.datetime-picker-wrapper label{color:var(--text-primary);display:block;font-weight:500;margin-bottom:.5rem}.datetime-picker-input{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;gap:10px;min-height:44px;padding:10px 14px;text-align:left;transition:all .2s ease;width:100%}.datetime-picker-input:hover{background:var(--hover-bg);border-color:var(--primary-color)}.datetime-picker-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea33;outline:none}.datetime-picker-input.has-error{border-color:var(--danger-color)}.datetime-picker-input.has-error:focus{box-shadow:0 0 0 3px #dc354533}.datetime-icon{color:var(--primary-color);flex-shrink:0}.datetime-value{flex:1 1}.datetime-clock{color:var(--text-secondary);flex-shrink:0}.quick-time-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.quick-time-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;min-height:36px;padding:6px 12px;transition:all .2s ease}.quick-time-btn:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--primary-color)}.quick-time-btn.primary{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.quick-time-btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.datetime-error{color:var(--danger-color);display:block;font-size:.85rem;margin-top:4px}.datetime-picker-popper{z-index:var(--z-modal)!important}.datetime-calendar{background:var(--card-bg)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-lg)!important;box-shadow:0 10px 40px #00000026!important;font-family:inherit!important}.react-datepicker__header{background:var(--bg-secondary)!important;border-bottom:1px solid var(--border-color)!important;padding-top:12px!important}.react-datepicker-time__header,.react-datepicker__current-month{color:var(--text-primary)!important;font-weight:600!important}.react-datepicker__day-name{color:var(--text-secondary)!important;font-weight:500!important}.react-datepicker__day{border-radius:var(--radius-md)!important;color:var(--text-primary)!important}.react-datepicker__day:hover{background:var(--hover-bg)!important}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected{background:var(--primary-color)!important;color:#fff!important}.react-datepicker__day--today{border:1px solid var(--primary-color)!important;font-weight:700!important}.react-datepicker__day--disabled{color:var(--text-muted)!important}.react-datepicker__time-container{border-left:1px solid var(--border-color)!important}.react-datepicker__time-list-item{color:var(--text-primary)!important}.react-datepicker__time-list-item:hover{background:var(--hover-bg)!important}.react-datepicker__time-list-item--selected{background:var(--primary-color)!important;color:#fff!important}.react-datepicker__navigation-icon:before{border-color:var(--text-secondary)!important}.react-datepicker__navigation:hover :before{border-color:var(--text-primary)!important}.preset-time-picker{width:100%}.preset-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.preset-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;min-height:36px;padding:8px 12px;transition:all .2s ease}.preset-btn:hover{background:#667eea1a;border-color:var(--primary-color);color:var(--primary-color)}[data-theme=dark] .datetime-calendar{box-shadow:0 10px 40px #0006!important}[data-theme=dark] .react-datepicker__day:hover,[data-theme=dark] .react-datepicker__time-list-item:hover{background:var(--hover-bg)!important;color:var(--text-primary)!important}@media (max-width:639px){.quick-time-actions{gap:6px}.quick-time-btn{flex:1 1;min-height:40px;min-width:70px;padding:8px 10px}.preset-buttons{gap:4px}.preset-btn{flex:1 1;font-size:.75rem;min-width:80px;padding:8px}.react-datepicker{display:flex;flex-direction:column}.react-datepicker__time-container{border-left:none!important;border-top:1px solid var(--border-color)!important;width:100%!important}}.responsive-table-wrapper{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:0 1px 3px var(--shadow);overflow-x:auto}.responsive-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.responsive-table thead{background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.responsive-table th{font-weight:var(--font-semibold);text-align:left;white-space:nowrap}.responsive-table td,.responsive-table th{color:var(--text-primary);padding:14px 16px}.responsive-table td{border-bottom:1px solid var(--border-color)}.responsive-table tbody tr:last-child td{border-bottom:none}.responsive-table tbody tr:hover{background:var(--hover-bg)}.responsive-table tbody tr.clickable{cursor:pointer}.responsive-table .actions-cell{text-align:right;white-space:nowrap}.responsive-card-list{display:flex;flex-direction:column;gap:12px}.responsive-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:0 1px 3px var(--shadow);padding:16px;transition:all var(--transition-fast)}.responsive-card.clickable{cursor:pointer}.responsive-card.clickable:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-1px)}.responsive-card.clickable:focus{outline:2px solid var(--primary-color);outline-offset:2px}.responsive-card-row{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:8px 0}.responsive-card-row:last-of-type{border-bottom:none}.responsive-card-label{color:var(--text-secondary);flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.5px;margin-right:16px;text-transform:uppercase}.responsive-card-value{color:var(--text-primary);font-size:var(--text-sm);text-align:right;word-break:break-word}.responsive-card-actions{border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px}.responsive-table-empty{background:var(--card-bg);border-radius:var(--radius-lg);color:var(--text-secondary);padding:48px 24px;text-align:center}.responsive-table-empty p{font-size:var(--text-base);margin:0}[data-theme=dark] .responsive-table thead{background:var(--bg-primary)}[data-theme=dark] .responsive-card{box-shadow:0 2px 8px #0000004d}.chart-data-table{margin-top:16px}.chart-data-toggle{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);gap:8px;padding:10px 16px;text-align:left;transition:all var(--transition-fast);width:100%}.chart-data-toggle:hover{background:var(--hover-bg);border-color:var(--primary-color);color:var(--text-primary)}.chart-data-toggle:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.chart-data-toggle span{flex:1 1}.chart-data-content{border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:12px;overflow:hidden}.chart-data-content table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.chart-data-content thead{background:var(--bg-secondary);position:-webkit-sticky;position:sticky;top:0}.chart-data-content td,.chart-data-content th{border-bottom:1px solid var(--border-color);padding:10px 12px;text-align:left}.chart-data-content th{color:var(--text-primary);font-weight:var(--font-semibold);white-space:nowrap}.chart-data-content td{color:var(--text-secondary)}.chart-data-content tbody tr:last-child td,.chart-data-content tbody tr:last-child th{border-bottom:none}.chart-data-content tbody tr:hover{background:var(--hover-bg)}.chart-data-note{background:var(--bg-secondary);border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:var(--text-sm);margin:0;padding:12px;text-align:center}.chart-summary{margin-top:8px}.chart-summary h3{font-size:var(--text-base);margin:0 0 8px}.chart-summary ul{list-style:none;margin:0;padding:0}.chart-summary li{margin-bottom:4px}@media (max-width:639px){.chart-data-content{max-height:300px;overflow-x:auto}.chart-data-content table{min-width:400px}.chart-data-content td,.chart-data-content th{font-size:var(--text-xs);padding:8px 10px}}[data-theme=dark] .chart-data-content thead,[data-theme=dark] .chart-data-toggle{background:var(--bg-primary)}.form-field{flex-direction:column;margin-bottom:var(--space-md)}.form-field,.form-field__label{display:flex;gap:var(--space-xs)}.form-field__label{align-items:center;color:var(--text-primary);font-size:.875rem;font-weight:500}.form-field__required{color:var(--error);font-weight:600}.form-field__control{position:relative}.form-field__control input,.form-field__control select,.form-field__control textarea{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;padding:var(--space-sm) var(--space-md);transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-field__control input:focus,.form-field__control select:focus,.form-field__control textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126;outline:none}.form-field--error .form-field__control input,.form-field--error .form-field__control select,.form-field--error .form-field__control textarea{border-color:var(--error)}.form-field--error .form-field__control input:focus,.form-field--error .form-field__control select:focus,.form-field--error .form-field__control textarea:focus{box-shadow:0 0 0 3px #ef444426}.form-field__error{align-items:center;animation:shake .3s ease;color:var(--error);display:flex;font-size:.8125rem;font-weight:500;gap:var(--space-xs)}.form-field__help{color:var(--text-tertiary);font-size:.8125rem}.form-row{grid-gap:var(--space-md);gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}@media (max-width:639px){.form-row{grid-template-columns:1fr}}.form-actions{border-top:1px solid var(--border-color);gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-md)}.form-actions--left{justify-content:flex-start}.form-actions--center{justify-content:center}.form-actions--right{justify-content:flex-end}.form-actions--space-between{justify-content:space-between}.form-error,.form-success{align-items:center;border-radius:var(--radius-md);display:flex;font-size:.875rem;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md)}.form-error{background:#ef44441a;border:1px solid #ef44444d;color:var(--error)}.form-success{background:#22c55e1a;border:1px solid #22c55e4d;color:var(--success)}.form-error__icon,.form-success__icon{flex-shrink:0;height:1.25rem;width:1.25rem}@keyframes shake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}.form-field__control input::placeholder,.form-field__control textarea::placeholder{color:var(--text-tertiary);opacity:.7}.form-field__control select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right var(--space-sm) center;background-repeat:no-repeat;background-size:1.25rem;padding-right:var(--space-xl)}.form-field__control textarea{min-height:80px;resize:vertical}.form-field__control input[type=number]::-webkit-inner-spin-button,.form-field__control input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.form-field__control input[type=number]{-moz-appearance:textfield}[data-theme=dark] .form-field__control select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%9ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E")}.dashboard-skeleton{margin:0 auto;max-width:1400px;padding:var(--space-lg)}.skeleton-hero{margin-bottom:var(--space-xl)}.skeleton-hero-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--space-lg)}.skeleton-hero-title{flex:1 1}.skeleton-hero-stats{display:flex;gap:var(--space-md)}.skeleton-chart{margin-bottom:var(--space-lg)}.skeleton-level-cards{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(4,1fr)}.skeleton-quick-actions{margin-bottom:var(--space-xl)}.skeleton-action-buttons{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.skeleton-rituals{margin-bottom:var(--space-xl)}.skeleton-ritual-cards{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(2,1fr);margin-top:var(--space-md)}.skeleton-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(3,1fr)}.skeleton-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:0 1px 3px var(--shadow)}.doses-skeleton,.skeleton-card{padding:var(--space-lg)}.skeleton-page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-xl)}.skeleton-dose-list{display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-dose-item{align-items:center;background:var(--card-bg);border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--space-lg)}.skeleton-dose-info{flex:1 1}.skeleton-dose-actions{display:flex;gap:var(--space-sm)}.visualization-skeleton{padding:var(--space-lg)}.skeleton-controls{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.skeleton-main-chart{margin-bottom:var(--space-xl)}.profile-skeleton{margin:0 auto;max-width:800px;padding:var(--space-lg)}.skeleton-profile-header{margin-bottom:var(--space-xl);text-align:center}.skeleton-avatar{margin:0 auto var(--space-md)}.skeleton-tabs{border-bottom:1px solid var(--border-color);display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);padding-bottom:var(--space-md)}.skeleton-form{display:flex;flex-direction:column;gap:var(--space-lg)}.skeleton-form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.page-skeleton{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:var(--space-xl)}.page-skeleton-content{text-align:center}@media (max-width:1023px){.skeleton-grid,.skeleton-level-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:639px){.skeleton-hero-header{flex-direction:column;gap:var(--space-md)}.skeleton-hero-stats{justify-content:space-between;width:100%}.skeleton-grid,.skeleton-level-cards,.skeleton-ritual-cards{grid-template-columns:1fr}.skeleton-action-buttons{flex-wrap:wrap}.skeleton-controls{flex-direction:column}.skeleton-tabs{overflow-x:auto}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{animation:skeleton-pulse 1.5s ease-in-out infinite;animation:skeleton-shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--border-color) 0,var(--hover-bg) 50%,var(--border-color) 100%);background-size:200% 100%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.auth-container{align-items:center;background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);display:flex;justify-content:center;min-height:100vh;transition:all .3s ease}.auth-card{background:var(--card-bg);border-radius:12px;box-shadow:0 10px 40px var(--shadow-hover);max-width:420px;padding:2.5rem;transition:all .3s ease;width:100%}.auth-card h1{color:var(--text-primary);font-size:1.8rem;margin-bottom:.5rem}.auth-card h1,.auth-card h2{text-align:center;transition:color .3s ease}.auth-card h2{color:var(--text-secondary);font-size:1.2rem;font-weight:400;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-primary);display:block;margin-bottom:.5rem;transition:color .3s ease}.form-group input{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.form-group input:focus{border-color:var(--primary-color);outline:none}.form-group input:disabled{background-color:var(--hover-bg);cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);border-radius:6px;font-size:1rem;font-weight:600;padding:.875rem;transition:all .3s ease;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.error-message{background-color:#fee;border-left:4px solid var(--danger-color);color:var(--danger-color);margin-bottom:1.5rem;padding:.75rem;transition:all .3s ease}.auth-link{color:var(--text-secondary);margin-top:1.5rem;text-align:center}.auth-link,.auth-link a{transition:color .3s ease}.auth-link a{color:var(--primary-color);font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.forgot-password-link{margin-top:.5rem;text-align:right}.forgot-password-link a{color:var(--primary-color);font-size:.875rem;text-decoration:none;transition:color .3s ease}.forgot-password-link a:hover{text-decoration:underline}.auth-description{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin-bottom:1.5rem;text-align:center}.auth-button{background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.875rem;text-align:center;text-decoration:none;transition:all .3s ease;width:100%}.auth-button:hover:not(:disabled){box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.6}.success-message{margin-bottom:1.5rem;padding:1.5rem;text-align:center}.error-message .error-icon,.success-message .success-icon{display:block;margin:0 auto 1rem}.error-message p,.success-message p{color:var(--text-secondary);line-height:1.6;margin:0}.form-hint{color:var(--text-muted);display:block;font-size:.8rem;margin-top:.5rem}.loading-spinner{margin:2rem auto}.auth-links{margin-top:1.5rem;text-align:center}.auth-links .auth-link{display:block;margin-top:.75rem}.auth-links .auth-link.primary{background:var(--primary-color);border-radius:6px;color:#fff;display:inline-block;font-weight:500;margin-bottom:1rem;padding:.75rem 1.5rem;text-decoration:none}.auth-links .auth-link.primary:hover{background:var(--primary-hover);text-decoration:none}.info-message{background-color:#eff6ff;background-color:var(--info-bg,#eff6ff);border-left:4px solid #3b82f6;border-left:4px solid var(--info-color,#3b82f6);border-radius:6px;color:#1e40af;color:var(--info-color,#1e40af);margin-bottom:1.5rem;padding:.75rem}.two-factor-actions{display:flex;justify-content:space-between;margin-bottom:1rem}.btn-link{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.875rem;padding:0;text-decoration:none}.btn-link:hover{text-decoration:underline}.btn-link:disabled{cursor:not-allowed;opacity:.6}.help-text{color:var(--text-muted);display:block;font-size:.8rem;margin-top:.5rem}.auth-divider{align-items:center;display:flex;margin:1.25rem 0}.auth-divider:after,.auth-divider:before{background-color:var(--border-color);content:"";flex:1 1;height:1px}.auth-divider span{color:var(--text-muted);font-size:.875rem;padding:0 1rem;text-transform:uppercase}.btn-secondary{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:.875rem;transition:all .3s ease;width:100%}.btn-secondary:hover:not(:disabled){background:var(--hover-bg);border-color:var(--primary-color)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.passkey-btn .passkey-icon{font-size:1.1rem}@media (max-width:480px){.auth-card{margin:1rem;padding:1.5rem}.auth-card h1{font-size:1.6rem}.auth-card h2{font-size:1.1rem}.btn-primary,.form-group input{font-size:.95rem}.btn-primary{min-height:44px}}@media (max-width:360px){.auth-card{margin:.75rem;padding:1.25rem}.auth-card h1{font-size:1.5rem}.auth-card h2{font-size:1rem;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group input{font-size:.9rem;padding:.65rem}.btn-primary{font-size:.9rem;padding:.75rem}}.today-reminders{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1rem}.reminders-layout{display:flex;gap:1.5rem}.todays-section{flex:2 1;min-width:0}.upcoming-section{border-left:1px solid var(--border-color);flex:1 1;max-width:280px;min-width:200px;padding-left:1.5rem}.upcoming-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.upcoming-header h4{color:var(--text-primary);font-size:.95rem;margin:0}.upcoming-note{background:var(--slate-4);border-radius:4px;color:var(--text-muted);font-size:.7rem;padding:.125rem .375rem}.upcoming-list{display:flex;flex-direction:column;gap:.5rem}.upcoming-item{align-items:flex-start;background:var(--slate-3);border-radius:var(--radius-sm);display:flex;gap:.5rem;opacity:.8;padding:.5rem}.upcoming-icon{flex-shrink:0;font-size:1rem}.upcoming-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.upcoming-ritual{color:var(--text-primary);font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upcoming-time{color:var(--text-muted);font-size:.75rem}.upcoming-empty{background:var(--slate-3);border-radius:var(--radius-sm);color:var(--text-secondary);padding:1rem;text-align:center}.upcoming-empty p{font-size:.85rem;margin:0 0 .25rem}.upcoming-empty small{color:var(--text-muted);display:block;font-size:.75rem}@media (max-width:768px){.reminders-layout{flex-direction:column}.upcoming-section{border-left:none;border-top:1px solid var(--border-color);max-width:100%;padding-left:0;padding-top:1rem}}.reminders-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.reminders-header h3{color:var(--text-primary);font-size:1.1rem;margin:0}.reminders-stats{align-items:center;display:flex;gap:.75rem}.reminders-stats .stat{border-radius:12px;font-size:.8rem;padding:.25rem .5rem}.reminders-stats .settings-link{align-items:center;background:var(--bg-secondary);border-radius:50%;display:flex;font-size:.9rem;height:28px;justify-content:center;margin-left:.25rem;text-decoration:none;transition:all .2s;width:28px}.reminders-stats .settings-link:hover{background:var(--bg-hover);transform:rotate(45deg)}.completed-stat{background:var(--green-3);color:var(--green-11)}.pending-stat{background:var(--amber-3);color:var(--amber-11)}.reminders-empty,.reminders-loading{color:var(--text-secondary);padding:2rem;text-align:center}.reminders-empty small{color:var(--text-muted);display:block;margin-top:.5rem}.affirmation-toast{align-items:center;animation:slideIn .3s ease-out;background:linear-gradient(135deg,var(--green-9),var(--green-10));border-radius:var(--radius-md);display:flex;gap:.75rem;margin-bottom:1rem;padding:1rem}.affirmation-icon{align-items:center;background:#fff;border-radius:50%;color:var(--green-9);display:flex;font-size:1.5rem;height:36px;justify-content:center;width:36px}.affirmation-content{color:#fff}.affirmation-content strong{display:block;margin-bottom:.25rem}.affirmation-content p{font-size:.9rem;margin:0;opacity:.95}.reminders-section{margin-bottom:1rem}.reminders-section h4{color:var(--text-secondary);font-size:.85rem;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.reminder-card{align-items:center;background:var(--slate-3);border-left:4px solid var(--border-color);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem;transition:all .2s ease}.reminder-card:hover{box-shadow:var(--shadow-hover)}.reminder-card.pending{background:var(--blue-3);border-left-color:var(--blue-9)}.reminder-card.overdue{animation:pulse 2s infinite;background:var(--red-3);border-left-color:var(--red-9)}.reminder-card.snoozed{background:var(--amber-3);border-left-color:var(--amber-9)}.reminder-card.completed{background:var(--green-3);border-left-color:var(--green-9);padding:.5rem .75rem}.reminder-card.skipped{background:var(--slate-3);border-left-color:var(--slate-8);opacity:.7;padding:.5rem .75rem}.reminder-card.processing{opacity:.6;pointer-events:none}.reminder-ritual{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem}.ritual-icon{font-size:1.25rem}.reminder-time{font-size:.85rem}.overdue-time{color:var(--red-11);font-weight:500}.snoozed-until{color:var(--amber-11)}.reminder-drugs{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.reminder-actions{gap:.5rem}.reminder-btn{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem .75rem;transition:all .2s ease}.reminder-btn:disabled{cursor:not-allowed;opacity:.5}.taken-btn{background:var(--green-9)}.taken-btn:hover:not(:disabled){background:var(--green-10)}.snooze-btn{background:var(--amber-9);color:#fff}.snooze-btn:hover:not(:disabled){background:var(--amber-10)}.skip-btn{background:var(--slate-5);color:var(--text-primary)}.skip-btn:hover:not(:disabled){background:var(--slate-6)}.completed-list,.skipped-list{display:flex;flex-direction:column;gap:.5rem}.completed-check{color:var(--green-9);font-weight:700;margin-right:.5rem}.skipped-icon{color:var(--slate-9);margin-right:.5rem}.completed-time{color:var(--text-muted);font-size:.8rem;margin-left:auto}.reminders-unified-list{display:flex;flex-direction:column;gap:.5rem}.reminder-card.unified-card{align-items:center;display:flex;gap:1rem;justify-content:space-between}.reminder-card.unified-card.completed{opacity:.85}.reminder-card.unified-card.skipped{opacity:.65}.status-indicator{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:20px;justify-content:center;width:20px}.status-indicator.completed-indicator{background:var(--green-9);color:#fff}.status-indicator.skipped-indicator{background:var(--slate-7);color:#fff}.status-badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;gap:.375rem;padding:.5rem .875rem}.status-badge .badge-icon{font-size:.9rem}.done-badge{background:var(--green-4);border:1px solid var(--green-6);color:var(--green-11)}.skipped-badge{background:var(--slate-4);border:1px solid var(--slate-6);color:var(--slate-11)}.completed-time-info{color:var(--green-11);font-size:.85rem}.skipped-time-info{color:var(--slate-10);font-size:.85rem}@media (max-width:480px){.reminder-card{gap:.75rem}.reminder-card,.reminder-card.unified-card{align-items:stretch;flex-direction:column}.reminder-actions{justify-content:stretch}.reminder-btn{flex:1 1;text-align:center}.status-badge{justify-content:center}.reminders-stats{gap:.5rem}.reminders-stats .stat{font-size:.75rem;padding:.2rem .4rem}}.notification-prompt-banner{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.notification-prompt-icon{animation:bellRing 2s ease-in-out infinite;font-size:2.5rem}@keyframes bellRing{0%,to{transform:rotate(0deg)}10%,30%{transform:rotate(-10deg)}20%,40%{transform:rotate(10deg)}}.notification-prompt-content{flex:1 1}.notification-prompt-content h4{font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.notification-prompt-content p{font-size:.875rem;margin:0;opacity:.95}.notification-prompt-actions{align-items:center;display:flex;gap:.75rem}.notification-prompt-actions .btn-primary{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-weight:600;padding:.625rem 1.25rem;transition:all .2s}.notification-prompt-actions .btn-primary:hover:not(:disabled){box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.notification-prompt-actions .btn-primary:disabled{cursor:not-allowed;opacity:.6}.notification-prompt-actions .btn-secondary{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.notification-prompt-actions .btn-secondary:hover{background:#ffffff4d}.notification-prompt-actions .btn-text{background:none;border:none;color:#fff;cursor:pointer;font-size:.875rem;opacity:.8;padding:.625rem;transition:opacity .2s}.notification-prompt-actions .btn-text:hover{opacity:1}.notification-prompt-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.notification-prompt-modal{animation:modalSlideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.notification-prompt-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px 16px 0 0;color:#fff;padding:2rem 2rem 1rem;text-align:center}.notification-prompt-icon-large{animation:bellRing 2s ease-in-out infinite;font-size:4rem;margin-bottom:1rem}.notification-prompt-header h2{font-size:1.5rem;font-weight:700;margin:0}.notification-prompt-body{padding:2rem}.notification-prompt-body>p{color:var(--text-secondary);font-size:1.125rem;margin:0 0 1.5rem;text-align:center}.notification-benefits{list-style:none;margin:0 0 1.5rem;padding:0}.notification-benefits li{align-items:flex-start;background:var(--bg-secondary);border-radius:8px;display:flex;gap:1rem;margin-bottom:.75rem;padding:.75rem;transition:all .2s}.notification-benefits li:hover{background:var(--bg-hover);transform:translateX(4px)}.benefit-icon{flex-shrink:0;font-size:1.5rem}.notification-benefits li span:last-child{color:var(--text-primary);font-size:.9375rem;line-height:1.5}.notification-privacy{background:#f0f7ff;border-left:3px solid #3b82f6;border-radius:6px;padding:1rem}.notification-privacy p{color:#1e3a8a;font-size:.875rem;margin:0}.notification-prompt-footer{display:flex;flex-direction:column;gap:.75rem;padding:0 2rem 2rem}.btn-primary-large{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .2s}.btn-primary-large:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-primary-large:disabled{cursor:not-allowed;opacity:.6}@media (max-width:640px){.notification-prompt-banner{flex-direction:column;text-align:center}.notification-prompt-actions{flex-direction:column;width:100%}.notification-prompt-actions button{width:100%}.notification-prompt-modal{width:95%}.notification-prompt-body,.notification-prompt-footer,.notification-prompt-header{padding:1.5rem}}.reminder-modal-overlay{align-items:center;animation:overlayFadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10001}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.reminder-modal{animation:modalBounceIn .5s cubic-bezier(.68,-.55,.265,1.55);background:#fff;border-radius:20px;box-shadow:0 25px 80px #00000080;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:90%}@keyframes modalBounceIn{0%{opacity:0;transform:scale(.3) translateY(-100px)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1) translateY(0)}}.reminder-modal.urgency-overdue{animation:modalBounceIn .5s cubic-bezier(.68,-.55,.265,1.55),pulse 2s ease-in-out infinite;border:3px solid #ef4444}.reminder-modal.urgency-due-soon{border:3px solid #f59e0b}.reminder-modal.urgency-upcoming{border:3px solid #3b82f6}.reminder-modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;gap:1.5rem;padding:2rem;position:relative}.reminder-icon{animation:iconBounce 1s ease-in-out infinite;font-size:4rem}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.reminder-header-text{flex:1 1}.reminder-urgency-badge{border-radius:20px;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:.5rem;padding:.25rem .75rem}.urgency-overdue .reminder-urgency-badge{animation:badgePulse 1.5s ease-in-out infinite;background:#ef4444;color:#fff}.urgency-due-soon .reminder-urgency-badge{background:#f59e0b;color:#fff}.urgency-upcoming .reminder-urgency-badge{background:#3b82f6;color:#fff}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.reminder-modal-header h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.reminder-time{color:var(--text-secondary);font-size:1rem;font-weight:500;margin:.5rem 0 0}.reminder-medications{background:var(--bg-secondary);padding:1.5rem 2rem}.reminder-medications h3{color:var(--text-secondary);font-size:1rem;font-weight:600;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.reminder-medications ul{list-style:none;margin:0;padding:0}.reminder-medications li{align-items:center;background:#fff;border-left:4px solid var(--primary-color);border-radius:10px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .2s}.reminder-medications li:hover{box-shadow:0 4px 12px #0000001a;transform:translateX(4px)}.drug-name{font-size:1rem}.drug-dose{color:var(--text-secondary);font-size:.9375rem}.drug-route{font-size:.875rem;opacity:.8}.reminder-modal-actions{display:flex;flex-direction:column;gap:.75rem;padding:2rem}.reminder-modal-actions button{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;padding:1rem;transition:all .2s}.reminder-modal-actions button:disabled{cursor:not-allowed;opacity:.5}.btn-icon{font-size:1.25rem}.btn-taken{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-taken:hover:not(:disabled){box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.snooze-container{position:relative}.btn-snooze{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;width:100%}.btn-snooze:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b66;transform:translateY(-2px)}.snooze-options{grid-gap:.5rem;animation:dropdownSlide .2s ease-out;background:#fff;border-radius:10px;box-shadow:0 10px 30px #0003;display:grid;gap:.5rem;grid-template-columns:1fr 1fr;left:0;margin-top:.5rem;padding:.5rem;position:absolute;right:0;top:100%;z-index:10}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.snooze-options button{background:var(--bg-secondary);color:var(--text-primary);font-size:.9375rem;padding:.75rem}.snooze-options button:hover:not(:disabled){background:var(--bg-hover);transform:translateY(-1px)}.btn-skip{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.btn-skip:hover:not(:disabled){box-shadow:0 6px 20px #6b728066;transform:translateY(-2px)}.btn-close{align-items:center;background:#fff;border:2px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:2.5rem;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:2.5rem;z-index:10}.btn-close:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--text-secondary);transform:rotate(90deg)}body.reminder-active{animation:bodyShake .5s ease-in-out}@keyframes bodyShake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@media (max-width:640px){.reminder-modal{max-width:none;width:95%}.reminder-modal-header{flex-direction:column;padding:1.5rem;text-align:center}.reminder-icon{font-size:3rem}.reminder-modal-header h2{font-size:1.5rem}.reminder-medications,.reminder-modal-actions{padding:1.5rem}.reminder-medications li{align-items:flex-start;flex-direction:column;gap:.5rem}.snooze-options{grid-template-columns:1fr}}.overdue-reminder-banner{animation:banner-attention 3s ease-in-out infinite;background:linear-gradient(135deg,#ef444426,#dc262633);border:2px solid var(--danger-color);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);overflow:hidden;transition:all var(--transition-normal)}@keyframes banner-attention{0%,to{border-color:var(--danger-color);box-shadow:0 0 0 0 #ef44444d}50%{border-color:#ef4444;box-shadow:0 0 20px 5px #ef444433}}.overdue-reminder-banner.collapsed{animation:none}.banner-main{align-items:center;cursor:pointer;display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg)}.overdue-reminder-banner.collapsed .banner-main{padding:var(--space-sm) var(--space-md)}.banner-icon-section{flex-shrink:0}.banner-pulse-wrapper{align-items:center;display:flex;justify-content:center;position:relative}.banner-icon{font-size:2rem;position:relative;z-index:2}.overdue-reminder-banner.collapsed .banner-icon{font-size:1.5rem}.pulse-ring{animation:pulse-ring-animation 2s ease-out infinite;background:#ef44444d;height:48px;width:48px}@keyframes pulse-ring-animation{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(1.5)}}.overdue-reminder-banner.collapsed .pulse-ring{display:none}.banner-content{flex:1 1;min-width:0}.banner-title{color:var(--danger-color);font-size:var(--text-lg);margin-bottom:.25rem}.overdue-reminder-banner.collapsed .banner-title{font-size:var(--text-base);margin-bottom:0}.banner-subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.banner-actions{align-items:center;display:flex;flex-shrink:0;gap:var(--space-sm)}.banner-action-btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:.25rem;padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast);white-space:nowrap}.banner-action-btn:disabled{cursor:not-allowed;opacity:.5}.banner-action-btn.primary{background:var(--success-color);color:#fff}.banner-action-btn.primary:hover:not(:disabled){background:#16a34a;transform:translateY(-1px)}.banner-action-btn.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.banner-action-btn.secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--warning-color);color:var(--warning-color)}.banner-action-btn.tertiary{background:#0000;color:var(--text-secondary);padding:var(--space-xs) var(--space-sm)}.banner-action-btn.tertiary:hover:not(:disabled){color:var(--text-primary)}.banner-collapse-btn{background:#0000;border:none;color:var(--text-muted);cursor:pointer;font-size:var(--text-sm);padding:var(--space-xs) var(--space-sm);transition:color var(--transition-fast)}.banner-collapse-btn:hover{color:var(--text-secondary)}.banner-details{background:#0000001a;border-top:1px solid #ef444433;padding:var(--space-md) var(--space-lg)}.overdue-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:200px;overflow-y:auto}.overdue-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);justify-content:space-between;padding:var(--space-sm) var(--space-md)}.overdue-info,.overdue-item{align-items:center;display:flex}.overdue-info{gap:var(--space-sm)}.overdue-icon{font-size:1.25rem}.overdue-name{color:var(--text-primary);font-weight:var(--font-medium)}.overdue-time{color:var(--danger-color)}.overdue-take-btn,.overdue-time{font-size:var(--text-xs);font-weight:var(--font-medium)}.overdue-take-btn{background:var(--success-color);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;padding:.375rem .75rem;transition:all var(--transition-fast)}.overdue-take-btn:hover:not(:disabled){background:#16a34a}.overdue-take-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.banner-main{flex-wrap:wrap}.banner-content{flex-basis:calc(100% - 80px)}.banner-actions{flex-basis:100%;flex-wrap:wrap;justify-content:flex-start;margin-top:var(--space-sm)}.banner-action-btn{flex:1 1;justify-content:center;min-width:100px}.banner-action-btn.tertiary{flex:0 1;min-width:auto}.overdue-item{align-items:flex-start;flex-direction:column;gap:var(--space-sm)}.overdue-take-btn{width:100%}}.overdue-list::-webkit-scrollbar{width:4px}.overdue-list::-webkit-scrollbar-track{background:#0000}.overdue-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}[data-theme=dark] .overdue-reminder-banner{background:linear-gradient(135deg,#ef44441a,#b91c1c26)}[data-theme=dark] .banner-details{background:#0003}.health-metrics-widget{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%;padding:1rem}.widget-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.widget-header h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.health-metrics-widget .view-all-link{color:var(--primary-color);font-size:13px;font-weight:500;margin-left:auto;text-decoration:none}.health-metrics-widget .view-all-link:hover{text-decoration:underline}.btn-view-all{background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.85rem;padding:.5rem .75rem;transition:all .2s}.btn-view-all:hover{background:var(--hover-bg);border-color:var(--slate-8);color:var(--text-primary)}.widget-metrics{grid-gap:.5rem;display:grid;flex:1 1;gap:.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:.75rem}.widget-metric-item{align-items:center;background:var(--slate-3);border-radius:var(--radius-sm);display:flex;gap:.5rem;padding:.5rem;transition:transform .2s}.widget-metric-item:hover{transform:translateY(-1px)}.metric-icon-small{font-size:1rem;line-height:1}.metric-details{flex:1 1;min-width:0}.metric-label-small{color:var(--text-secondary);font-size:.65rem;margin-bottom:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric-value-small{align-items:center;color:var(--text-primary);display:flex;font-size:.85rem;font-weight:600;gap:.15rem}.trend-icon{font-size:.85rem}.widget-footer{align-items:center;display:flex;justify-content:center;padding-top:.5rem}.metric-meta{display:none}.metric-time{color:var(--text-tertiary);font-size:.55rem}.metric-source{display:none}.metric-source.manual{background:#0000000d;background:var(--bg-secondary,#0000000d);color:#888;color:var(--text-tertiary,#888)}.metric-source.integration{background:#3b82f61a;color:#007bff;color:var(--primary-color,#007bff)}.btn-log-metric{background:var(--primary-color);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.4rem .75rem;transition:all .2s;white-space:nowrap}.btn-log-metric:hover{background:var(--primary-hover)}.widget-empty,.widget-error,.widget-loading{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.widget-empty p,.widget-error p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.widget-error p{color:var(--danger-color)}.widget-loading{gap:.75rem}.spinner-small{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:30px;width:30px}.widget-loading p{color:var(--text-secondary);font-size:.85rem;margin:0}@media (max-width:1200px){.widget-metrics{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.widget-metrics{grid-template-columns:repeat(2,1fr)}.widget-footer{align-items:stretch;flex-direction:column}.btn-log-metric{width:100%}}@media (max-width:480px){.widget-metrics{grid-template-columns:1fr}}.recommendations-widget{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;transition:all .3s ease}.recommendations-widget:hover{box-shadow:var(--shadow-hover)}.recommendations-widget .widget-header{align-items:center;background:var(--card-bg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.25rem}.recommendations-widget .widget-header h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.recommendations-widget .view-all-link{color:var(--primary-color);font-size:13px;font-weight:500;margin-left:auto;text-decoration:none}.recommendations-widget .view-all-link:hover{text-decoration:underline}.badge{background:var(--primary-color);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.widget-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:2rem}.loading-spinner{height:32px;width:32px}.widget-error{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:.75rem;padding:1.5rem}.error-icon{font-size:2rem}.retry-btn{background:var(--primary-color);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background .2s}.retry-btn:hover{background:var(--primary-hover)}.widget-empty{align-items:center;display:flex;flex-direction:column;padding:2rem;text-align:center}.empty-icon{font-size:2.5rem;margin-bottom:.5rem}.widget-empty p{color:var(--text-primary);font-weight:600;margin:0}.empty-subtext{color:var(--text-secondary);font-size:.875rem;margin-top:.25rem}.recommendations-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding:.75rem}.recommendation-item{background:var(--slate-3);border-left:4px solid var(--primary-color);border-radius:var(--radius-md);padding:1rem;transition:all .2s ease}.recommendation-item:hover{box-shadow:var(--shadow);transform:translateX(4px)}.recommendation-item.priority-critical{background:var(--red-3);border-left-color:var(--red-9)}.recommendation-item.priority-high{background:var(--amber-3);border-left-color:var(--amber-9)}.recommendation-item.priority-medium{border-left-color:var(--primary-color)}.recommendation-item.priority-low{background:var(--green-3);border-left-color:var(--green-9)}.rec-header{justify-content:space-between;margin-bottom:.75rem}.agent-badge,.rec-header{align-items:center;display:flex}.agent-badge{background:var(--hover-bg);border-radius:12px;color:var(--text-secondary);font-size:.75rem;gap:.375rem;padding:.25rem .625rem}.priority-badge{border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;padding:.2rem .5rem;text-transform:uppercase}.priority-badge.critical{background:var(--red-9);color:#fff}.priority-badge.high{background:var(--amber-9);color:#fff}.priority-badge.medium{background:var(--primary-color);color:#fff}.priority-badge.low{background:var(--green-9);color:#fff}.rec-title{color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.4;margin:0 0 .5rem}.rec-description{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0 0 .75rem}.confidence-bar{align-items:center;display:flex;gap:.5rem;margin-bottom:.75rem}.confidence-label{color:var(--text-secondary);font-size:.75rem;min-width:70px}.confidence-track{background:var(--border-color);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.confidence-fill{background:linear-gradient(90deg,var(--primary-color),var(--green-9));border-radius:3px;height:100%;transition:width .5s ease}.confidence-value{color:var(--primary-color);font-size:.75rem;font-weight:600;min-width:35px;text-align:right}.rec-actions{display:flex;gap:.5rem}.accept-btn,.dismiss-btn{border-radius:var(--radius-sm);cursor:pointer;flex:1 1;font-size:.8rem;font-weight:600;padding:.5rem .75rem;transition:all .2s}.accept-btn{background:var(--primary-color);border:none;color:#fff}.accept-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.dismiss-btn{border:1px solid var(--border-color);color:var(--text-secondary)}.dismiss-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--text-secondary)}.accept-btn:disabled,.dismiss-btn:disabled{cursor:not-allowed;opacity:.6}.recommendations-widget .widget-footer{background:var(--slate-3);border-top:1px solid var(--border-color);padding:.75rem 1rem}.view-all-btn{border:1px dashed var(--border-color);font-size:.875rem;font-weight:600;padding:.625rem;transition:all .2s}.view-all-btn:hover{border-style:solid}@media (max-width:768px){.recommendations-list{max-height:300px}.recommendation-item{padding:.875rem}.rec-header{flex-wrap:wrap;gap:.5rem}.rec-title{font-size:.9rem}.rec-description{font-size:.8rem}.confidence-bar{flex-wrap:wrap}.confidence-label{margin-bottom:.25rem;min-width:100%}}@media (max-width:480px){.recommendations-widget .widget-header{padding:.875rem 1rem}.recommendations-widget .widget-header h3{font-size:1rem}.recommendations-list{padding:.5rem}.rec-actions{flex-direction:column}.accept-btn,.dismiss-btn{width:100%}}.recommendations-list::-webkit-scrollbar{width:6px}.recommendations-list::-webkit-scrollbar-track{background:var(--border-color);border-radius:3px}.recommendations-list::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:3px}.recommendations-list::-webkit-scrollbar-thumb:hover{background:var(--primary-hover)}.insights-widget{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--shadow);padding:20px}.insights-widget .widget-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.insights-widget .widget-header h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.insights-widget .unread-badge{background:linear-gradient(135deg,var(--kyx-violet) 0,#8b5cf6 100%);border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.insights-widget .view-all-link{color:var(--kyx-violet);font-size:13px;font-weight:500;margin-left:auto;text-decoration:none}.insights-widget .view-all-link:hover{text-decoration:underline}.insight-alerts{display:flex;gap:8px;margin-bottom:12px}.alert-badge{border-radius:6px;font-size:11px;font-weight:600;padding:4px 10px}.alert-badge.critical{background:#dc262626;border:1px solid #dc26264d;color:#ef4444}.alert-badge.warning{background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b}.insights-widget .insights-list{display:flex;flex-direction:column;gap:8px}.insights-widget .insight-item{align-items:flex-start;background:var(--bg-secondary);border-left:3px solid var(--border-color);border-radius:8px;display:flex;gap:12px;padding:12px;transition:background .2s ease}.insights-widget .insight-item:hover{background:var(--hover-bg)}.insights-widget .insight-item.critical{background:#ef444414;border-left-color:#ef4444}.insights-widget .insight-item.warning{background:#f59e0b14;border-left-color:#f59e0b}.insights-widget .insight-item.success{background:#10b98114;border-left-color:#10b981}.insights-widget .insight-item.info{border-left-color:var(--kyx-violet)}.insights-widget .insight-icon{flex-shrink:0;font-size:18px}.insights-widget .insight-content{flex:1 1;min-width:0}.insights-widget .insight-title{color:var(--text-primary);display:block;font-size:13px;font-weight:500;margin-bottom:2px}.insights-widget .insight-description{color:var(--text-secondary);font-size:12px;line-height:1.4}.insights-widget .dismiss-btn{align-items:center;background:#0000;border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:12px;height:24px;justify-content:center;transition:all .2s ease;width:24px}.insights-widget .dismiss-btn:hover{background:#10b981;border-color:#10b981;color:#fff}.insights-widget .no-insights{padding:24px 16px;text-align:center}.insights-widget .no-insights-icon{display:block;font-size:32px;margin-bottom:8px}.insights-widget .no-insights p{color:var(--text-secondary);font-size:14px;margin:0 0 12px}.insights-widget .generate-link{background:linear-gradient(135deg,var(--kyx-violet) 0,#8b5cf6 100%);border-radius:6px;color:#fff;display:inline-block;font-size:13px;font-weight:500;padding:8px 16px;text-decoration:none;transition:opacity .2s ease}.insights-widget .generate-link:hover{opacity:.9}.insights-widget .widget-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-size:13px;gap:12px;justify-content:center;padding:32px 16px}.insights-widget .loading-spinner.small{animation:spin 1s linear infinite;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:24px;width:24px}.insights-widget .widget-error{color:var(--text-secondary);font-size:13px;padding:24px 16px;text-align:center}.insights-widget .last-generated{border-top:1px solid var(--border-color);color:var(--text-tertiary);font-size:11px;margin-top:12px;padding-top:12px;text-align:center}.predictions-widget{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--shadow);padding:20px}.predictions-widget .widget-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.predictions-widget .widget-header h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.predictions-widget .unread-badge{background:linear-gradient(135deg,#8b5cf6,#a855f7);border-radius:10px;color:#fff;font-size:11px;font-weight:600;padding:3px 8px}.predictions-widget .view-all-link{color:#8b5cf6;font-size:13px;font-weight:500;margin-left:auto;text-decoration:none}.predictions-widget .view-all-link:hover{text-decoration:underline}.prediction-quick-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.prediction-quick-stats .alert-badge{border-radius:12px;font-size:11px;font-weight:600;padding:4px 10px}.prediction-quick-stats .alert-badge.critical{background:#ef444426;color:#ef4444}.prediction-quick-stats .accuracy-badge{background:#6366f126;border-radius:12px;color:var(--primary-color);font-size:11px;font-weight:500;padding:4px 10px}.predictions-widget .predictions-list{display:flex;flex-direction:column;gap:12px}.predictions-widget .prediction-item{align-items:flex-start;background:var(--bg-secondary);border-left:3px solid var(--border-color);border-radius:8px;display:flex;gap:12px;padding:12px;position:relative;transition:background .2s ease}.predictions-widget .prediction-item:hover{background:var(--hover-bg)}.predictions-widget .prediction-item.critical{background:#ef444414;border-left-color:#ef4444}.predictions-widget .prediction-item.high{background:#ea580c14;border-left-color:#ea580c}.predictions-widget .prediction-item.medium{background:#f59e0b14;border-left-color:#f59e0b}.predictions-widget .prediction-item.low{background:#3b82f614;border-left-color:#3b82f6}.predictions-widget .prediction-item.info{background:#8b5cf614;border-left-color:#8b5cf6}.predictions-widget .prediction-icon{flex-shrink:0;font-size:20px}.predictions-widget .prediction-content{flex:1 1;min-width:0}.predictions-widget .prediction-title{color:var(--text-primary);display:block;font-size:13px;font-weight:600;margin-bottom:4px}.predictions-widget .prediction-description{color:var(--text-secondary);display:block;font-size:12px;line-height:1.4}.predictions-widget .prediction-meta{margin-top:6px}.predictions-widget .confidence-indicator{align-items:center;color:var(--text-tertiary);display:flex;font-size:11px;gap:4px}.predictions-widget .confidence-dot{border-radius:50%;height:6px;width:6px}.predictions-widget .dismiss-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:12px;height:20px;justify-content:center;opacity:0;position:absolute;right:8px;top:8px;transition:opacity .2s ease,background .2s ease;width:20px}.predictions-widget .prediction-item:hover .dismiss-btn{opacity:1}.predictions-widget .dismiss-btn:hover{background:var(--hover-bg);color:var(--text-secondary)}.predictions-widget .no-predictions{padding:24px 16px;text-align:center}.predictions-widget .no-predictions-icon{display:block;font-size:32px;margin-bottom:12px;opacity:.6}.predictions-widget .no-predictions p{color:var(--text-secondary);font-size:13px;margin:0 0 12px}.predictions-widget .generate-link{color:#8b5cf6;font-size:13px;font-weight:500;text-decoration:none}.predictions-widget .generate-link:hover{text-decoration:underline}.predictions-widget .last-generated{border-top:1px solid var(--border-color);color:var(--text-tertiary);font-size:11px;margin-top:16px;padding-top:12px;text-align:center}.predictions-widget .widget-loading{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:32px 16px}.predictions-widget .widget-loading .loading-spinner.small{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top:3px solid #8b5cf6;height:24px;width:24px}.predictions-widget .widget-loading span{color:var(--text-secondary);font-size:13px}.predictions-widget .widget-error{padding:24px 16px;text-align:center}.predictions-widget .widget-error span{color:var(--text-secondary);font-size:13px}@media (max-width:480px){.predictions-widget .widget-header{flex-wrap:wrap}.predictions-widget .view-all-link{margin-left:0;margin-top:8px;width:100%}}.metric-form{margin:0 auto;max-width:800px}.metric-form form{display:flex;flex-direction:column;gap:2rem}.form-section{background:#fff;background:var(--card-bg,#fff);border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.form-section h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.2rem;font-weight:600;margin:0 0 1rem}.section-description{color:#666;color:var(--text-secondary,#666);font-size:.9rem;margin:-.5rem 0 1rem}.form-row{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-group{gap:.5rem}.form-group label{align-items:center;color:#1a1a1a;color:var(--text-primary,#1a1a1a);display:flex;font-size:.95rem;justify-content:space-between}.optional{color:#666;color:var(--text-secondary,#666);font-size:.85rem;font-style:italic;font-weight:400}.form-group input[type=datetime-local],.form-group input[type=number],.form-group textarea{border:1px solid #ddd;border:1px solid var(--border-color,#ddd);border-radius:6px;font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s}.form-group input[type=datetime-local]:focus,.form-group input[type=number]:focus,.form-group textarea:focus{border-color:#007bff;border-color:var(--primary-color,#007bff);outline:none}.form-group input[type=number]::placeholder,.form-group textarea::placeholder{color:#999;color:var(--text-tertiary,#999)}.form-group textarea{min-height:100px;resize:vertical}.slider-group{margin-bottom:1.5rem}.slider-group:last-child{margin-bottom:0}.slider-group label{color:#1a1a1a;color:var(--text-primary,#1a1a1a);display:block;font-weight:500;margin-bottom:.5rem}.slider-labels{color:#666;color:var(--text-secondary,#666);display:flex;font-size:.85rem;font-weight:400;justify-content:space-between;margin-top:.25rem}.slider-group input[type=range]{-webkit-appearance:none;background:linear-gradient(90deg,#e74c3c,#f39c12,#2ecc71);border-radius:5px;height:8px;margin-top:.5rem;outline:none;width:100%}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#007bff;background:var(--primary-color,#007bff);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:20px;width:20px}.slider-group input[type=range]::-moz-range-thumb{background:#007bff;background:var(--primary-color,#007bff);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:20px;width:20px}.slider-group:has(#pain_level) input[type=range]{background:linear-gradient(90deg,#2ecc71,#f39c12,#e74c3c)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:#007bff;background:var(--primary-color,#007bff)}.btn-primary:hover:not(:disabled){background:#0056b3;background:var(--primary-hover,#0056b3);box-shadow:0 4px 8px #007bff4d}.btn-primary:disabled{opacity:.6}.btn-secondary{background:var(--secondary-bg,#f5f5f5);color:#1a1a1a;color:var(--text-primary,#1a1a1a)}.btn-secondary:hover{background:#e0e0e0;background:var(--secondary-hover,#e0e0e0)}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c00;margin-bottom:1rem;padding:1rem}@media (prefers-color-scheme:dark){.form-section{background:#2a2a2a;background:var(--card-bg,#2a2a2a)}.form-group input[type=datetime-local],.form-group input[type=number],.form-group textarea{background:#1a1a1a;background:var(--input-bg,#1a1a1a);border-color:#444;border-color:var(--border-color,#444);color:#fff;color:var(--text-primary,#fff)}.btn-secondary{background:#3a3a3a;background:var(--secondary-bg,#3a3a3a);color:#fff;color:var(--text-primary,#fff)}.btn-secondary:hover{background:#4a4a4a;background:var(--secondary-hover,#4a4a4a)}}@media (max-width:768px){.form-row{grid-template-columns:1fr}.form-section{padding:1rem}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.chart-time-cursor-container{bottom:0;cursor:crosshair;left:0;pointer-events:all;position:absolute;right:0;top:50px;z-index:10}.cursor-hint{background:#0009;border-radius:8px;color:#fff;font-size:.85rem;left:50%;opacity:0;padding:8px 16px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .3s ease;white-space:nowrap}.chart-time-cursor-container:hover .cursor-hint{opacity:1}.cursor-line{background:#3b82f6;background:var(--primary-color,#3b82f6);transition:background-color .15s ease;width:2px;z-index:20}.cursor-line,.cursor-line:before{bottom:0;cursor:ew-resize;position:absolute;top:0}.cursor-line:before{content:"";left:-10px;right:-10px}.cursor-line.dragging{background:#2563eb;background:var(--primary-hover,#2563eb)}.cursor-handle{align-items:center;background:#3b82f6;background:var(--primary-color,#3b82f6);border-radius:6px 6px 0 0;bottom:0;box-shadow:0 -2px 6px #0003;cursor:ew-resize;display:flex;height:20px;justify-content:center;left:50%;position:absolute;transform:translateX(-50%);transition:transform .15s ease,background-color .15s ease;width:24px}.cursor-line.dragging .cursor-handle{background:#2563eb;background:var(--primary-hover,#2563eb);transform:translateX(-50%) scale(1.1)}.cursor-handle-grip{display:flex;gap:2px}.cursor-handle-grip span{background:#ffffffb3;border-radius:1px;height:10px;width:2px}.cursor-values-panel{background:#1a1f24;background:var(--card-bg,#1a1f24);border:1px solid #363a3f;border:1px solid var(--border-color,#363a3f);border-radius:10px;box-shadow:0 8px 24px #0000004d;max-width:280px;min-width:200px;padding:12px;pointer-events:none;position:absolute;top:30px;z-index:30}.cursor-values-panel.left,.cursor-values-panel.right{text-align:left}.cursor-time-header{align-items:center;border-bottom:1px solid #363a3f;border-bottom:1px solid var(--border-color,#363a3f);color:#edeef0;color:var(--text-primary,#edeef0);display:flex;flex-wrap:wrap;font-size:.8rem;font-weight:600;gap:8px;margin-bottom:10px;padding-bottom:8px}.projected-badge{background:#ffa50033;border-radius:4px;color:orange;font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:2px 6px}.cursor-values-list{display:flex;flex-direction:column;gap:6px}.cursor-value-item{align-items:center;display:flex;font-size:.85rem;gap:8px}.cursor-value-color{border-radius:50%;flex-shrink:0;height:10px;width:10px}.cursor-value-name{color:#b0b4ba;color:var(--text-secondary,#b0b4ba);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-value-number{font-feature-settings:"tnum";color:#edeef0;color:var(--text-primary,#edeef0);font-variant-numeric:tabular-nums;font-weight:600}.cursor-value-unit{color:#6b7280;color:var(--text-tertiary,#6b7280);font-size:.75rem;font-weight:400;margin-left:2px}.cursor-no-data{color:#b0b4ba;color:var(--text-secondary,#b0b4ba);font-size:.85rem;font-style:italic}.hover-line{background:#6b7280;background:var(--text-tertiary,#6b7280);bottom:0;opacity:.6;pointer-events:none;position:absolute;top:0;width:1px;z-index:15}.cursor-values-panel.hover-panel{background:#1a1f24;background:var(--card-bg,#1a1f24);opacity:.95}.hover-hint{border-top:1px solid #363a3f;border-top:1px solid var(--border-color,#363a3f);color:#6b7280;color:var(--text-tertiary,#6b7280);font-size:.7rem;font-style:italic;margin-top:8px;padding-top:8px;text-align:center}@media (max-width:768px){.cursor-values-panel{max-width:200px;min-width:160px;padding:10px}.cursor-time-header{font-size:.75rem}.cursor-value-item{font-size:.8rem}.cursor-handle{height:24px;width:28px}.cursor-hint{font-size:.75rem;padding:6px 12px}}@media (prefers-color-scheme:light){.cursor-values-panel{background:#fffffffa;box-shadow:0 8px 24px #00000026}.cursor-hint{background:#000000bf}}.voice-logger-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;background:var(--overlay-bg,#0009);bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-lg);position:fixed;right:0;top:0;z-index:1000}.voice-logger-modal{animation:slideUp .3s ease;background:var(--bg-primary);border-radius:16px;box-shadow:var(--shadow-xl);max-width:420px;padding:24px;position:relative;width:100%}.voice-logger-modal h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 20px;text-align:center}.close-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;position:absolute;right:16px;top:16px;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.close-btn svg{height:20px;width:20px}.browser-warning{background:var(--amber-3);border-radius:8px;color:var(--amber-11);font-size:.9rem;margin-bottom:16px;padding:12px;text-align:center}.voice-idle{padding:20px 0;text-align:center}.voice-icon-large{align-items:center;background:var(--bg-secondary);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.voice-icon-large svg{color:var(--primary-color);height:40px;width:40px}.voice-instruction{color:var(--text-secondary);font-size:.95rem;margin:0 0 16px}.voice-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}.suggestion-chip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;color:var(--text-secondary);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .2s}.suggestion-chip:hover{background:var(--bg-hover);border-color:var(--primary-color);color:var(--text-primary)}.voice-start-btn{align-items:center;background:var(--primary-color);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:10px;justify-content:center;padding:14px 24px;transition:all .2s;width:100%}.voice-start-btn:hover{background:var(--primary-color-dark)}.voice-start-btn:disabled{cursor:not-allowed;opacity:.5}.voice-start-btn svg{height:24px;width:24px}.voice-listening{padding:20px 0;text-align:center}.voice-pulse{align-items:center;display:flex;height:100px;justify-content:center;margin:0 auto 20px;position:relative;width:100px}.voice-pulse svg{color:var(--primary-color);height:40px;width:40px;z-index:1}.pulse-ring{animation:pulse 1.5s ease-out infinite;border:2px solid var(--primary-color);border-radius:50%;height:100%;position:absolute;width:100%}.pulse-ring:nth-child(2){animation-delay:.5s}.pulse-ring:nth-child(3){animation-delay:1s}.listening-text{animation:blink 1s infinite;color:var(--primary-color);font-size:1.1rem;font-weight:500;margin:0 0 12px}@keyframes blink{50%{opacity:.5}}.transcript-preview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;margin-bottom:20px;min-height:60px;padding:12px}.transcript-preview .interim{color:var(--primary-color);font-style:italic;opacity:.8}.voice-stop-btn{background:var(--danger-color);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow);color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:var(--space-sm) 40px;transition:all var(--transition-normal)}.voice-stop-btn:hover{background:var(--danger-hover);box-shadow:var(--shadow-hover)}.voice-parsed{padding:40px 0;text-align:center}.voice-parsed p{color:var(--text-secondary);margin:0}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-top-color:var(--primary-color);height:40px;margin:0 auto 16px;width:40px}.voice-confirming{padding:0}.voice-confirming h3{color:var(--text-primary);margin:0 0 12px;text-align:center}.parsed-text{background:var(--bg-secondary);border-radius:8px;color:var(--text-secondary);font-style:italic;margin:0 0 20px;padding:10px;text-align:center}.confirm-form{gap:16px;margin-bottom:20px}.confirm-form,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:2fr 1fr}.form-group input,.form-group select{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;padding:10px 12px}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);outline:none}.selected-drug{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px}.selected-drug .drug-name{color:var(--text-primary);font-weight:500}.selected-drug .match-type{color:var(--text-tertiary);font-size:.8rem}.selected-drug .change-btn{background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.8rem;margin-left:auto;padding:4px 10px}.selected-drug .change-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.alternatives{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.alternatives span{color:var(--text-tertiary);font-size:.85rem}.alternative-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;font-size:.85rem;padding:4px 10px}.alternative-btn:hover{background:var(--bg-hover);border-color:var(--primary-color)}.confirm-actions{display:flex;gap:12px}.confirm-actions .btn{border-radius:8px;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:12px;transition:all .2s}.confirm-actions .btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.confirm-actions .btn-secondary:hover{background:var(--bg-hover)}.confirm-actions .btn-primary{background:var(--primary-color);border:none;color:#fff}.confirm-actions .btn-primary:hover{background:var(--primary-color-dark)}.confirm-actions .btn-primary:disabled{cursor:not-allowed;opacity:.5}.voice-success{padding:40px 0;text-align:center}.success-icon{animation:scaleIn .3s ease;background:var(--success-bg);border-radius:50%;height:80px;margin:0 auto 20px;width:80px}.success-icon svg{color:var(--success-color);height:40px;width:40px}.voice-success h3{color:var(--success-color);margin:0 0 8px}.voice-success p{color:var(--text-secondary);margin:0}.voice-error{padding:40px 0;text-align:center}.error-icon{align-items:center;background:var(--error-bg);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.error-icon svg{color:var(--error-color);height:40px;width:40px}.error-message{color:var(--text-primary);margin:0 0 20px}.voice-error .btn{border-radius:8px;padding:12px 32px}.drug-search-input{position:relative}.drug-search-input input{width:100%}.search-spinner{animation:spin 1s linear infinite;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:16px;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:16px}.drug-search-input .search-results{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-lg);left:0;margin-top:4px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.drug-search-input .search-result{background:none;border:none;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:10px 12px;text-align:left;transition:background .15s;width:100%}.drug-search-input .search-result:last-child{border-bottom:none}.drug-search-input .search-result:hover{background:var(--bg-hover)}.drug-search-input .search-result .drug-name{color:var(--text-primary);font-weight:500}.drug-search-input .search-result .drug-category{color:var(--text-tertiary);font-size:.8rem}@media (max-width:480px){.voice-logger-modal{margin:10px;padding:20px}.form-row{grid-template-columns:1fr}.confirm-actions{flex-direction:column}}.serum-levels-hero{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 20px var(--shadow);margin-bottom:2rem;padding:24px}.hero-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.hero-title-section h1{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 4px}.hero-subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.voice-log-btn{align-items:center;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.voice-log-btn:hover{background:#3730a3;background:var(--primary-color-dark,#3730a3);box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.voice-log-btn svg{flex-shrink:0}.hero-stats{display:flex;gap:24px}.hero-stat{background:var(--hover-bg);border-radius:12px;min-width:100px;padding:12px 20px;text-align:center}.hero-stat-value{color:var(--primary-color);display:block;font-size:1.75rem;font-weight:700;line-height:1}.hero-stat-label{color:var(--text-secondary);display:block;font-size:.75rem;letter-spacing:.5px;margin-top:4px;text-transform:uppercase}.hero-chart-container{height:400px;margin-bottom:24px;position:relative}.hero-chart-wrapper{height:100%;position:relative;width:100%}.hero-chart-wrapper canvas{position:relative;z-index:1}.hero-chart-loading{background:var(--hover-bg)}.hero-chart-loading,.hero-empty-state{align-items:center;border-radius:12px;display:flex;height:100%;justify-content:center}.hero-empty-state{background:linear-gradient(135deg,var(--hover-bg) 0,var(--bg-secondary) 100%);border:2px dashed var(--border-color);flex-direction:column;padding:40px;text-align:center}.hero-empty-state .empty-state-icon{color:var(--primary-color);margin-bottom:16px;opacity:.6}.hero-empty-state h3{color:var(--text-primary);font-size:1.25rem;margin:0 0 8px}.hero-empty-state p{color:var(--text-secondary);margin:0 0 20px;max-width:300px}.hero-cta-btn{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:transform .15s ease,box-shadow .15s ease}.hero-cta-btn:hover{box-shadow:0 4px 16px #667eea66;transform:translateY(-2px)}.current-levels-cards{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start}.level-card{background:var(--bg-secondary);border-radius:10px;border-top:4px solid var(--primary-color);flex:1 1 auto;max-width:180px;min-width:120px;padding:12px 16px;text-align:center;transition:transform .15s ease,box-shadow .15s ease}.level-card:hover{box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.level-card-name{color:var(--text-primary);font-size:.8rem;font-weight:600;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.level-card-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1}.level-card-unit{color:var(--text-secondary);font-size:.7rem;margin-top:2px}.level-card-peak{background:#667eea1a;border-radius:4px;color:var(--primary-color);display:inline-block;font-size:.7rem;margin-top:6px;padding:3px 6px}@media (max-width:768px){.serum-levels-hero{padding:16px}.hero-header{flex-direction:column}.hero-title-section h1{font-size:1.5rem}.hero-stats{justify-content:center;width:100%}.hero-chart-container{height:300px}.current-levels-cards{justify-content:center}.level-card{max-width:150px;min-width:100px}.level-card-value{font-size:1.25rem}}@media (max-width:480px){.hero-stats{flex-direction:column;gap:8px}.hero-stat{width:100%}.hero-chart-container{height:250px}}.dashboard h1{color:var(--text-primary);margin-bottom:2rem;transition:color .3s ease}.quick-log-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--shadow);margin-bottom:2rem;padding:20px;transition:all .3s ease}.quick-log-section h2{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem;margin-top:0;padding-bottom:.75rem;transition:color .3s ease}.quick-log-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.quick-log-voice-btn{align-items:center;background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);border:none;border-left:5px solid var(--primary-color);border-radius:10px;box-shadow:0 4px 12px #6366f140;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:1rem;font-weight:600;gap:10px;justify-content:center;min-height:100px;padding:24px 20px;transition:all .2s ease}.quick-log-voice-btn:hover{box-shadow:0 8px 20px #6366f159;transform:translateY(-2px)}.quick-log-voice-btn:active{transform:translateY(0)}.quick-log-voice-btn svg{height:32px;width:32px}.quick-log-voice-btn span{font-size:.9rem;letter-spacing:.5px;text-transform:uppercase}.rituals-quick-log{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--shadow);margin-bottom:2rem;padding:20px;transition:all .3s ease}.rituals-quick-log h2{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem;margin-top:0;padding-bottom:.75rem;transition:color .3s ease}.ritual-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.ritual-card{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-left:5px solid var(--primary-color);border-radius:10px;display:flex;gap:15px;justify-content:space-between;padding:15px;transition:all .3s ease}.ritual-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px var(--shadow-hover)}.ritual-info{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0}.ritual-name{font-size:16px;font-weight:600;transition:color .3s ease}.ritual-drugs{font-size:13px}.ritual-description,.ritual-drugs{color:var(--text-secondary);transition:color .3s ease}.ritual-description{font-size:12px;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ritual-log-btn{background-color:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap}.ritual-log-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea40;transform:translateY(-1px)}.ritual-log-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.seven-day-chart-section{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--shadow);margin-bottom:2rem;padding:20px;transition:all .3s ease}.seven-day-chart-section h2{color:var(--text-primary);font-size:20px;margin-bottom:15px;margin-top:0;transition:color .3s ease}.chart-container-dashboard{height:400px;position:relative;width:100%}.chart-loading{align-items:center;color:var(--primary-color);display:flex;font-size:16px;font-weight:500;height:100%;justify-content:center;transition:color .3s ease}.toxicity-warnings{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;position:relative}.warning-card.warning{background:#f59e0b1a;background:var(--warning-card-bg,#f59e0b1a);border-color:var(--warning-color);border-left-color:var(--warning-color)}.warning-card.warning:before{background:var(--warning-color);content:"";height:4px;left:0;position:absolute;right:0;top:0}.warning-card.critical{background:#2a0a0a;border-color:var(--danger-color);border-left-color:var(--danger-color);color:#fff}.warning-card.critical:before{background:var(--danger-color);content:"";height:4px;left:0;position:absolute;right:0;top:0}.warning-card.critical .stat-label,.warning-card.critical .stat-value,.warning-card.critical .warning-drug-name,.warning-card.critical .warning-header h3,.warning-card.critical .warning-message{color:#fff}.warning-card.critical .warning-header{border-bottom-color:#fff3}.warning-content{position:relative;z-index:1}.warning-drug-name{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.warning-message{color:var(--text-primary);font-size:1rem;line-height:1.5;margin-bottom:1.25rem}.toxicity-details{grid-gap:1rem;background:#0000000d;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:1rem;padding:1rem}.warning-card.critical .toxicity-details{background:#ffffff1a}.toxicity-stat{display:flex;flex-direction:column;gap:.25rem}.toxicity-stat .stat-label{font-size:.875rem;font-weight:600;opacity:.8}.toxicity-stat .stat-value{font-size:1.125rem;font-weight:700}.toxicity-stat .stat-value.danger{color:var(--danger-color);font-size:1.5rem}.warning-card.critical .toxicity-stat .stat-value.danger{color:#fecaca;text-shadow:0 0 10px #fecaca80}.critical-action{background:#dc262626;border-left:4px solid var(--danger-color);border-radius:6px;font-size:.95rem;line-height:1.6;margin:0;padding:1rem}.warning-card.critical .critical-action{background:#fecaca33;border-left-color:#fecaca;color:#fff}.critical-action strong{color:var(--danger-color);font-weight:800}.warning-card.critical .critical-action strong{color:#fecaca;text-shadow:0 0 10px #fecaca80}.interaction-warnings{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;position:relative}.warning-card{border:2px solid;border-left:6px solid;border-radius:12px;box-shadow:0 4px 12px #00000026;overflow:hidden;padding:1.5rem;position:relative;transition:box-shadow .2s ease}.warning-card:hover{box-shadow:0 6px 16px #0003}.warning-card.contraindicated{background:#ef44440d;background:var(--danger-card-bg,#ef44440d);border-color:var(--danger-color);border-left-color:var(--danger-color)}.warning-card.contraindicated:before{background:var(--danger-color);content:"";height:4px;left:0;position:absolute;right:0;top:0}.warning-card.severe{background:#f59e0b1a;background:var(--warning-card-bg,#f59e0b1a);border-color:var(--warning-color);border-left-color:var(--warning-color)}.warning-card.severe:before{background:var(--warning-color);content:"";height:4px;left:0;position:absolute;right:0;top:0}.warning-header{border-bottom:2px solid #0000001a;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem}.warning-header,.warning-icon{align-items:center;display:flex}.warning-icon{color:inherit;justify-content:center}.warning-header h3{color:var(--text-primary);font-size:1.4rem;font-weight:800;letter-spacing:.5px;margin:0;text-transform:uppercase}.interaction-item{background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px var(--shadow);margin-bottom:1rem;padding:1.25rem;transition:all .3s ease}.interaction-item:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateX(5px)}.interaction-item:last-child{margin-bottom:0}.interaction-drugs{color:var(--text-primary);font-size:1.2rem;font-weight:700;line-height:1.4;margin-bottom:.75rem;transition:color .3s ease}.interaction-drugs strong{background:#dc26261a;border-radius:4px;color:var(--danger-color);font-weight:800;padding:2px 6px}.interaction-desc{font-size:1rem;margin:.75rem 0;transition:color .3s ease}.interaction-desc,.interaction-mgmt{color:var(--text-primary);font-weight:500;line-height:1.6}.interaction-mgmt{background:linear-gradient(135deg,var(--hover-bg) 0,var(--bg-primary) 100%);border-left:4px solid var(--primary-color);border-radius:6px;box-shadow:0 2px 6px var(--shadow);margin:1rem 0 0;padding:1rem;transition:all .3s ease}.interaction-mgmt strong{color:var(--primary-color);font-size:1.05rem;font-weight:700;transition:color .3s ease}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.card{background:var(--card-bg);border-radius:8px;box-shadow:0 2px 8px var(--shadow);padding:1.5rem}.card,.card h2{transition:all .3s ease}.card h2{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;margin-bottom:1rem;padding-bottom:.5rem}.doses-list,.levels-list{display:flex;flex-direction:column;gap:1rem}.level-item{border:1px solid var(--border-color);border-radius:6px;padding:1rem;transition:all .3s ease}.level-item:hover{box-shadow:0 2px 8px var(--shadow)}.level-item.aggregated{background-color:var(--hover-bg);border-color:var(--primary-color)}.level-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.drug-name{color:var(--text-primary);font-size:1.1rem;font-weight:600;transition:color .3s ease}.concentration{color:var(--primary-color);font-size:1.25rem;font-weight:700;transition:color .3s ease}.level-status{align-items:center;display:flex;font-size:.9rem;justify-content:space-between}.status-badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.status-badge.in-range{background-color:#22c55e1a;background-color:var(--success-bg,#22c55e1a);color:#166534;color:var(--success-text,#166534)}.status-badge.out-range{background-color:#ef44441a;background-color:var(--danger-bg,#ef44441a);color:#991b1b;color:var(--danger-text,#991b1b)}.range-info{color:var(--text-secondary);transition:color .3s ease}.components{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem;padding-top:.75rem;transition:border-color .3s ease}.component{color:var(--text-secondary);display:flex;font-size:.9rem;justify-content:space-between;transition:color .3s ease}.dose-item{background-color:var(--hover-bg);border-left:3px solid var(--primary-color);border-radius:4px;padding:.75rem;transition:all .3s ease}.dose-drug{color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.dose-details,.dose-drug{transition:color .3s ease}.dose-details{color:var(--text-secondary);display:flex;font-size:.9rem;gap:1rem}.dose-route{background-color:var(--primary-color);border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.125rem .5rem;transition:background-color .3s ease}.dose-time{font-style:italic}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-item{background-color:var(--hover-bg);border-radius:6px;padding:1rem;text-align:center;transition:all .3s ease}.stat-value{color:var(--primary-color);font-size:2rem;font-weight:700;margin-bottom:.25rem;transition:color .3s ease}.stat-label{font-size:.9rem}.empty-state,.stat-label{color:var(--text-secondary);transition:color .3s ease}.empty-state{font-style:italic}.empty-state,.error,.loading{padding:2rem;text-align:center}.error,.loading{font-size:1.1rem}.error{color:var(--danger-color);transition:color .3s ease}.btn-add,.ritual-log-btn{min-height:44px;min-width:44px}@media (max-width:968px){.dashboard-grid{gap:1.25rem;grid-template-columns:1fr}.ritual-cards{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stats-grid,.toxicity-details{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard h1{font-size:1.75rem;margin-bottom:1.5rem}.rituals-quick-log{padding:15px}.ritual-cards{gap:12px;grid-template-columns:1fr}.ritual-card{align-items:stretch;flex-direction:column;padding:12px}.ritual-log-btn{padding:12px 16px;width:100%}.seven-day-chart-section{padding:15px}.chart-container-dashboard{height:300px}.toxicity-details{gap:.75rem;grid-template-columns:1fr}.warning-card{padding:1.5rem}.interaction-item{padding:1rem}.interaction-drugs{font-size:1.1rem}.card{padding:1.25rem}.stats-grid{gap:.75rem;grid-template-columns:1fr}.dose-details{flex-direction:column;gap:.25rem}.level-header{align-items:flex-start;flex-direction:column;gap:.5rem}.concentration{font-size:1.5rem}}@media (max-width:480px){.dashboard h1{font-size:1.5rem}.card,.rituals-quick-log,.seven-day-chart-section{padding:12px}.chart-container-dashboard{height:250px}.warning-card{padding:1.25rem}.warning-header h3{font-size:1.2rem}.interaction-drugs{font-size:1rem}.stat-value{font-size:1.5rem}}@media (max-width:375px){.ritual-info{min-width:0}.ritual-description,.ritual-drugs,.ritual-name{font-size:.9rem}.interaction-drugs{font-size:.95rem}.warning-header h3{font-size:1.1rem}}@media (max-width:360px){.dashboard h1{font-size:1.35rem}.ritual-card{padding:10px}.stats-grid,.toxicity-details{grid-template-columns:1fr}.chart-container-dashboard{height:220px}.warning-card{padding:1rem}.interaction-item{padding:.875rem}}.full-width-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.full-width-section h2{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem;padding-bottom:.75rem}.blood-levels-grid{display:flex;flex-wrap:wrap;gap:1rem;width:100%}.blood-levels-grid>*{flex-basis:calc(25% - 0.75rem);flex-grow:1;flex-shrink:1;max-width:calc(50% - .5rem);min-width:180px}@media (max-width:1200px){.blood-levels-grid>*{flex-basis:calc(33.333% - 0.67rem);flex-grow:1;flex-shrink:1}}@media (max-width:768px){.blood-levels-grid>*{flex-basis:calc(50% - 0.5rem);flex-grow:1;flex-shrink:1;min-width:140px}}@media (max-width:480px){.blood-levels-grid>*{flex:1 1 100%;max-width:100%}}.blood-level-card{background:var(--bg-secondary);border-left:4px solid var(--primary-color);border-radius:10px;padding:1rem 1.25rem}.blood-level-card.aggregated{background:linear-gradient(135deg,var(--bg-secondary) 0,#10b9810d 100%);border-left-color:var(--success-color)}.blood-level-card .level-name{color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blood-level-card .level-concentration{color:var(--primary-color);font-size:1.75rem;font-weight:700;line-height:1.1}.blood-level-card .level-unit{color:var(--text-secondary);font-size:.875rem;font-weight:500;margin-left:.25rem}.blood-level-card .level-range-status{margin-top:.5rem}.blood-level-card .level-range-info{color:var(--text-secondary);font-size:.75rem;margin-top:.25rem}.blood-level-card .level-components{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.component-badge{background:#667eea1a;border-radius:4px;color:var(--primary-color);font-size:.7rem;padding:.125rem .5rem}.active-doses-grid{display:flex;flex-wrap:wrap;gap:1rem;width:100%}.active-doses-grid>*{flex:1 1 200px;min-width:180px}@media (max-width:480px){.active-doses-grid>*{flex:1 1 100%}}.active-dose-card{background:var(--bg-secondary);border-left:4px solid var(--primary-color);border-radius:10px;padding:1rem 1.25rem}.active-dose-card .dose-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.active-dose-card .dose-drug-name{color:var(--text-primary);font-size:.95rem;font-weight:600;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.active-dose-card .dose-route-badge{background:var(--primary-color);border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:.125rem .5rem}.active-dose-card .dose-info{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.active-dose-card .dose-amount{color:var(--text-primary);font-size:1.1rem;font-weight:700;white-space:nowrap}.active-dose-card .dose-time{color:var(--text-secondary);font-size:.7rem;text-align:right;white-space:nowrap}.active-doses-grid.grouped{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.active-dose-card.grouped-card{transition:all .2s ease}.active-dose-card.grouped-card.expanded{background:var(--card-bg);box-shadow:0 4px 12px var(--shadow)}.active-dose-card .dose-header.clickable{align-items:center;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin:-.25rem;padding:.25rem;transition:background .15s ease}.active-dose-card .dose-header.clickable:hover{background:var(--hover-bg)}.active-dose-card .dose-header-main{align-items:center;display:flex;flex:1 1;gap:.5rem;min-width:0}.active-dose-card .expand-indicator{color:var(--text-secondary);flex-shrink:0;font-size:.7rem;margin-left:.5rem;transition:transform .2s ease}.active-dose-card .expand-indicator.expanded{color:var(--primary-color)}.active-dose-card .dose-summary{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin:.75rem 0 .5rem}.active-dose-card .dose-count-badge{background:var(--primary-color);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.active-dose-card .dose-total{color:var(--text-secondary);font-size:.85rem;font-weight:500}.active-dose-card .dose-time-range{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.5rem;margin-top:.25rem}.active-dose-card .time-label{font-weight:500}.active-dose-card .expanded-doses{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.active-dose-card .expanded-dose-item{align-items:center;background:var(--hover-bg);border-radius:6px;display:flex;font-size:.85rem;gap:.75rem;padding:.5rem .75rem}.active-dose-card .dose-number{color:var(--text-tertiary);font-size:.7rem;font-weight:600;min-width:24px}.active-dose-card .expanded-dose-item .dose-amount{color:var(--text-primary);flex:1 1;font-size:.9rem;font-weight:600}.active-dose-card .expanded-dose-item .dose-time{color:var(--text-secondary);font-size:.75rem}.health-metrics-section,.insights-section,.predictions-section,.recommendations-section{margin-bottom:2rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:900px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;color:var(--text-secondary,#666);cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#f5f5f5;background:var(--hover-bg,#f5f5f5);color:#1a1a1a;color:var(--text-primary,#1a1a1a)}@media (prefers-color-scheme:dark){.modal-content{background:#2a2a2a;background:var(--card-bg,#2a2a2a)}.modal-close:hover{background:#3a3a3a;background:var(--hover-bg,#3a3a3a)}}@media (max-width:768px){.modal-overlay{padding:0}.modal-content{border-radius:0;max-height:100vh;max-width:100%}.modal-header{padding:1rem}.modal-header h2{font-size:1.25rem}}.food-timing-mini{align-items:center;border-radius:50%;cursor:help;display:inline-flex;font-size:.8rem;height:24px;justify-content:center;transition:transform .2s ease;width:24px}.food-timing-mini:hover{transform:scale(1.15)}.food-timing-mini.food-with{background:#10b98126}.food-timing-mini.food-empty{background:#f59e0b26}.food-timing-mini.food-fat{background:#667eea26}.food-timing-mini.food-either{background:var(--hover-bg)}.dose-summary{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.notification-bell-container{position:relative}.notification-bell{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.5rem;padding:.5rem;position:relative;transition:background-color .2s}.notification-bell:hover{background-color:var(--bg-secondary)}.notification-badge{background-color:var(--danger-color);border-radius:10px;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;padding:.15rem .35rem;position:absolute;right:0;text-align:center;top:0}.notification-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:500px;max-width:90vw;position:absolute;right:0;top:calc(100% + .5rem);width:380px;z-index:1000}.notification-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem}.notification-header h3{color:var(--text-primary);font-size:1.1rem;margin:0}.mark-all-read-btn{background:none;border:none;border-radius:4px;color:var(--primary-color);cursor:pointer;font-size:.85rem;padding:.25rem .5rem;transition:background-color .2s}.mark-all-read-btn:hover{background-color:var(--bg-secondary)}.notification-list{flex:1 1;max-height:400px;overflow-y:auto}.notification-loading{padding:2rem}.notification-empty,.notification-loading{color:var(--text-secondary);text-align:center}.notification-empty{padding:3rem 1rem}.notification-empty span{display:block;font-size:3rem;margin-bottom:.5rem}.notification-empty p{margin:0}.notification-item{border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;padding:1rem;position:relative;transition:background-color .2s}.notification-item:hover{background-color:var(--bg-secondary)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:#3b82f60d}.notification-item.unread:before{background-color:var(--primary-color);bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.notification-icon{font-size:1.5rem}.notification-content{min-width:0}.notification-title{color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:.9rem;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis}.notification-time{color:var(--text-tertiary);font-size:.8rem}.notification-quick-action-btn{align-items:center;background:linear-gradient(135deg,var(--gradient-start) 0,var(--gradient-end) 100%);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow);color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;margin:.5rem 0;padding:.5rem 1rem;transition:all var(--transition-normal);width:100%}.notification-quick-action-btn:hover{background:linear-gradient(135deg,var(--gradient-end) 0,var(--gradient-start) 100%);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.notification-quick-action-btn:active{box-shadow:var(--shadow);transform:translateY(0)}.notification-actions{display:flex;flex-shrink:0;gap:.25rem}.notification-action-btn{align-items:center;background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.2rem;height:28px;justify-content:center;transition:all .2s;width:28px}.notification-action-btn:hover{background-color:var(--bg-tertiary);border-color:var(--text-secondary)}.notification-action-btn.delete:hover{background-color:#dc35451a;background-color:var(--danger-bg,#dc35451a);border-color:var(--danger-color);color:var(--danger-color)}.notification-footer{border-top:1px solid var(--border-color);padding:.75rem 1rem;text-align:center}.view-all-link{color:var(--primary-color);font-size:.9rem;font-weight:500;text-decoration:none}.view-all-link:hover{text-decoration:underline}[data-theme=dark] .notification-panel{box-shadow:var(--shadow-lg)}[data-theme=dark] .notification-item.unread{background-color:#3b82f61a}@media (max-width:768px){.notification-panel{right:-50px;width:340px}}@media (max-width:480px){.notification-panel{border-radius:0;left:0;max-height:calc(100vh - 60px);max-width:100%;position:fixed;right:0;top:60px;width:100%}}.command-palette-overlay{align-items:flex-start;animation:fadeIn .1s ease-out;background:#00000080;display:flex;inset:0;justify-content:center;padding-top:15vh;position:fixed;z-index:9999}.command-palette{animation:slideDown .15s ease-out;background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 25px 50px -12px #00000040;max-width:640px;overflow:hidden;width:100%}.command-input-wrapper{align-items:center;border-bottom:1px solid #ddd;border-bottom:1px solid var(--border-color,#ddd);display:flex;gap:12px;padding:16px 20px}.command-search-icon{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);flex-shrink:0}.command-palette [cmdk-input]{background:#0000;border:none;color:#2c3e50;color:var(--text-primary,#2c3e50);flex:1 1;font-family:inherit;font-size:16px;outline:none}.command-palette [cmdk-input]::placeholder{color:#7f8c8d;color:var(--text-secondary,#7f8c8d)}.command-palette [cmdk-list]{max-height:400px;overflow-y:auto;padding:8px}.command-palette [cmdk-empty]{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);font-size:14px;padding:32px;text-align:center}.command-palette [cmdk-group-heading]{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 12px 4px;text-transform:uppercase}.command-palette [cmdk-item]{align-items:center;border-radius:8px;color:#2c3e50;color:var(--text-primary,#2c3e50);cursor:pointer;display:flex;font-size:14px;gap:12px;padding:12px 16px;transition:background-color .1s ease}.command-palette [cmdk-item] svg{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);flex-shrink:0}.command-palette [cmdk-item][data-selected=true]{background:#667eea;background:var(--primary-color,#667eea);color:#fff}.command-palette [cmdk-item][data-selected=true] svg{color:#fff}.command-palette [cmdk-item]:hover:not([data-selected=true]){background:#f8f9fa;background:var(--hover-bg,#f8f9fa)}.command-footer{background:#f8f9fa;background:var(--bg-secondary,#f8f9fa);border-top:1px solid #ddd;border-top:1px solid var(--border-color,#ddd);gap:24px;justify-content:center;padding:12px 16px}.command-footer,.command-hint{align-items:center;display:flex}.command-hint{color:#7f8c8d;color:var(--text-secondary,#7f8c8d);font-size:12px;gap:6px}.command-hint kbd{background:#fff;background:var(--card-bg,#fff);border:1px solid #ddd;border:1px solid var(--border-color,#ddd);border-radius:4px;box-shadow:0 1px 2px #0000000d;font-family:inherit;font-size:11px;padding:2px 6px}[data-theme=dark] .command-palette{box-shadow:0 25px 50px -12px #00000080}@media (max-width:640px){.command-palette-overlay{padding:10vh 8px 8px}.command-palette{max-width:none}.command-footer{flex-wrap:wrap;gap:12px}}.mobile-nav{bottom:0;display:none;left:0;position:fixed;right:0;z-index:100}@media (max-width:768px){.mobile-nav{display:block}.main-content{padding-bottom:80px}}.mobile-nav-container{align-items:center;background:var(--card-bg);border-top:1px solid var(--border-color);box-shadow:var(--shadow-lg);display:flex;justify-content:space-around;padding:8px 0 max(8px,env(safe-area-inset-bottom))}.mobile-nav-item{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;min-width:64px;padding:var(--space-sm) var(--space-md);text-decoration:none;transition:color var(--transition-fast)}.mobile-nav-item svg{transition:transform .15s ease}.mobile-nav-item.active{color:var(--primary-color)}.mobile-nav-item.active svg{transform:scale(1.1)}.mobile-nav-label{font-size:11px;font-weight:500;margin-top:4px}.mobile-nav-fab-space{width:64px}.mobile-nav-fab{align-items:center;background:var(--primary-color);border:none;border-radius:50%;box-shadow:var(--shadow-lg);color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;left:50%;position:absolute;top:-24px;transform:translateX(-50%);transition:transform var(--transition-fast),box-shadow var(--transition-fast);width:56px}.mobile-nav-fab:hover{box-shadow:var(--shadow-hover);transform:translateX(-50%) scale(1.05)}.mobile-nav-fab:active{transform:translateX(-50%) scale(.95)}[data-theme=dark] .mobile-nav-container{background:var(--bg-secondary);border-top-color:var(--border-color)}[data-theme=dark] .mobile-nav-fab{box-shadow:var(--shadow-lg)}@media (max-height:500px) and (orientation:landscape){.mobile-nav{display:none}.main-content{padding-bottom:0}}.account-switcher{align-items:center;display:flex;position:relative}.switcher-button{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;min-width:140px;padding:.5rem .75rem;transition:all .2s}.switcher-button:hover{background:var(--bg-hover);border-color:var(--primary-color)}.switcher-button.managing-other{background:#4f46e51a;background:var(--primary-bg,#4f46e51a);border-color:var(--primary-color)}.switcher-icon{align-items:center;color:var(--text-secondary);display:flex;justify-content:center}.switcher-button.managing-other .switcher-icon{color:var(--primary-color)}.switcher-label{flex:1 1;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.switcher-dropdown{animation:slideDown .2s ease;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #00000026;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);width:280px;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{color:var(--text-tertiary);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.75rem 1rem .5rem;text-transform:uppercase}.switcher-option{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background .15s;width:100%}.switcher-option:hover{background:var(--bg-hover)}.switcher-option.active{background:#4f46e51a;background:var(--primary-bg,#4f46e51a)}.option-avatar{align-items:center;background:var(--primary-color);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:36px;justify-content:center;width:36px}.option-avatar.self{background:#10b981;background:var(--success-color,#10b981)}.option-avatar.dependent{background:#3b82f6;background:var(--info-color,#3b82f6)}.option-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.option-name{color:var(--text-primary);font-weight:500}.option-email,.option-meta,.option-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.option-email,.option-meta{color:var(--text-tertiary);font-size:.75rem}.switcher-option svg{color:var(--primary-color);flex-shrink:0}.managing-indicator{background:var(--primary-color);color:#fff;font-size:.875rem;font-weight:500;left:0;padding:.5rem;position:fixed;right:0;text-align:center;top:0;z-index:9999}@media (max-width:768px){.switcher-button{min-width:auto;padding:.5rem}.switcher-label{display:none}.switcher-dropdown{border-radius:16px 16px 0 0;bottom:0;left:0;max-height:60vh;overflow-y:auto;position:fixed;right:0;top:auto;width:100%}}.language-selector-dropdown{position:relative}.lang-flag-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all var(--transition-normal);width:36px}.lang-flag-button:hover{background:var(--bg-hover)}.lang-code{color:var(--text-primary);font-size:.875rem;font-weight:var(--font-semibold);letter-spacing:.5px;text-transform:uppercase}.lang-backdrop{inset:0;position:fixed;z-index:var(--z-dropdown)}.lang-menu{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + var(--space-sm));z-index:calc(var(--z-dropdown) + 1)}.lang-menu-item{align-items:center;background:#0000;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-md);padding:var(--space-md);text-align:left;transition:all var(--transition-fast);width:100%}.lang-menu-item:hover{background:var(--bg-hover)}.lang-menu-item.active{background:#3b82f61a;color:var(--primary-color);font-weight:var(--font-medium)}.lang-menu-item:disabled{cursor:not-allowed;opacity:.5}.menu-lang-code{color:var(--text-secondary);font-size:.75rem;font-weight:var(--font-bold);letter-spacing:.5px;min-width:28px;text-align:center;text-transform:uppercase}.menu-lang-name{font-family:Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji,sans-serif}.lang-check{color:var(--primary-color);margin-left:auto}.language-select,.language-select-inline{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-family:Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji,sans-serif;font-size:var(--text-base);padding:var(--space-md);transition:all var(--transition-normal);width:100%}.language-select:hover{background:var(--bg-hover);border-color:var(--primary-color)}.language-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a;outline:none}.language-select:disabled{cursor:not-allowed;opacity:.5}.language-select option{background:var(--card-bg);color:var(--text-primary);font-family:Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji,sans-serif;padding:var(--space-md)}@media (max-width:768px){.language-options{grid-template-columns:1fr}.lang-menu{left:auto;right:0}}.medication-reminder-toast{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);bottom:var(--space-lg);box-shadow:var(--shadow-lg);max-width:calc(100vw - var(--space-lg)*2);overflow:hidden;position:fixed;right:var(--space-lg);transition:all var(--transition-normal);width:380px;z-index:var(--z-toast)}.medication-reminder-toast.has-overdue{animation:pulse-border 2s ease-in-out infinite;border-color:var(--danger-color);box-shadow:0 0 0 2px #ef444433,var(--shadow-lg)}@keyframes pulse-border{0%,to{box-shadow:0 0 0 2px #ef444433,var(--shadow-lg)}50%{box-shadow:0 0 0 4px #ef44444d,var(--shadow-lg)}}.medication-reminder-toast.collapsed{min-width:200px;width:auto}.reminder-toast-header{align-items:center;background:var(--bg-secondary);cursor:pointer;display:flex;justify-content:space-between;padding:var(--space-sm) var(--space-md);transition:background var(--transition-fast);-webkit-user-select:none;user-select:none}.reminder-toast-header:hover{background:var(--bg-hover)}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm)}.header-icon{font-size:1.25rem}.header-text{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm)}.overdue-badge{background:#ef444426;color:var(--danger-color)}.due-soon-badge,.overdue-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:.25rem;padding:.125rem .5rem}.due-soon-badge{background:#f59e0b26;color:var(--warning-color)}.expand-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);padding:var(--space-xs);transition:transform var(--transition-fast)}.medication-reminder-toast.collapsed .expand-toggle{transform:rotate(180deg)}.reminder-toast-content{max-height:400px;overflow-y:auto}.reminder-toast-item{align-items:flex-start;border-bottom:1px solid var(--border-subtle);display:flex;gap:var(--space-sm);justify-content:space-between;padding:var(--space-md);transition:background var(--transition-fast)}.reminder-toast-item:last-child{border-bottom:none}.reminder-toast-item:hover{background:var(--bg-hover)}.reminder-toast-item.overdue{background:#ef44440d;border-left:3px solid var(--danger-color)}.reminder-toast-item.overdue:hover{background:#ef44441a}.reminder-toast-item.due_soon{background:#f59e0b0d;border-left:3px solid var(--warning-color)}.reminder-toast-item.due_soon:hover{background:#f59e0b1a}.reminder-toast-item.success{background:#22c55e1a;border-left:3px solid var(--success-color)}.success-message{animation:slide-in .3s ease-out;color:var(--success-color);font-weight:var(--font-medium);gap:var(--space-sm)}.success-icon,.success-message{align-items:center;display:flex}.success-icon{background:var(--success-color);border-radius:var(--radius-full);color:#fff;font-size:var(--text-sm);height:24px;justify-content:center;width:24px}@keyframes slide-in{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.reminder-info{flex:1 1;min-width:0}.reminder-name{align-items:center;display:flex;gap:var(--space-xs);margin-bottom:.25rem}.ritual-icon{font-size:1rem}.ritual-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reminder-timing{font-size:var(--text-xs);margin-bottom:.25rem}.overdue-text{color:var(--danger-color);font-weight:var(--font-medium)}.due-text{color:var(--text-secondary)}.reminder-drugs-count{color:var(--text-muted);font-size:var(--text-xs)}.reminder-actions{flex-shrink:0;gap:.25rem}.action-btn,.reminder-actions{align-items:center;display:flex}.action-btn{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--font-medium);justify-content:center;padding:.375rem .5rem;transition:all var(--transition-fast);white-space:nowrap}.action-btn:disabled{cursor:not-allowed;opacity:.5}.taken-btn{background:var(--success-color);color:#fff;padding:.375rem .75rem}.taken-btn:hover:not(:disabled){background:#16a34a;transform:scale(1.02)}.snooze-btn{background:var(--bg-secondary);color:var(--text-secondary)}.snooze-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--warning-color)}.skip-btn{background:var(--bg-secondary);color:var(--text-secondary)}.skip-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--danger-color)}.dismiss-btn{background:#0000;color:var(--text-muted);font-size:var(--text-base);padding:.25rem}.dismiss-btn:hover:not(:disabled){color:var(--text-secondary)}.more-reminders{background:var(--bg-secondary);color:var(--text-muted);font-size:var(--text-xs);padding:var(--space-sm);text-align:center}.reminder-toast-footer{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:var(--space-sm) var(--space-md)}.view-all-btn{background:#0000;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--primary-color);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-sm);transition:all var(--transition-fast);width:100%}.view-all-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}@media (max-width:480px){.medication-reminder-toast{bottom:var(--space-md);left:var(--space-md);max-width:none;right:var(--space-md);width:auto}.reminder-toast-item{flex-direction:column;gap:var(--space-sm)}.reminder-actions{justify-content:flex-start;width:100%}.taken-btn{flex:1 1}}.reminder-toast-content::-webkit-scrollbar{width:6px}.reminder-toast-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.reminder-toast-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.reminder-toast-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}[data-theme=dark] .medication-reminder-toast{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .reminder-toast-item.overdue{background:#ef44441a}[data-theme=dark] .reminder-toast-item.due_soon{background:#f59e0b1a}.layout{background-color:var(--bg-primary);min-height:100vh;transition:background-color .3s ease}.navbar{background-color:var(--card-bg);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px #0000004d;color:var(--text-primary);justify-content:space-between;padding:1rem 2rem}.navbar,.navbar-brand,.navbar-brand .brand-link{align-items:center;display:flex}.navbar-brand .brand-link{gap:.5rem;text-decoration:none;transition:opacity .2s}.navbar-brand .brand-link:hover{opacity:.85}.navbar-brand .brand-text{color:#f3f7fa;color:var(--kyx-text-primary,#f3f7fa);font-family:var(--font-display);font-size:1.25rem;font-weight:700;letter-spacing:.1em}.navbar-menu{align-items:center;display:flex;gap:1.5rem}.nav-link{border-radius:4px;color:var(--text-primary);padding:.5rem 1rem;text-decoration:none;transition:background-color .2s,color .2s}.nav-link:hover{background-color:var(--hover-bg)}.nav-link.active{background-color:#3b82f61a;color:var(--primary-color);font-weight:600}[data-theme=dark] .nav-link.active{background-color:#3b82f633}.nav-link.nav-admin{background-color:var(--primary-color);color:#fff;font-weight:600}.nav-link.nav-admin.active,.nav-link.nav-admin:hover{background-color:var(--primary-hover)}.nav-link.nav-admin.active{box-shadow:0 0 0 2px var(--shadow)}.nav-user{color:var(--text-secondary);margin-left:1rem;transition:color .2s}.btn-logout{background-color:var(--danger-color);border-radius:4px;color:#fff;padding:.5rem 1rem;transition:background-color .2s}.btn-logout:hover{background-color:var(--danger-hover)}.nav-dropdown{display:inline-block;padding-bottom:.5rem;position:relative}.dropdown-toggle{cursor:pointer;display:inline-block;-webkit-user-select:none;user-select:none}.dropdown-menu{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px var(--shadow);left:0;margin-top:.25rem;min-width:220px;padding:.5rem 0;position:absolute;top:100%;transition:background-color .2s;z-index:1000}.dropdown-menu:before{background:#0000;content:"";height:.25rem;left:0;position:absolute;right:0;top:-.25rem}[data-theme=dark] .dropdown-menu{background-color:var(--card-bg)}.dropdown-item{align-items:center;color:var(--text-primary);display:flex;font-size:.95rem;gap:.75rem;padding:.75rem 1.25rem;text-decoration:none;transition:background-color .15s,color .15s;width:100%}.dropdown-icon{flex-shrink:0;font-size:1.1rem;text-align:center;width:1.5rem}.dropdown-item:hover{background-color:var(--hover-bg);color:var(--primary-color)}.dropdown-item.dropdown-action{background:var(--primary-color);border-radius:6px;color:#fff;font-weight:600;margin:.25rem .5rem;width:auto}.dropdown-item.dropdown-action:hover{background:var(--primary-hover);color:#fff}.dropdown-divider{background:var(--border-color);height:1px;margin:.5rem 0}.nav-search-btn{align-items:center;background:var(--hover-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;gap:.5rem;padding:.5rem .75rem;transition:all .15s ease}.nav-search-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--text-primary)}.nav-avatar{padding:0}.avatar-circle{align-items:center;background:var(--primary-color);border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;transition:transform .15s ease;width:36px}.nav-avatar:hover .avatar-circle{transform:scale(1.05)}.nav-avatar.active .avatar-circle{box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--primary-color)}.btn-logout{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:color .15s ease,background-color .15s ease}.btn-logout:hover{background:#dc35451a;background:var(--danger-bg,#dc35451a);color:var(--danger-color)}.dropdown-toggle{align-items:center;display:flex;gap:.25rem}.dropdown-toggle svg{transition:transform .15s ease}.nav-dropdown:hover .dropdown-toggle svg{transform:rotate(180deg)}.main-content{margin:0 auto;max-width:1400px;padding:2rem}.mobile-menu-toggle{background:none;border:none;color:var(--text-primary);cursor:pointer;display:none;font-size:1.8rem;min-height:44px;min-width:44px;padding:.5rem;transition:color .2s}.mobile-menu-toggle:hover{color:var(--primary-color)}@media (max-width:968px){.mobile-menu-toggle{display:block}.navbar{flex-wrap:wrap;position:relative}.navbar-brand{flex:1 1}.navbar-menu{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow);display:none;flex-direction:column;left:0;max-height:0;overflow:hidden;position:absolute;right:0;top:100%;transition:max-height .3s ease-in-out;z-index:1000}.navbar-menu.mobile-open{display:flex;max-height:80vh;overflow-y:auto}.navbar-menu .btn-logout,.navbar-menu .nav-link,.navbar-menu .nav-user{border-bottom:1px solid var(--border-color);border-radius:0;padding:1rem 2rem;text-align:left;width:100%}.navbar-menu .nav-link:last-child{border-bottom:none}.nav-dropdown{width:100%}.nav-dropdown .dropdown-toggle{border-bottom:1px solid var(--border-color);padding:1rem 2rem;text-align:left;width:100%}.dropdown-menu{background-color:var(--hover-bg);border:none;border-radius:0;box-shadow:none;margin:0;padding:0;position:static}.dropdown-item{border-bottom:1px solid var(--border-color);padding:.75rem 3rem}.nav-user{color:var(--text-secondary);font-size:.9rem}.btn-logout{background-color:var(--danger-color);color:#fff;margin:1rem;text-align:center;width:calc(100% - 2rem)}}@media (max-width:768px){.main-content{padding:1rem}}@media (max-width:480px){.navbar{padding:.75rem 1rem}.navbar-brand a{font-size:1.25rem}.main-content{padding:.75rem}.navbar-menu .btn-logout,.navbar-menu .nav-link,.navbar-menu .nav-user{align-items:center;display:flex;min-height:44px}}@media (max-width:360px){.navbar{padding:.625rem .875rem}.navbar-brand a{font-size:1.15rem}.main-content{padding:.625rem}.mobile-menu-toggle{font-size:1.6rem;min-height:40px;min-width:40px;padding:.4rem}.navbar-menu .btn-logout,.navbar-menu .nav-link,.navbar-menu .nav-user{font-size:.95rem;padding:.875rem 1.5rem}.dropdown-item{font-size:.9rem;padding:.65rem 1rem}}.legal-check-loading{align-items:center;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;gap:1rem;height:100vh;justify-content:center}.legal-check-spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:50px;width:50px}.legal-check-error{align-items:center;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;gap:1rem;height:100vh;justify-content:center;padding:2rem;text-align:center}.legal-check-error .error-icon{font-size:4rem}.legal-check-error h2{color:var(--text-primary);margin:0}.legal-check-error p{color:var(--text-secondary);max-width:400px}.legal-agreement-gate{align-items:flex-start;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:2rem}.legal-gate-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-top:2rem;max-width:700px;padding:2rem;width:100%}.legal-gate-header{margin-bottom:2rem;text-align:center}.legal-gate-logo{font-size:4rem;margin-bottom:1rem}.legal-gate-header h1{color:var(--text-primary);font-size:1.75rem;margin:0 0 .5rem}.legal-gate-header p{color:var(--text-secondary);font-size:1rem;margin:0}.legal-gate-error{background:#ef44441a;border:1px solid var(--danger-color);border-radius:var(--radius-md);color:var(--danger-color);margin-bottom:1.5rem;padding:.75rem 1rem;text-align:center}.legal-documents-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.legal-document-item{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;gap:1rem;padding:1.5rem;transition:border-color .2s}.legal-document-item:hover{border-color:var(--primary-color)}.document-icon{flex-shrink:0;font-size:2rem}.document-info{flex:1 1;min-width:0}.document-info h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.document-meta{color:var(--text-secondary);font-size:.85rem;margin:0 0 .5rem}.document-summary{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.document-actions{display:flex;flex-direction:column;flex-shrink:0;gap:.5rem}.document-actions .btn-outline{background:#0000;border:1px solid var(--primary-color);border-radius:var(--radius-md);color:var(--primary-color);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.document-actions .btn-outline:hover{background:#3b82f61a}.document-actions .btn-primary{background:var(--primary-color);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.document-actions .btn-primary:hover:not(:disabled){background:var(--primary-hover)}.document-actions .btn-primary:disabled{cursor:not-allowed;opacity:.6}.legal-gate-footer{border-top:1px solid var(--border-color);padding-top:1.5rem;text-align:center}.legal-gate-footer p{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0}.legal-modal-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.legal-modal-content{background:var(--card-bg);border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.legal-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:1.25rem 1.5rem}.legal-modal-header h2{color:var(--text-primary);font-size:1.25rem;margin:0}.modal-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.75rem;line-height:1;padding:0;transition:color .2s}.modal-close-btn:hover{color:var(--text-primary)}.legal-modal-meta{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);color:var(--text-secondary);display:flex;flex-shrink:0;font-size:.85rem;gap:.5rem;padding:.75rem 1.5rem}.meta-separator{color:var(--text-muted)}.legal-modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.legal-document-text{color:var(--text-primary);font-size:.95rem;line-height:1.7}.legal-document-text h1,.legal-document-text h2,.legal-document-text h3{color:var(--text-primary);margin-bottom:.75rem;margin-top:1.5rem}.legal-document-text h1:first-child,.legal-document-text h2:first-child,.legal-document-text h3:first-child{margin-top:0}.legal-document-text p{margin-bottom:1rem}.legal-document-text ol,.legal-document-text ul{margin-bottom:1rem;padding-left:1.5rem}.legal-document-text li{margin-bottom:.5rem}.legal-modal-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;gap:.75rem;padding:1.25rem 1.5rem}.scroll-reminder{align-items:center;background:#f59e0b1a;border:1px solid var(--warning-color);border-radius:var(--radius-md);color:var(--warning-color);display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem}.modal-buttons{display:flex;gap:.75rem;justify-content:flex-end}.scroll-end-marker{border-top:1px dashed var(--border-color);margin-top:2rem;padding:1rem;text-align:center}.scroll-complete{color:var(--success-color);font-size:.9rem;font-weight:600}.scroll-hint{animation:pulse 2s ease-in-out infinite;color:var(--text-secondary);font-size:.9rem}.btn-disabled{background:var(--text-muted)!important;cursor:not-allowed!important;opacity:.5!important}.legal-modal-footer .btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.legal-modal-footer .btn-secondary:hover{background:var(--bg-hover)}.legal-modal-footer .btn-primary{background:var(--primary-color);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.legal-modal-footer .btn-primary:hover:not(:disabled){background:var(--primary-hover)}.legal-modal-footer .btn-primary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:640px){.legal-agreement-gate{padding:1rem}.legal-gate-container{margin-top:1rem;padding:1.5rem}.legal-document-item{flex-direction:column;gap:.75rem}.document-actions{flex-direction:row;width:100%}.document-actions button{flex:1 1}.legal-modal-footer{flex-direction:column}.legal-modal-footer button{width:100%}}.onboarding-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.onboarding-container{animation:slideUp .4s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:90%}.onboarding-header{border-bottom:1px solid #e0e0e0;padding:30px 40px;position:relative}.onboarding-skip-btn{background:none;border:none;border-radius:6px;color:#666;cursor:pointer;font-size:14px;padding:8px 16px;position:absolute;right:20px;top:20px;transition:all .2s}.onboarding-skip-btn:hover{background:#f5f5f5;color:#333}.onboarding-title{color:#1a1a1a;font-size:28px;font-weight:600;margin:0 0 10px}.onboarding-subtitle{color:#666;font-size:16px;margin:0}.onboarding-progress{background:#f8f9fa;padding:20px 40px}.progress-steps{justify-content:space-between;margin-bottom:10px}.progress-step,.progress-steps{align-items:center;display:flex}.progress-step{flex:1 1;position:relative}.progress-step:not(:last-child):after{background:#e0e0e0;content:"";flex:1 1;height:2px;margin:0 10px;transition:background .3s}.progress-step.completed:not(:last-child):after{background:#4caf50}.progress-dot{align-items:center;background:#e0e0e0;border-radius:50%;color:#999;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:32px;justify-content:center;transition:all .3s;width:32px}.progress-step.completed .progress-dot{background:#4caf50;color:#fff}.progress-step.active .progress-dot{background:#2196f3;box-shadow:0 0 0 4px #2196f333;color:#fff;transform:scale(1.1)}.progress-bar{background:#e0e0e0;border-radius:3px;height:6px;overflow:hidden;width:100%}.progress-bar-fill{background:linear-gradient(90deg,#2196f3,#4caf50);border-radius:3px;height:100%;transition:width .4s ease}.progress-text{color:#666;font-size:14px;margin-top:12px;text-align:center}.onboarding-content{flex:1 1;overflow-y:auto;padding:40px}.step-transition-enter{opacity:0;transform:translateX(30px)}.step-transition-enter-active{transition:all .3s ease}.step-transition-enter-active,.step-transition-exit{opacity:1;transform:translateX(0)}.step-transition-exit-active{opacity:0;transform:translateX(-30px);transition:all .3s ease}.onboarding-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 40px}.footer-buttons{display:flex;gap:12px}.onboarding-btn{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s}.onboarding-btn:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-primary{background:#2196f3}.btn-primary:hover:not(:disabled){background:#1976d2;box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.btn-success{background:#4caf50;color:#fff}.btn-success:hover:not(:disabled){background:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-1px)}.dark-mode .onboarding-container{background:#1e1e1e;color:#e0e0e0}.dark-mode .onboarding-header{border-bottom-color:#333}.dark-mode .onboarding-title{color:#e0e0e0}.dark-mode .onboarding-subtitle,.dark-mode .progress-text{color:#999}.dark-mode .onboarding-progress{background:#252525}.dark-mode .progress-dot{background:#333;color:#666}.dark-mode .progress-bar{background:#333}.dark-mode .onboarding-footer{border-top-color:#333}.dark-mode .btn-secondary{background:#333;color:#e0e0e0}.dark-mode .btn-secondary:hover:not(:disabled){background:#404040}.dark-mode .onboarding-skip-btn{color:#999}.dark-mode .onboarding-skip-btn:hover{background:#2a2a2a;color:#e0e0e0}@media (max-width:768px){.onboarding-container{max-height:95vh;width:95%}.onboarding-content,.onboarding-footer,.onboarding-header{padding:20px}.onboarding-title{font-size:24px}.onboarding-subtitle{font-size:14px}.progress-dot{font-size:12px;height:24px;width:24px}.progress-step:not(:last-child):after{margin:0 6px}.onboarding-footer{flex-direction:column;gap:12px}.footer-buttons{justify-content:space-between;width:100%}.onboarding-btn{flex:1 1;font-size:14px;padding:10px 16px}}.step-content{animation:fadeInUp .4s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;font-size:36px;height:80px;justify-content:center;margin:0 auto 24px;width:80px}.step-heading{color:#1a1a1a;font-size:24px;font-weight:600;margin:0 0 16px;text-align:center}.dark-mode .step-heading{color:#e0e0e0}.step-description{color:#333;font-size:16px;line-height:1.6;margin:0 0 32px;text-align:center}.dark-mode .step-description{color:#ccc}.form-group{margin-bottom:24px}.form-label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.dark-mode .form-label{color:#e0e0e0}.form-input,.form-select{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .2s;width:100%}.form-input:focus,.form-select:focus{border-color:#2196f3;box-shadow:0 0 0 4px #2196f31a;outline:none}.dark-mode .form-input,.dark-mode .form-select{background:#2a2a2a;border-color:#404040;color:#e0e0e0}.dark-mode .form-input:focus,.dark-mode .form-select:focus{border-color:#2196f3}.form-hint{color:#666;font-size:13px;margin-top:6px}.dark-mode .form-hint{color:#999}.tooltip-icon{align-items:center;background:#e0e0e0;border-radius:50%;color:#666;cursor:help;display:inline-flex;font-size:12px;font-weight:700;height:18px;justify-content:center;margin-left:6px;position:relative;width:18px}.tooltip-icon:hover:after{background:#333;border-radius:6px;bottom:calc(100% + 8px);box-shadow:0 4px 12px #0003;color:#fff;content:attr(data-tooltip);font-size:13px;font-weight:400;left:50%;padding:8px 12px;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000}.checkbox-group{display:flex;flex-direction:column;gap:12px}.checkbox-item{align-items:flex-start;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;padding:16px;transition:all .2s}.checkbox-item:hover{background:#2196f30d;border-color:#2196f3}.checkbox-item.selected{background:#2196f31a;border-color:#2196f3}.dark-mode .checkbox-item{border-color:#404040}.dark-mode .checkbox-item:hover{background:#2196f31a}.dark-mode .checkbox-item.selected{background:#2196f326}.checkbox-item input[type=checkbox]{cursor:pointer;height:20px;margin-right:12px;width:20px}.checkbox-content{flex:1 1}.checkbox-title{color:#1a1a1a;font-weight:500;margin:0 0 4px}.dark-mode .checkbox-title{color:#e0e0e0}.checkbox-description{color:#666;font-size:14px;margin:0}.dark-mode .checkbox-description{color:#999}.loading-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;margin-right:8px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.feature-list-heading{color:#1a1a1a;font-size:18px;font-weight:600;margin-bottom:16px}.dark-mode .feature-list-heading{color:#e0e0e0}.feature-list{display:flex;flex-direction:column;gap:16px;list-style:none;padding:0}.feature-item{align-items:flex-start;display:flex;gap:12px}.feature-icon{flex-shrink:0;font-size:24px}.feature-text{color:#333;line-height:1.5}.dark-mode .feature-text{color:#ccc}.feature-text strong{color:#1a1a1a;font-weight:600}.dark-mode .feature-text strong{color:#e0e0e0}.info-box{background:#2196f31a;border-left:4px solid #2196f3;border-radius:8px;margin-top:32px;padding:16px}.dark-mode .info-box{background:#2196f326;border-left-color:#42a5f5}.info-box p{color:#333}.dark-mode .info-box p{color:#ccc}.info-box strong{color:#1a1a1a}.dark-mode .info-box strong{color:#e0e0e0}.language-step{margin:0 auto;max-width:600px;padding:var(--space-2xl)}.step-header{margin-bottom:var(--space-2xl);text-align:center}.step-header h2{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-md)}.step-description{color:var(--text-secondary);font-size:var(--text-base)}.language-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:var(--space-2xl)}.language-card{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:180px;padding:var(--space-xl);position:relative;transition:all var(--transition-normal)}.language-card:hover{background:var(--bg-hover);border-color:var(--primary-color);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.language-card.selected{background:#3b82f61a;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f633}.language-flag{font-size:4rem;margin-bottom:var(--space-md)}.language-name{color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-xs)}.language-name-english{color:var(--text-secondary);font-size:var(--text-sm)}.checkmark{align-items:center;background:var(--primary-color);border-radius:var(--radius-full);color:#fff;font-size:var(--text-lg);font-weight:var(--font-bold);height:32px;position:absolute;right:var(--space-md);top:var(--space-md);width:32px}.checkmark,.step-actions{display:flex;justify-content:center}.step-actions{gap:var(--space-md);margin-top:var(--space-2xl)}.btn-primary{background:var(--primary-color);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:var(--text-base);font-weight:var(--font-semibold);padding:var(--space-md) var(--space-2xl);transition:all var(--transition-normal)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.language-step{padding:var(--space-lg)}.language-grid{gap:var(--space-md);grid-template-columns:1fr}.language-card{min-height:140px;padding:var(--space-lg)}.language-flag{font-size:3rem}.step-header h2{font-size:var(--text-2xl)}}.tour-overlay{animation:fadeIn .3s ease;background:#0009;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9999}.tour-highlight{animation:pulse 2s infinite;border-radius:4px;box-shadow:0 0 0 4px #2196f380,0 0 0 9999px #0009!important;position:relative;z-index:10001!important}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #2196f380,0 0 0 9999px #0009}50%{box-shadow:0 0 0 8px #2196f34d,0 0 0 9999px #0009}}.tour-tooltip{animation:slideIn .3s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;position:fixed;width:320px;z-index:10000}.tour-tooltip:before{border:10px solid #0000;content:"";height:0;position:absolute;width:0}.tour-tooltip.arrow-top:before{border-bottom-color:#fff;left:50%;top:-20px;transform:translateX(-50%)}.tour-tooltip.arrow-bottom:before{border-top-color:#fff;bottom:-20px;left:50%;transform:translateX(-50%)}.tour-tooltip.arrow-left:before{border-right-color:#fff;left:-20px;top:50%;transform:translateY(-50%)}.tour-tooltip.arrow-right:before{border-left-color:#fff;right:-20px;top:50%;transform:translateY(-50%)}.tour-tooltip-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.tour-tooltip-title{color:#1a1a1a;font-size:18px;font-weight:600}.tour-close-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:20px;padding:4px 8px;transition:all .2s}.tour-close-btn:hover{background:#f5f5f5;color:#333}.tour-tooltip-content{color:#666;font-size:15px;line-height:1.6;padding:16px 20px}.tour-tooltip-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.tour-progress{color:#999;font-size:13px}.tour-buttons{display:flex;gap:8px}.tour-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.tour-btn-secondary{background:#f5f5f5;color:#333}.tour-btn-secondary:hover{background:#e0e0e0}.tour-btn-primary{background:#2196f3;color:#fff}.tour-btn-primary:hover{background:#1976d2;box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.dark-mode .tour-tooltip{background:#1e1e1e;color:#e0e0e0}.dark-mode .tour-tooltip-title{color:#e0e0e0}.dark-mode .tour-tooltip-content{color:#999}.dark-mode .tour-tooltip-footer,.dark-mode .tour-tooltip-header{border-color:#333}.dark-mode .tour-close-btn{color:#999}.dark-mode .tour-close-btn:hover{background:#2a2a2a;color:#e0e0e0}.dark-mode .tour-btn-secondary{background:#333;color:#e0e0e0}.dark-mode .tour-btn-secondary:hover{background:#404040}.dark-mode .tour-tooltip.arrow-top:before{border-bottom-color:#1e1e1e}.dark-mode .tour-tooltip.arrow-bottom:before{border-top-color:#1e1e1e}.dark-mode .tour-tooltip.arrow-left:before{border-right-color:#1e1e1e}.dark-mode .tour-tooltip.arrow-right:before{border-left-color:#1e1e1e}@media (max-width:768px){.tour-tooltip{max-width:300px;width:90%}.tour-tooltip-footer{align-items:stretch;flex-direction:column;gap:12px}.tour-buttons{justify-content:space-between;width:100%}.tour-btn{flex:1 1}}.offline-indicator{animation:slideUp .3s ease;border-radius:var(--radius-lg);bottom:80px;box-shadow:0 4px 12px #00000026;left:50%;padding:var(--space-sm) var(--space-md);position:fixed;transform:translateX(-50%);z-index:1100}.offline-indicator--offline{background:#fef3c7;background:var(--warning-bg,#fef3c7);border:1px solid #f59e0b;border:1px solid var(--warning,#f59e0b);color:#92400e;color:var(--warning-text,#92400e)}.offline-indicator--online{background:#d1fae5;background:var(--success-bg,#d1fae5);border:1px solid #10b981;border:1px solid var(--success,#10b981);color:#065f46;color:var(--success-text,#065f46)}.offline-indicator__content{align-items:center;display:flex;font-size:.875rem;font-weight:500;gap:var(--space-sm)}.offline-indicator__close{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:inherit;cursor:pointer;display:flex;justify-content:center;margin-left:var(--space-xs);opacity:.7;padding:var(--space-xs);transition:opacity .2s ease}.offline-indicator__close:hover{background:#0000001a;opacity:1}[data-theme=dark] .offline-indicator--offline{background:#f59e0b26;border-color:#f59e0b80;color:#fcd34d}[data-theme=dark] .offline-indicator--online{background:#10b98126;border-color:#10b98180;color:#6ee7b7}@media (min-width:640px){.offline-indicator{bottom:24px}}@media (prefers-reduced-motion:reduce){.offline-indicator{animation:none}}.websocket-notifications{display:flex;flex-direction:column;gap:12px;max-width:400px;position:fixed;right:20px;top:80px;z-index:10000}.notification{align-items:flex-start;animation:slideIn .3s ease-out;background:#fff;border-left:4px solid var(--notification-color);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;padding:16px}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.notification-info{--notification-color:#3b82f6}.notification-success{--notification-color:#10b981}.notification-warning{--notification-color:#f59e0b}.notification-error{--notification-color:#ef4444}.notification-content{align-items:flex-start;display:flex;flex:1 1;gap:12px}.notification-icon{flex-shrink:0;font-size:24px}.notification-text{flex:1 1}.notification-text strong{color:#111827;display:block;font-size:14px;font-weight:600;margin-bottom:4px}.notification-text p{color:#6b7280;font-size:13px;line-height:1.4;margin:0}.notification-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:24px;height:24px;line-height:1;padding:0;transition:color .2s;width:24px}.notification-close:hover{color:#4b5563}[data-theme=dark] .notification{background:#1f2937}[data-theme=dark] .notification-text strong{color:#f9fafb}[data-theme=dark] .notification-text p{color:#d1d5db}[data-theme=dark] .notification-close{color:#6b7280}[data-theme=dark] .notification-close:hover{color:#9ca3af}@media (max-width:768px){.websocket-notifications{left:10px;max-width:none;right:10px;top:70px}.notification{padding:12px}.notification-text strong{font-size:13px}.notification-text p{font-size:12px}}.install-banner{align-items:center;animation:slideUp .3s ease-out;background:linear-gradient(135deg,var(--primary-color),#4f46e5);bottom:0;box-shadow:0 -4px 20px #0003;color:#fff;display:flex;gap:var(--space-md);justify-content:space-between;left:0;padding:var(--space-md);position:fixed;right:0;z-index:var(--z-sticky)}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.install-banner-content{align-items:center;display:flex;flex:1 1;gap:var(--space-md);min-width:0}.install-banner-icon{flex-shrink:0;opacity:.9}.install-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.install-banner-title{font-size:var(--text-base);font-weight:var(--font-semibold)}.install-banner-subtitle{font-size:var(--text-sm);opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.install-banner-actions{align-items:center;display:flex;flex-shrink:0;gap:var(--space-sm)}.install-banner-button{border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}.install-banner-button.install{background:#fff;color:var(--primary-color)}.install-banner-button.install:hover{background:#ffffffe6;transform:translateY(-1px)}.install-banner-button.install:disabled{cursor:not-allowed;opacity:.7;transform:none}.install-banner-button.dismiss{align-items:center;background:#fff3;color:#fff;display:flex;justify-content:center;padding:var(--space-sm)}.install-banner-button.dismiss:hover{background:#ffffff4d}.install-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;display:flex;inset:0;justify-content:center;padding:var(--space-md);position:fixed;z-index:var(--z-modal)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.install-modal{animation:scaleIn .2s ease-out;background:var(--card-bg);border-radius:var(--radius-lg);max-width:400px;padding:var(--space-xl);position:relative;width:100%}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.install-modal-close{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);position:absolute;right:var(--space-md);top:var(--space-md);transition:all var(--transition-fast)}.install-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.install-modal-header{align-items:center;display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.install-modal-header h3{color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0}.platform-icon{color:var(--primary-color);height:32px;width:32px}.install-modal-description{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-lg)}.install-steps{flex-direction:column;margin-bottom:var(--space-xl)}.install-step,.install-steps{display:flex;gap:var(--space-md)}.install-step{align-items:flex-start}.step-number{background:var(--primary-color);border-radius:var(--radius-full);color:#fff;flex-shrink:0;font-size:var(--text-sm);font-weight:var(--font-semibold);height:24px;justify-content:center;width:24px}.step-number,.step-text{align-items:center;display:flex}.step-text{color:var(--text-primary);font-size:var(--text-base);gap:var(--space-xs);line-height:24px}.step-icon{color:var(--primary-color);flex-shrink:0}.install-modal-dismiss{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);padding:var(--space-md);transition:all var(--transition-fast);width:100%}.install-modal-dismiss:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width:480px){.install-banner{align-items:stretch;flex-direction:column;gap:var(--space-md);padding:var(--space-md)}.install-banner-content{justify-content:center;text-align:center}.install-banner-text{align-items:center}.install-banner-actions{justify-content:center}.install-banner-button.install{flex:1 1}.install-modal{padding:var(--space-lg)}}@supports (padding-bottom:env(safe-area-inset-bottom)){.install-banner{padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom))}}