:root{--bg:#faf8f5;--bg-subtle:#f3f0eb;--surface:#fff;--surface-raised:#fff;--surface-hover:#f9f7f4;--text:#2c2825;--text-secondary:#7a7269;--text-tertiary:#a8a099;--border:#e8e3dc;--border-subtle:#f0ece6;--shadow-sm:0 1px 3px #2c28250f;--shadow:0 2px 6px #2c282512;--shadow-md:0 4px 12px #2c282514;--shadow-lg:0 8px 24px #2c28251a;--shadow-xl:0 12px 32px #2c28251f;--shadow-card-hover:0 4px 16px #2c28251a;--primary:#b8704a;--primary-hover:#a5623f;--primary-light:#b8704a14;--primary-glow:#b8704a26;--primary-text:#fff;--success:#5a8a5c;--success-light:#5a8a5c1a;--warning:#c4933b;--warning-light:#c4933b1a;--danger:#c4513b;--danger-light:#c4513b1a;--critical:#a3392a;--info:#5a7a8a;--info-light:#5a7a8a1a;--sidebar-w:240px;--sidebar-collapsed:64px;--sidebar-width:var(--sidebar-w);--sidebar-collapsed-width:var(--sidebar-collapsed);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--font:system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-sans:var(--font);--font-display:var(--font);--font-mono:"Cascadia Code", "Fira Code", "SF Mono", ui-monospace, monospace;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--duration-fast:.15s;--duration-base:.2s;--duration-smooth:.25s;--duration-slow:.35s;--ease:cubic-bezier(.4, 0, .2, 1);--transition-fast:var(--duration-fast) var(--ease);--transition:var(--duration-base) var(--ease);--transition-slow:var(--duration-slow) var(--ease);--z-sidebar:100;--z-dropdown:150;--z-overlay:200;--z-modal:300;--z-toast:400;--color-bg:var(--bg);--color-bg-subtle:var(--bg-subtle);--color-surface:var(--surface);--color-surface-raised:var(--surface-raised);--color-text:var(--text);--color-text-secondary:var(--text-secondary);--color-text-tertiary:var(--text-tertiary);--color-border:var(--border);--color-border-subtle:var(--border-subtle);--color-primary:var(--primary);--color-primary-hover:var(--primary-hover);--color-primary-light:var(--primary-light);--color-primary-glow:var(--primary-glow);--color-success:var(--success);--color-success-light:var(--success-light);--color-warning:var(--warning);--color-warning-light:var(--warning-light);--color-danger:var(--danger);--color-danger-light:var(--danger-light);--color-critical:var(--critical);--color-info:var(--info);--color-info-light:var(--info-light);--color-sidebar-bg:var(--surface);--color-sidebar-border:var(--border)}[data-theme=dark]{--bg:#1c1a17;--bg-subtle:#242119;--surface:#2a2621;--surface-raised:#332e28;--surface-hover:#332e28;--text:#ede9e3;--text-secondary:#9c958c;--text-tertiary:#6b645c;--border:#3a352e;--border-subtle:#302b25;--shadow-sm:0 1px 3px #0003;--shadow:0 2px 6px #0000003d;--shadow-md:0 4px 12px #00000047;--shadow-lg:0 8px 24px #00000059;--shadow-xl:0 12px 32px #0006;--shadow-card-hover:0 4px 16px #0000004d;--primary:#d4956e;--primary-hover:#c4845d;--primary-light:#d4956e1f;--primary-glow:#d4956e33;--success:#7aae7c;--success-light:#7aae7c26;--warning:#d4a84e;--warning-light:#d4a84e26;--danger:#d4715b;--danger-light:#d4715b26;--info:#7a9aaa;--info-light:#7a9aaa26}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;overflow-x:hidden}html{-webkit-text-size-adjust:100%;tab-size:4;scroll-behavior:smooth}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px;line-height:1.6}button,input,select,textarea,fieldset,legend,label,optgroup,option{font-family:inherit;font-size:inherit;line-height:inherit}a{color:var(--primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-hover)}img,svg{max-width:100%;display:block}input,select,textarea{font-family:var(--font)}h1,h2,h3,h4,h5,h6{font-family:var(--font);color:var(--text);letter-spacing:-.02em;font-weight:600;line-height:1.3}h1{letter-spacing:-.02em;font-size:27px;font-weight:700;line-height:1.2}h2{letter-spacing:-.02em;font-size:21px;font-weight:600;line-height:1.3}h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:11px;font-weight:600}h4{font-size:15px;font-weight:600}p{line-height:1.6}.text-muted{color:var(--text-secondary)}.app-layout{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);height:100vh;z-index:var(--z-sidebar);transition:width var(--transition);flex-direction:column;display:none;position:sticky;top:0;overflow:hidden auto}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;min-height:49px;display:flex}.app-title{letter-spacing:-.02em;color:var(--text);white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.sidebar.collapsed .app-title{display:none}.sidebar-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.sidebar-brand{color:inherit;align-items:center;gap:10px;text-decoration:none;display:flex}.brand-icon{width:24px;height:24px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.brand-icon svg{width:24px;height:24px}.brand-text{letter-spacing:-.02em;color:var(--text);font-size:15px;font-weight:700}.sidebar.collapsed .brand-text,.sidebar.collapsed .sidebar-brand span.brand-text{display:none}.sidebar-user{padding:10px var(--space-4);border-bottom:1px solid var(--border);align-items:center;gap:10px;display:flex}.sidebar-user-collapsed,.sidebar.collapsed .sidebar-user:not(.sidebar-user-collapsed){display:none}.sidebar.collapsed .sidebar-user-collapsed{border-bottom:1px solid var(--border);justify-content:center;padding:10px 0;display:flex}.sidebar.collapsed .user-info{display:none}.user-avatar{border-radius:var(--radius-full);background:var(--primary);width:30px;height:30px;color:var(--primary-text);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.user-avatar-sm{width:26px;height:26px;font-size:11px}.user-info{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.user-role{color:var(--text-secondary);text-transform:capitalize;font-size:11px}.sidebar-nav{padding:var(--space-2);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.nav-group{margin-bottom:var(--space-1)}.nav-group-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:var(--space-3) var(--space-3) var(--space-1);white-space:nowrap;font-size:11px;font-weight:600;overflow:hidden}.sidebar.collapsed .nav-group-title{opacity:0;height:0;margin:0;padding:0;overflow:hidden}.nav-item{padding:7px var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:10px;width:100%;margin:1px 0;font-size:13px;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.nav-item:hover{background:var(--bg-subtle);color:var(--text)}.nav-item.active,.nav-item[aria-current=page]{background:var(--primary-light);color:var(--primary);border-left:3px solid var(--primary);font-weight:500}.nav-item-active{font-weight:500;background:var(--primary-light)!important;color:var(--primary)!important;border-left:3px solid var(--primary)!important}.nav-icon{color:currentColor;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-icon svg{width:18px;height:18px}.nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.nav-divider{background:var(--border);height:1px;margin:var(--space-2) var(--space-3)}.sidebar.collapsed .nav-item{border-left:none;justify-content:center;padding:7px}.sidebar.collapsed .nav-divider{margin:var(--space-2) var(--space-1)}.sidebar.collapsed .nav-label{display:none}.nav-group-label{padding:var(--space-4) var(--space-4) var(--space-2);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-size:11px;font-weight:600}.nav-group-chevron{color:var(--text-secondary);transition:transform var(--transition);font-size:10px}.nav-group-chevron.collapsed{transform:rotate(-90deg)}.nav-group-divider{background:var(--border);height:1px;margin:var(--space-1) var(--space-3)}.nav-group-items{overflow:hidden}.sidebar-footer{padding:var(--space-2);border-top:1px solid var(--border);flex-shrink:0}.topbar{z-index:50;padding:var(--space-3) var(--space-8);background:var(--bg);border-bottom:1px solid var(--border);justify-content:flex-end;align-items:center;gap:var(--space-2);display:none;position:sticky;top:0}.topbar-actions{align-items:center;gap:var(--space-2);display:flex}.avatar-menu{position:relative}.avatar-btn{cursor:pointer;background:0 0;border:none;padding:0}.avatar-circle{border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);border:1.5px solid var(--border);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.avatar-circle:hover{border-color:var(--text);color:var(--text)}img.avatar-img{object-fit:cover;padding:0}.avatar-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:210px;box-shadow:var(--shadow-lg);z-index:var(--z-overlay);animation:dropdownIn var(--duration-fast) var(--ease);position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.avatar-dropdown-header{padding:var(--space-3) 14px;flex-direction:column;gap:2px;display:flex}.avatar-dropdown-header strong{font-size:13px;font-weight:600}.avatar-dropdown-divider{background:var(--border);height:1px}.avatar-dropdown-item{width:100%;color:var(--text);text-align:left;cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;padding:9px 14px;font-size:13px;text-decoration:none;display:block}.avatar-dropdown-item:hover{background:var(--bg-subtle)}.avatar-dropdown-danger{color:var(--danger)}.tablet-nav{display:none}.tablet-nav-primary{padding:var(--space-2) var(--space-4);background:var(--surface);border-bottom:1px solid var(--border);z-index:var(--z-sidebar);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.tablet-brand{align-items:center;gap:var(--space-2);color:inherit;font-size:15px;font-weight:700;text-decoration:none;display:flex}.tablet-nav-groups{align-items:center;gap:var(--space-1);display:flex}.tablet-group-tab{padding:var(--space-2) var(--space-3);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:none;font-size:13px;font-weight:500;position:relative}.tablet-group-tab:hover{color:var(--text);background:var(--bg-subtle)}.tablet-group-tab.active{color:var(--primary);background:var(--primary-light)}.tablet-group-tab.active:after{content:"";background:var(--primary);border-radius:1px;width:24px;height:2px;position:absolute;bottom:-9px;left:50%;transform:translate(-50%)}.tablet-nav-actions{align-items:center;gap:var(--space-2);display:flex}.tablet-subnav{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:var(--bg-subtle);border-bottom:1px solid var(--border-subtle);-webkit-overflow-scrolling:touch;scrollbar-width:none;display:flex;overflow-x:auto}.tablet-subnav::-webkit-scrollbar{display:none}.subnav-pill{padding:var(--space-1) var(--space-3);color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:none;font-size:13px;font-weight:500;text-decoration:none}.subnav-pill:hover{color:var(--text);background:var(--surface)}.subnav-pill.active{background:var(--primary);color:var(--primary-text)}.mobile-header{padding:var(--space-2) var(--space-4);background:var(--surface);border-bottom:1px solid var(--border);z-index:var(--z-sidebar);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.mobile-brand{align-items:center;gap:var(--space-2);color:inherit;font-size:15px;font-weight:700;text-decoration:none;display:flex}.mobile-header-actions{align-items:center;gap:var(--space-1);display:flex}.mobile-menu-btn{cursor:pointer;color:var(--text);padding:var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;display:flex}.mobile-menu-btn:hover{background:var(--bg-subtle)}.mobile-overlay-backdrop{z-index:var(--z-overlay);animation:overlayIn var(--duration-fast) var(--ease);background:#0006;position:fixed;inset:0}.mobile-overlay{background:var(--surface);z-index:calc(var(--z-overlay) + 1);animation:mobileOverlayIn var(--duration-slow) var(--ease);flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes mobileOverlayIn{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.mobile-overlay-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.mobile-overlay-title{color:var(--text);font-size:15px;font-weight:700}.mobile-overlay-nav{padding:var(--space-2) var(--space-4);flex:1;overflow-y:auto}.mobile-nav-group{margin-bottom:var(--space-2)}.mobile-overlay-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.sidebar-backdrop{display:none}.main-content{background:var(--bg);flex:1;min-width:0;min-height:100vh;overflow-y:auto}.page{padding:var(--space-4);width:100%;animation:pageIn var(--duration-base) var(--ease)}.page h2{margin-bottom:var(--space-5);color:var(--text);letter-spacing:-.02em;font-size:21px;font-weight:600}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-flow:column wrap;display:flex}.page-header h2{letter-spacing:-.02em;margin-bottom:0;font-size:21px;font-weight:600}.page-actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4);transition:box-shadow var(--transition), border-color var(--transition);box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow-md)}.card h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--space-3);font-size:11px;font-weight:600}.card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.card-header h3{margin-bottom:0}.card-link{color:var(--primary);transition:color var(--transition-fast);white-space:nowrap;font-size:12px;font-weight:500;text-decoration:none}.card-link:hover{color:var(--primary-hover);text-decoration:underline}.card--status-normal{border-left:4px solid var(--success)}.card--status-warning{border-left:4px solid var(--warning)}.card--status-danger{border-left:4px solid var(--danger)}.card--status-info{border-left:4px solid var(--primary)}.dashboard-grid{gap:var(--space-4);grid-template-columns:1fr;display:grid}.stats-row{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.stat-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;color:inherit;transition:all var(--transition);box-shadow:var(--shadow-sm);text-decoration:none}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-value{color:var(--text);letter-spacing:-.03em;font-size:28px;font-weight:700;line-height:1.2;font-family:var(--font-mono)}.stat-label{color:var(--text-secondary);margin-top:var(--space-1);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.dash-list{flex-direction:column;gap:2px;display:flex}.dash-item{padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);justify-content:space-between;align-items:center;font-size:13px;display:flex}.dash-item:last-child{border-bottom:none}.dash-meta{color:var(--text-secondary);white-space:nowrap;margin-left:var(--space-3);font-size:12px;font-weight:500}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius);font-family:var(--font);cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:all var(--transition);white-space:nowrap;padding:10px 20px;font-size:15px;font-weight:500;line-height:1.4;text-decoration:none;display:inline-flex}.btn:hover{background:var(--bg-subtle);border-color:var(--text-tertiary)}.btn:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.btn-primary{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:var(--radius);transition:all var(--transition);padding:10px 20px;font-size:15px;font-weight:500}.btn-secondary:hover{background:var(--bg-subtle);border-color:var(--text-tertiary)}.btn-ghost{color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:10px 20px;font-size:15px;font-weight:500}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text)}.btn-danger{background:var(--danger);color:var(--primary-text);border-color:var(--danger)}.btn-danger:hover{background:var(--critical);border-color:var(--critical)}.btn-add{background:var(--primary);color:var(--primary-text);border-color:var(--primary);padding:10px 20px;font-size:15px}.btn-add:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-add:active{transform:translateY(0)}.btn-add:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-icon{color:var(--text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.btn-icon:hover{background:var(--bg-subtle);color:var(--text)}.btn-text{font:inherit;cursor:pointer;color:var(--text-secondary);padding:var(--space-2) var(--space-3);border-radius:var(--radius);transition:all var(--transition);text-align:left;background:0 0;border:none;font-size:13px;font-weight:500}.btn-text:hover{background:var(--bg-subtle);color:var(--text)}.btn-sm{padding:var(--space-2) 14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500}.btn-sm:hover{background:var(--bg-subtle);border-color:var(--text-tertiary)}.btn-icon-sm{cursor:pointer;color:var(--text-tertiary);padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:inline-flex}.btn-icon-sm:hover{background:var(--danger-light);color:var(--danger)}.form-group{margin-bottom:var(--space-4);position:relative}.form-group label{color:var(--text-secondary);margin-bottom:var(--space-1);transition:color var(--transition-fast);font-size:13px;font-weight:500;display:block}.form-group:focus-within label{color:var(--primary)}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font);background:var(--surface);color:var(--text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:15px;line-height:1.5}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--text-tertiary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group textarea{resize:vertical;min-height:60px}.form-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7269' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:14px;padding-right:36px}.form-group select:hover{border-color:var(--primary)}.form-group select option{background:var(--surface);color:var(--text);padding:10px 14px}.form-group--float{position:relative}.form-group--float label{pointer-events:none;transition:all var(--transition);padding:0 var(--space-1);color:var(--text-tertiary);background:0 0;font-size:13px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-group--float input:focus+label,.form-group--float input:not(:placeholder-shown)+label,.form-group--float textarea:focus+label,.form-group--float textarea:not(:placeholder-shown)+label{color:var(--primary);background:var(--surface);font-size:11px;font-weight:600;top:0;transform:translateY(-50%)}.form-row{gap:var(--space-4);margin-bottom:var(--space-1);grid-template-columns:1fr;display:grid}.form-card{margin-bottom:var(--space-4)}.form-actions{margin-top:var(--space-4);gap:10px;display:flex}.vital-form .form-row{gap:var(--space-4);margin-bottom:var(--space-1);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.profile-selector,.metric-selector{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-family:var(--font);transition:all var(--transition);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A7269' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:14px;outline:none;padding-right:32px;font-size:13px;font-weight:500}.profile-selector:hover,.metric-selector:hover{border-color:var(--primary)}.profile-selector:focus,.metric-selector:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.radio-group{border:1px solid var(--border);border-radius:var(--radius);gap:0;display:flex;overflow:hidden}.radio-group label{padding:var(--space-2) 14px;text-align:center;cursor:pointer;border-right:1px solid var(--border);transition:all var(--transition);color:var(--text-secondary);flex:1;font-size:13px;font-weight:500}.radio-group label:last-child{border-right:none}.radio-group label:hover{background:var(--bg-subtle)}.radio-group input[type=radio]{display:none}.radio-group input[type=radio]:checked+span{color:var(--primary);font-weight:600}.radio-group label:has(input:checked){background:var(--primary-light);color:var(--primary)}.toggle-label{align-items:center;gap:var(--space-2);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);font-size:13px;display:flex}.toggle-label:hover{color:var(--text)}.toggle-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;width:15px;height:15px}.alert{border-radius:var(--radius);margin-bottom:var(--space-4);padding:10px 14px;font-size:13px;font-weight:500;line-height:1.5}.alert-error{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger-light)}.alert-warning{background:var(--warning-light);color:var(--warning);border:1px solid var(--warning-light)}.alert-success{background:var(--success-light);color:var(--success);border:1px solid var(--success-light)}.alert-info{background:var(--info-light);color:var(--info);border:1px solid var(--info-light)}.auth-page{min-height:100vh;padding:var(--space-5);background:var(--bg);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);animation:cardIn var(--duration-slow) var(--ease);padding:36px}.auth-card h1{text-align:center;margin-bottom:var(--space-1);letter-spacing:-.02em;font-size:27px;font-weight:700}.auth-tagline{text-align:center;color:var(--text-secondary);margin-bottom:28px;font-size:15px;line-height:1.5}.onboarding-page{min-height:100vh;padding:var(--space-5);background:var(--bg);justify-content:center;align-items:center;display:flex}.onboarding-card{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);animation:cardIn var(--duration-slow) var(--ease);padding:36px}.onboarding-card h1{text-align:center;margin-bottom:var(--space-2);letter-spacing:-.02em;font-size:27px;font-weight:700}.onboarding-card h2{margin-bottom:var(--space-4);font-size:21px;font-weight:600}.progress-bar{background:var(--border);height:3px;margin-bottom:var(--space-3);border-radius:2px;overflow:hidden}.progress-bar-fill{background:var(--primary);height:100%;transition:width var(--transition-slow);border-radius:2px}.step-indicator{color:var(--text-secondary);text-align:center;margin-bottom:var(--space-6);letter-spacing:.02em;font-size:12px;font-weight:500}.recovery-grid{gap:var(--space-2);grid-template-columns:1fr;display:grid}.recovery-code{font-family:var(--font-mono);padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);letter-spacing:.04em;font-size:13px;font-weight:500}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg-subtle);font-size:11px;font-weight:600}.data-table td{text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.data-table tbody tr{cursor:pointer;transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--surface-hover,var(--bg-subtle))}.data-table tbody tr:last-child td{border-bottom:none}.badge{padding:2px var(--space-2);border-radius:var(--radius-sm);white-space:nowrap;align-items:center;font-size:11px;font-weight:600;line-height:1.6;display:inline-flex}.badge-active{background:var(--success-light);color:var(--success)}.badge-inactive{background:var(--bg-subtle);color:var(--text-tertiary)}.badge-scheduled{background:var(--info-light);color:var(--info)}.badge-completed{background:var(--success-light);color:var(--success)}.badge-cancelled,.badge-missed,.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--primary-light);color:var(--primary)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.tag{padding:2px var(--space-2);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);font-size:11px;font-weight:500;display:inline-block}.status-normal{color:var(--success);font-weight:500}.status-borderline{color:var(--warning);font-weight:500}.status-abnormal{color:var(--danger);font-weight:500}.status-critical{color:var(--danger);font-weight:700}.med-list,.appt-list,.doc-list,.task-list{gap:var(--space-2);flex-direction:column;display:flex}.med-item,.appt-item,.doc-item,.task-item{padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition);box-shadow:var(--shadow-sm);align-items:center;gap:14px;display:flex}.med-item:hover,.appt-item:hover,.doc-item:hover,.task-item:hover{box-shadow:var(--shadow-md)}.med-info,.appt-info,.doc-info,.task-info{flex:1;min-width:0}.med-name{color:var(--text);font-size:15px;font-weight:600}.med-details{color:var(--text-secondary);margin-top:2px;font-size:13px;line-height:1.5}.med-meta{color:var(--text-tertiary);margin-top:2px;font-size:12px}.med-actions,.appt-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.appt-date{text-align:center;min-width:56px;padding:var(--space-2);background:var(--primary-light);border-radius:var(--radius);flex-shrink:0}.appt-day{color:var(--primary);font-size:20px;font-weight:700;line-height:1;font-family:var(--font-mono)}.appt-month{text-transform:uppercase;color:var(--text-secondary);letter-spacing:.04em;margin-top:2px;font-size:11px;font-weight:600}.appt-time{color:var(--primary);font-size:12px;font-weight:500;font-family:var(--font-mono);margin-top:3px}.appt-title{font-size:15px;font-weight:600}.appt-type{color:var(--text-secondary);text-transform:capitalize;font-size:13px}.appt-location{color:var(--text-tertiary);margin-top:2px;font-size:12px}.appt-past{opacity:.55}.doc-icon{text-align:center;width:36px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:22px;display:flex}.doc-name{font-size:13px;font-weight:500}.doc-meta{color:var(--text-secondary);align-items:center;gap:var(--space-1);flex-wrap:wrap;margin-top:2px;font-size:12px;display:flex}.doc-tags{gap:var(--space-1);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.doc-category-badge{padding:1px var(--space-2);background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);font-size:11px;font-weight:500;line-height:1.6;display:inline-block}.doc-upload-zone{padding:var(--space-6) var(--space-5);border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition), background var(--transition);color:var(--text-secondary);justify-content:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.doc-upload-zone:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.doc-upload-text{margin:0;font-size:13px;font-weight:500}.doc-upload-controls{margin-top:var(--space-1)}.doc-upload-progress{color:var(--primary);align-items:center;gap:10px;padding:10px 0 0;font-size:13px;font-weight:500;display:flex}.doc-upload-spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);width:16px;height:16px;animation:.6s linear infinite doc-spin}.doc-preview-container{background:var(--bg-subtle);border-radius:var(--radius);justify-content:center;align-items:flex-start;min-height:200px;display:flex;overflow:hidden}.doc-preview-image{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:500px}.doc-preview-pdf{border-radius:var(--radius);border:none;width:100%;height:600px}.doc-preview-placeholder{padding:var(--space-10) var(--space-5);color:var(--text-tertiary);justify-content:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.doc-edit-form{gap:var(--space-3);flex-direction:column;display:flex}.doc-edit-label{gap:var(--space-1);color:var(--text-secondary);flex-direction:column;font-size:13px;font-weight:500;display:flex}.doc-edit-label .input,.doc-edit-label .metric-selector{margin-top:2px}.doc-linked-list{gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.doc-linked-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2) var(--space-1) 10px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;display:inline-flex}.doc-linked-type{color:var(--text);font-weight:600}.doc-linked-id{color:var(--text-secondary);font-family:var(--font-mono);font-size:11px}.doc-linked-remove{width:18px;height:18px;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-full);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.doc-linked-remove:hover{background:var(--danger-light);color:var(--danger)}.doc-link-add{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.drop-active{outline:2px dashed var(--primary);outline-offset:-4px;background:var(--primary-light)}.drop-overlay{z-index:var(--z-overlay);pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#b8704a0a;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-message{padding:var(--space-6) var(--space-12);background:var(--surface);border:2px dashed var(--primary);border-radius:var(--radius-lg);color:var(--primary);box-shadow:var(--shadow-lg);font-size:15px;font-weight:600}.timeline{gap:var(--space-2);flex-direction:column;display:flex}.timeline-item{padding:14px var(--space-4);border-radius:var(--radius-lg);transition:all var(--transition);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);align-items:flex-start;gap:14px;display:flex}.timeline-item:hover{box-shadow:var(--shadow-md)}.timeline-icon{text-align:center;flex-shrink:0;width:36px;padding-top:2px;font-size:22px}.timeline-content{flex:1;min-width:0}.timeline-header{align-items:baseline;gap:var(--space-3);flex-wrap:wrap;display:flex}.timeline-title{font-size:15px;font-weight:600}.timeline-date{color:var(--text-secondary);font-size:12px;font-weight:500;font-family:var(--font-mono)}.timeline-meta{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.timeline-desc{margin-top:var(--space-2);color:var(--text-secondary);font-size:13px;line-height:1.6}.timeline-location{color:var(--text-tertiary);margin-top:3px;font-size:12px}.chart-card{margin-bottom:var(--space-4);overflow:hidden}.vital-chart-tabs{background:var(--bg-subtle);border-radius:var(--radius);margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;gap:2px;padding:3px;display:flex;overflow-x:auto}.vital-chart-tab{padding:var(--space-2) 14px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:none;font-size:12px;font-weight:500}.vital-chart-tab:hover{color:var(--text);background:var(--surface-hover,var(--bg-subtle))}.vital-chart-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.vital-latest{align-items:baseline;gap:var(--space-5);padding:0 var(--space-1) 14px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;margin-bottom:14px;display:flex}.vital-latest-item{align-items:baseline;gap:var(--space-1);display:flex}.vital-latest-value{letter-spacing:-.5px;font-size:28px;font-weight:700;line-height:1;font-family:var(--font-mono)}.vital-latest-unit{color:var(--text-secondary);font-size:13px;font-weight:500}.vital-latest-label{color:var(--text-tertiary);margin-left:var(--space-1);font-size:12px}.vital-latest-date{color:var(--text-tertiary);font-size:12px;font-family:var(--font-mono);margin-left:auto}.chart-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.chart-empty{height:200px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:13px;display:flex}.chart-filters{background:var(--bg-subtle);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.chart-range-btn{padding:var(--space-1) 10px;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-size:12px;font-weight:500}.chart-range-btn:hover{color:var(--text)}.chart-range-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.metric-toggles{gap:var(--space-2);padding:0 var(--space-1);flex-wrap:wrap;margin-bottom:14px;display:flex}.metric-toggle{align-items:center;gap:var(--space-2);padding:var(--space-1) 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:12px;font-weight:500;display:inline-flex}.metric-toggle:hover{border-color:var(--text-tertiary)}.metric-toggle.active{border-color:var(--metric-color,var(--primary));color:var(--text);background:var(--surface)}.metric-dot{border-radius:var(--radius-full);width:8px;height:8px;transition:background var(--transition-fast)}.recharts-legend-item{cursor:pointer!important}.recharts-legend-item:hover{opacity:.7}.task-overdue{border-left:3px solid var(--danger)}.task-check{border-radius:var(--radius-full);border:2px solid var(--border);cursor:pointer;width:24px;height:24px;color:var(--text-secondary);transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.task-check:hover{border-color:var(--success);background:var(--success-light)}.task-check.task-done{background:var(--success);border-color:var(--success);color:var(--primary-text)}.task-title{font-size:13px;font-weight:500}.task-completed-text{color:var(--text-secondary);text-decoration:line-through}.task-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.contact-grid{gap:var(--space-3);grid-template-columns:1fr;display:grid}.contact-card{gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-lg);transition:all var(--transition);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.contact-card:hover{box-shadow:var(--shadow-md)}.contact-header{align-items:center;gap:10px;display:flex}.contact-avatar{border-radius:var(--radius-full);background:var(--primary);width:38px;height:38px;color:var(--primary-text);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.contact-name{font-size:15px;font-weight:600}.contact-detail{color:var(--text-secondary);font-size:13px;line-height:1.4}.symptom-entries{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.symptom-entry{align-items:center;gap:var(--space-2);display:flex}.quick-add-card{margin-bottom:var(--space-4)}.quick-add-form{align-items:flex-end;gap:var(--space-3);flex-wrap:wrap;display:flex}.quick-add-fields{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.quick-input{flex-direction:column;gap:3px;display:flex}.quick-input input{width:72px;padding:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;background:var(--surface);color:var(--text);font-size:16px;font-weight:600;font-family:var(--font-mono);transition:all var(--transition);outline:none}.quick-input input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.quick-label{color:var(--text-tertiary);text-align:center;font-size:11px;font-weight:500}.quick-separator{color:var(--text-tertiary);padding-bottom:14px;font-size:20px;font-weight:300}.lab-list{gap:var(--space-2);flex-direction:column;display:flex}.lab-item{border-radius:var(--radius-lg);transition:all var(--transition);background:var(--surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);overflow:hidden}.lab-item:hover{box-shadow:var(--shadow-md)}.lab-header{padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.lab-header:hover{background:var(--bg-subtle)}.expand-icon{color:var(--text-tertiary);transition:transform var(--transition);font-size:12px}.lab-info{flex:1;min-width:0}.lab-values{border-top:1px solid var(--border);padding:0 var(--space-4) var(--space-3)}.settings-section{margin-bottom:var(--space-4)}.setting-row{justify-content:space-between;align-items:center;gap:var(--space-3);padding:10px 0;display:flex}.storage-bar{background:var(--bg-subtle);border-radius:3px;height:6px;margin-bottom:10px;overflow:hidden}.storage-fill{background:var(--primary);height:100%;transition:width var(--transition-slow);border-radius:3px}.avatar-upload-row{align-items:center;gap:var(--space-4);display:flex}.avatar-upload-preview{border-radius:var(--radius-full);border:2px solid var(--border);flex-shrink:0;width:64px;height:64px;overflow:hidden}.avatar-upload-img{object-fit:cover;width:100%;height:100%}.avatar-upload-placeholder{width:100%;height:100%;color:var(--text-secondary);background:var(--bg-subtle);justify-content:center;align-items:center;font-size:24px;font-weight:600;display:flex}.avatar-upload-actions{gap:var(--space-2);flex-direction:column;align-items:flex-start;display:flex}.crop-modal{width:95vw;max-width:600px}.crop-container{background:#1a1a1a;width:100%;height:60vh;min-height:300px;max-height:500px;position:relative}.crop-zoom-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);color:var(--text-secondary);display:flex}.crop-zoom-bar input[type=range]{flex:1}.security-block{padding:0}.security-header{align-items:center;gap:var(--space-3);display:flex}.security-icon{border-radius:var(--radius-sm);background:var(--bg-subtle);width:36px;height:36px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.security-title{font-size:13px;font-weight:600}.security-form{border-top:1px solid var(--border-subtle);margin-top:14px;padding-top:14px}.totp-setup{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.totp-qr{border-radius:var(--radius);border:1px solid var(--border);width:200px;height:200px}.totp-secret{padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-sm);letter-spacing:1px;-webkit-user-select:all;user-select:all;font-size:12px;font-family:var(--font-mono)}.session-section-header{margin-bottom:var(--space-1);justify-content:space-between;align-items:center;display:flex}.session-section-header h3{margin:0}.session-list{gap:var(--space-2);flex-direction:column;display:flex}.session-card{align-items:center;gap:var(--space-3);padding:var(--space-3) 14px;border-radius:var(--radius-lg);background:var(--bg-subtle);transition:background var(--transition-fast);display:flex;position:relative}.session-card.session-current{background:var(--primary-light);border:1px solid var(--primary)}.session-icon{border-radius:var(--radius-sm);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.session-current .session-icon{background:var(--primary);color:var(--primary-text)}.session-info{flex:1;min-width:0}.session-device-name{align-items:center;gap:var(--space-2);font-size:13px;font-weight:600;display:flex}.session-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);background:var(--primary);color:var(--primary-text);font-size:11px;font-weight:500}.session-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.session-revoke{color:var(--text-tertiary);transition:color var(--transition-fast);flex-shrink:0}.session-revoke:hover{color:var(--danger)}.search-box{margin-bottom:var(--space-4)}.search-input{width:100%;padding:10px var(--space-4);font-size:15px;font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);transition:all var(--transition);outline:none}.search-input:hover{border-color:var(--text-tertiary)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.search-input::placeholder{color:var(--text-tertiary)}.search-items{flex-direction:column;gap:2px;display:flex}.search-item{padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);font-size:13px}.search-item:last-child{border-bottom:none}.search-item-name{font-weight:500}.notif-container{position:relative}.notif-bell{cursor:pointer;width:34px;height:34px;color:var(--text-secondary);border-radius:var(--radius-full);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:relative}.notif-bell:hover{background:var(--bg-subtle);color:var(--text)}.notif-badge{background:var(--danger);color:var(--primary-text);border-radius:var(--radius-full);min-width:18px;height:18px;padding:0 var(--space-1);justify-content:center;align-items:center;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:0;right:0}.notif-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:340px;box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);max-height:400px;animation:dropdownIn var(--duration-fast) var(--ease);position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}.notif-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.notif-title{color:var(--text);font-size:13px;font-weight:600}.notif-mark-all{cursor:pointer;color:var(--primary);transition:color var(--transition-fast);background:0 0;border:none;font-size:12px;font-weight:500}.notif-mark-all:hover{color:var(--primary-hover)}.notif-empty{padding:28px var(--space-5);text-align:center;color:var(--text-secondary);font-size:13px}.notif-list{flex-direction:column;display:flex}.notif-item{padding:10px var(--space-4);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast);gap:10px;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-subtle)}.notif-unread{background:var(--primary-light)}.notif-read{opacity:.7}.notif-icon{flex-shrink:0;padding-top:2px;font-size:18px}.notif-content{flex:1;min-width:0}.notif-item-title{color:var(--text);font-size:13px;font-weight:500}.notif-body{color:var(--text-secondary);margin-top:2px;font-size:12px;line-height:1.4}.notif-time{color:var(--text-tertiary);margin-top:3px;font-size:11px}.notif-dot{border-radius:var(--radius-full);background:var(--primary);width:8px;height:8px;margin-top:var(--space-1);flex-shrink:0}.sync-indicator{bottom:var(--space-5);align-items:center;gap:var(--space-2);padding:var(--space-2) 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:var(--z-overlay);animation:slideUp var(--duration-slow) var(--ease);font-size:13px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.sync-dot{border-radius:var(--radius-full);width:8px;height:8px}.sync-offline .sync-dot{background:var(--danger)}.sync-syncing .sync-dot{background:var(--warning);animation:1s infinite pulse}.sync-text{color:var(--text-secondary);font-weight:500}.error-boundary{background:var(--bg);min-height:100vh;padding:var(--space-5);justify-content:center;align-items:center;display:flex}.error-card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-10) 36px;text-align:center;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle)}.error-card h2{margin-bottom:10px}.trend-panel{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border)}.trend-panel h4{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--space-3);font-size:11px;font-weight:600}.trend-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.trend-stat{text-align:center;background:var(--bg-subtle);border-radius:var(--radius-sm);padding:10px}.trend-label{color:var(--text-secondary);margin-bottom:3px;font-size:11px;font-weight:500}.trend-value{font-size:16px;font-weight:600;font-family:var(--font-mono)}.feed-url-box{gap:var(--space-2);align-items:center;margin-top:10px;display:flex}.feed-url{font-size:12px;font-family:var(--font-mono);word-break:break-all;padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);flex:1}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-overlay);animation:overlayIn var(--duration-fast) var(--ease);background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}[data-theme=dark] .modal-overlay{background:#000000a6}.modal{background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-lg);width:100%;max-width:100%;max-height:92vh;animation:modalIn var(--duration-slow) var(--ease);border:1px solid var(--border-subtle);flex-direction:column;display:flex;overflow:hidden}.confirm-modal{max-width:380px;padding:28px var(--space-6) var(--space-5);text-align:center;align-items:center}.confirm-icon{border-radius:var(--radius-full);background:var(--danger-light);justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:14px;display:flex}.confirm-title{margin:0 0 var(--space-2);color:var(--text);font-size:16px;font-weight:600}.confirm-message{color:var(--text-secondary);margin:0 0 var(--space-5);font-size:13px;line-height:1.5}.confirm-actions{gap:10px;width:100%;display:flex}.confirm-actions .btn{padding:var(--space-2) 14px;border-radius:var(--radius);flex:1;font-size:13px;font-weight:500}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-header h2,.modal-header h3{margin:0;font-size:16px;font-weight:600}.modal-close{color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);transition:color var(--transition-fast);border-radius:var(--radius-sm);background:0 0;border:none;font-size:18px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:var(--space-6);flex:1;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border);display:flex}.stepper{padding:0 var(--space-6) 14px;border-bottom:1px solid var(--border)}.stepper-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:0;display:flex}.stepper-track{justify-content:center;align-items:center;gap:0;display:flex}.stepper-step{flex-direction:column;align-items:center;display:flex}.stepper-dot{border-radius:var(--radius-full);background:var(--border);width:26px;height:26px;color:var(--text-secondary);transition:all var(--transition);justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.stepper-step.active .stepper-dot{background:var(--primary);color:var(--primary-text)}.stepper-label{color:var(--text-secondary);margin-top:var(--space-1);text-align:center;font-size:11px;display:block}.stepper-step.active .stepper-label{color:var(--primary);font-weight:500}.stepper-line{background:var(--border);width:48px;height:2px;margin:0 var(--space-3);margin-bottom:var(--space-4);border-radius:1px;overflow:hidden}.stepper-line-fill{background:var(--primary);width:0;height:100%;transition:width var(--transition-slow);border-radius:1px}.stepper-line-fill.filled{width:100%}.stepper-text{text-align:center;color:var(--text-secondary);margin-top:var(--space-2);font-size:12px}.stepper-connector{background:var(--border);width:40px;height:2px;transition:background var(--transition)}.stepper-connector.active{background:var(--primary)}.stepper-connector.completed{background:var(--success)}.vital-picker{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.vital-chip{align-items:center;gap:var(--space-2);padding:10px var(--space-2);border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;flex-direction:column;display:flex}.vital-chip:hover,.vital-chip.active,.vital-chip.selected{border-color:var(--primary);background:var(--primary-light)}.vital-chip.active:hover,.vital-chip.selected:hover{background:var(--primary-glow)}.vital-chip-icon{font-size:22px;line-height:1}.vital-chip-label{text-align:center;font-size:11px;font-weight:500}.vital-fieldset{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-3);padding:14px}.vital-fieldset legend{color:var(--primary);padding:0 var(--space-2);font-size:12px;font-weight:600}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{opacity:.5;margin-bottom:14px;font-size:44px}.empty-state-title{color:var(--text);margin-bottom:var(--space-2);font-size:16px;font-weight:600}.empty-state-subtitle{color:var(--text-secondary);max-width:320px;font-size:13px;line-height:1.5}.toast-container{top:var(--space-5);right:var(--space-5);z-index:var(--z-toast);gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastIn var(--duration-slow) var(--ease);align-items:center;gap:10px;max-width:360px;font-size:13px;font-weight:500;display:flex}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-warning{border-left:3px solid var(--warning)}.toast-info{border-left:3px solid var(--primary)}.toast-icon{flex-shrink:0;font-size:16px}.toast-message{flex:1;min-width:0}.toast-close{cursor:pointer;color:var(--text-tertiary);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:2px;font-size:14px}.toast-close:hover{color:var(--text)}.toast-exit{animation:toastOut var(--duration-smooth) var(--ease) forwards}.skeleton{background:linear-gradient(90deg, var(--bg-subtle) 25%, var(--border-subtle) 50%, var(--bg-subtle) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);width:20px;height:20px;animation:.6s linear infinite spin}.export-grid{gap:var(--space-4);grid-template-columns:1fr;display:grid}.export-card{text-align:center;padding:var(--space-6) var(--space-5);flex-direction:column;align-items:center;gap:10px;display:flex}.export-card-icon{color:var(--primary);margin-bottom:var(--space-1)}.export-card-body{flex:1}.export-card-title{margin:0 0 var(--space-2);font-size:15px;font-weight:600}.export-card-desc{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.5}.export-card-btn{align-items:center;gap:var(--space-2);margin-top:var(--space-2);justify-content:center;min-width:130px;display:inline-flex}.export-spinner{border:2px solid #ffffff4d;border-top-color:var(--primary-text);border-radius:var(--radius-full);width:14px;height:14px;animation:.6s linear infinite spin}.admin-tabs{background:var(--bg-subtle);border-radius:var(--radius);margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;gap:2px;padding:3px;display:flex;overflow-x:auto}.admin-tab{padding:var(--space-2) 14px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition);background:0 0;border:none;font-size:12px;font-weight:500}.admin-tab:hover{color:var(--text);background:var(--surface-hover,var(--bg-subtle))}.admin-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.admin-user-list{gap:var(--space-4);grid-template-columns:1fr;display:grid}.admin-user-card{flex-direction:column;display:flex}.admin-user-card.admin-user-disabled{opacity:.6}.admin-user-header{align-items:center;gap:var(--space-3);display:flex}.admin-user-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:40px;height:40px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.admin-user-info{min-width:0}.admin-user-name{align-items:center;gap:var(--space-1);flex-wrap:wrap;font-size:13px;font-weight:600;display:flex}.admin-user-email{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.admin-user-actions{gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle);flex-wrap:wrap;display:flex}.share-page{background:var(--bg);min-height:100vh;padding:0}.share-container{max-width:920px;padding:var(--space-6) var(--space-5);margin:0 auto}.share-header{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);margin-bottom:var(--space-4);flex-flow:column wrap;align-items:flex-start;display:flex}.share-brand{align-items:center;gap:var(--space-3);display:flex}.share-tabs{background:var(--bg-subtle);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;gap:2px;padding:3px;display:flex;overflow-x:auto}.share-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) 14px;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:0 0;border:none;font-size:12px;font-weight:500;display:flex}.share-tab:hover{background:var(--surface-hover,var(--bg-subtle));color:var(--text)}.share-tab.active{background:var(--primary);color:var(--primary-text)}.share-tab.active .share-tab-count{color:var(--primary-text);background:#ffffff40}.share-tab-label{display:none}.share-tab-count{padding:1px var(--space-2);border-radius:var(--radius-sm);background:var(--bg-subtle);color:var(--text-secondary);font-size:10px;font-weight:600}.share-content{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--space-3);margin-bottom:var(--space-4)}.share-table th,.share-table td{text-align:left}.share-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);white-space:nowrap;padding:var(--space-2) 14px;font-size:11px;font-weight:600}.share-table td{padding:10px 14px;font-size:13px}.share-table tbody tr{border-bottom:1px solid var(--border-subtle)}.share-table tbody tr:last-child{border-bottom:none}.share-vital-filters{gap:var(--space-1);flex-wrap:wrap;margin-bottom:14px;display:flex}.share-vital-filter{padding:5px var(--space-3);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-size:12px;font-weight:500}.share-vital-filter:hover{border-color:var(--primary);color:var(--primary)}.share-vital-filter.active{background:var(--primary);border-color:var(--primary);color:var(--primary-text)}.share-footer{text-align:center;padding:var(--space-5);color:var(--text-tertiary);font-size:12px}.toggle-switch{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle);display:flex}.toggle-switch:last-child{border-bottom:none;padding-bottom:0}.toggle-switch:first-child{padding-top:0}.toggle-switch-label{text-align:left;font-size:13px;font-weight:500}.toggle-switch-desc{color:var(--text-secondary);text-align:left;margin-top:2px;font-size:12px}.toggle-switch input[type=checkbox]{appearance:none;background:var(--border);cursor:pointer;width:44px;height:24px;transition:background var(--transition);border:none;border-radius:12px;outline:none;flex-shrink:0;margin:0;position:relative}.toggle-switch input[type=checkbox]:after{content:"";border-radius:var(--radius-full);background:var(--primary-text);width:18px;height:18px;transition:transform var(--transition);box-shadow:var(--shadow-sm);position:absolute;top:3px;left:3px}.toggle-switch input[type=checkbox]:checked{background:var(--primary)}.toggle-switch input[type=checkbox]:checked:after{transform:translate(20px)}.settings-form-row{padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;display:flex}.settings-form-row:last-child{border-bottom:none}.settings-form-row label{text-align:left;flex:1;font-size:13px;font-weight:500}.settings-form-row input[type=number]{width:72px;padding:var(--space-2) 10px;border:1px solid var(--border);border-radius:var(--radius);text-align:center;background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font-mono);outline:none}.settings-form-row input[type=number]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.settings-form-row .settings-unit{color:var(--text-secondary);min-width:50px;font-size:12px}.view-toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);flex-flow:column wrap;align-items:stretch;display:flex}.view-toolbar-right{justify-content:space-between;align-items:center;gap:10px;display:flex}.view-tabs{background:var(--bg-subtle);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.view-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) 14px;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-size:12px;font-weight:500;display:inline-flex}.view-tab:hover{color:var(--text)}.view-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.lab-trends-grid{gap:var(--space-3);margin-top:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.lab-trend-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);cursor:pointer;transition:all var(--transition-fast)}.lab-trend-card:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.lab-trend-card-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.lab-trend-card-marker{text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;font-size:11px;font-weight:600}.lab-trend-card-value{margin:2px 0;font-size:22px;font-weight:700}.lab-trend-card-unit{color:var(--text-secondary);margin-left:4px;font-size:12px;font-weight:400}.lab-trend-card-trend{font-size:13px;font-weight:500}.lab-trend-expanded{background:var(--surface);border:2px solid var(--primary);border-radius:var(--radius-lg);padding:var(--space-4);grid-column:1/-1}.lab-trend-expanded-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.lab-trend-expanded-content{gap:var(--space-4);grid-template-columns:1fr 280px;align-items:start;display:grid}@media (width<=900px){.lab-trends-grid{grid-template-columns:repeat(2,1fr)}.lab-trend-expanded-content{grid-template-columns:1fr}}@media (width<=600px){.lab-trends-grid{grid-template-columns:1fr}}.ocr-upload{width:100%}.ocr-dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:28px var(--space-5);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--surface)}.ocr-dropzone:hover{border-color:var(--primary);background:var(--primary-light)}.ocr-dropzone.processing{border-color:var(--primary);cursor:default}.ocr-progress{flex-direction:column;align-items:center;gap:10px;display:flex}.ocr-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);width:28px;height:28px;animation:.8s linear infinite spin}.ocr-results{margin-top:var(--space-4)}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hide-mobile,.hide-sm{display:none}.form-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font);background:var(--surface);color:var(--text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:15px;line-height:1.5}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}:focus-visible{box-shadow:0 0 0 3px var(--primary-light);border-color:var(--primary);outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::selection{background:var(--primary-light);color:var(--primary-hover)}@keyframes pageIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes doc-spin{to{transform:rotate(360deg)}}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{to{opacity:0;transform:translate(20px)}}@media print{.sidebar,.sidebar-header,.sidebar-footer,.tablet-nav,.mobile-header,.mobile-overlay,.mobile-overlay-backdrop,.sync-indicator,.toast-container{display:none!important}.main-content{width:100%!important;margin-left:0!important;padding:0!important}.app-layout{display:block!important}.card{break-inside:avoid;box-shadow:none!important;border:1px solid #ddd!important}body{color:#000!important;background:#fff!important}}@media (width>=640px){.mobile-header{display:none}.tablet-nav{display:block}.page{padding:var(--space-6) var(--space-8)}.page-header{flex-direction:row;align-items:center}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.stats-row{grid-template-columns:repeat(4,1fr)}.contact-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.admin-user-list{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.export-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.recovery-grid{grid-template-columns:1fr 1fr}.trend-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.vital-picker{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{padding:var(--space-5)}.auth-card,.onboarding-card{padding:36px}.modal-overlay{padding:var(--space-5);align-items:center}.modal{border-radius:var(--radius-xl);max-width:520px;max-height:85vh}.notif-dropdown{width:340px}.view-toolbar{flex-direction:row;align-items:center}.quick-add-form{flex-direction:row;align-items:flex-end}.toast-container{right:var(--space-5);left:auto}.toast{max-width:360px}.share-header{flex-direction:row;align-items:center}.share-tab-label{display:inline}.share-content{padding:var(--space-4)}.hide-mobile,.hide-sm{display:revert}.data-table .hide-mobile,.data-table .hide-sm,.med-table .col-route,.med-table .col-prescribed,.med-table .col-since,.med-table .col-frequency,.med-table .col-dosage{display:table-cell}}@media (width>=1024px){.tablet-nav{display:none}.sidebar,.topbar{display:flex}.app-layout{grid-template-columns:var(--sidebar-w) 1fr;display:grid}.app-layout.sidebar-collapsed{grid-template-columns:var(--sidebar-collapsed) 1fr}.page{padding:var(--space-6) var(--space-10)}.topbar{padding:var(--space-3) var(--space-10)}.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
