:root{--bg-primary:#07080a;--bg-secondary:#0c0e12;--bg-tertiary:#12161f;--glass-bg:#12161fbf;--glass-border:#ffffff0f;--glass-border-hover:#ffffff1f;--text-primary:#f1f3f6;--text-secondary:#9ea5b4;--text-muted:#616875;--color-primary:#0369a1;--color-primary-glow:#0369a126;--color-spo2:#0ea5e9;--color-spo2-glow:#0ea5e926;--color-bp:#10b981;--color-bp-glow:#10b98126;--color-warning:#f59e0b;--color-warning-glow:#f59e0b26;--color-critical:#ef4444;--color-safe:#10b981;--color-info:#3b82f6;--font-display:"Outfit", "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;--font-sans:"Inter", "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;--sidebar-width:260px;--bottom-bar-height:72px;--border-radius:18px;--transition-smooth:all .3s cubic-bezier(.25, .8, .25, 1);--box-shadow-glow:0 8px 32px 0 #0006;--input-bg:#ffffff08;--hover-bg:#ffffff08;--hover-bg-secondary:#ffffff0d;--alert-strip-bg:#ffffff05;--alert-strip-hover-bg:#ffffff0a}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{background-image:radial-gradient(circle at 10% 20%,#ff336608 0%,#0000 40%),radial-gradient(circle at 90% 80%,#00f2fe08 0%,#0000 40%);min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;padding:2.5rem;overflow-y:auto}.sidebar{width:var(--sidebar-width);background-color:var(--bg-secondary);border-right:1px solid var(--glass-border);z-index:100;flex-direction:column;height:100vh;padding:2rem 1.5rem;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;margin-bottom:3rem;display:flex}.brand-icon{background:linear-gradient(135deg, var(--color-primary), #f05);width:40px;height:40px;box-shadow:0 0 15px var(--color-primary-glow);color:#fff;border-radius:12px;justify-content:center;align-items:center;display:flex}.brand-name{font-family:var(--font-display);letter-spacing:-.5px;background:linear-gradient(135deg, #fff 40%, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.nav-menu{flex-direction:column;flex:1;gap:8px;display:flex}.nav-item{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);border:1px solid #0000;border-radius:12px;align-items:center;gap:14px;padding:12px 16px;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-primary);background-color:var(--hover-bg)}.nav-item.active{color:var(--text-primary);background-color:var(--bg-tertiary);border:1px solid var(--glass-border);box-shadow:var(--box-shadow-glow)}.nav-item.active svg{color:var(--color-primary);filter:drop-shadow(0 0 5px var(--color-primary-glow))}.user-profile{background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:14px;align-items:center;gap:12px;margin-top:auto;padding:12px;display:flex}.avatar{color:#fff;width:36px;height:36px;font-weight:600;font-family:var(--font-display);background:linear-gradient(135deg,#4f46e5,#06b6d4);border-radius:50%;justify-content:center;align-items:center;display:flex}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}.logout-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none}.logout-btn:hover{color:var(--color-critical)}.mobile-nav-bar{height:var(--bottom-bar-height);background-color:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);z-index:100;padding:0 10px;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--text-secondary);cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;height:100%;font-size:.7rem;font-weight:500;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--color-primary)}.mobile-nav-item svg{width:22px;height:22px;transition:var(--transition-smooth)}.mobile-nav-item.active svg{filter:drop-shadow(0 0 5px var(--color-primary-glow));transform:translateY(-2px)}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-title{font-family:var(--font-display);letter-spacing:-.5px;font-size:2rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:.95rem}.btn{font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border:1px solid #0000;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn:active{transition:transform .1s;transform:scale(.98)}.btn-primary{background:linear-gradient(135deg, var(--color-primary), #e62050);color:#fff;box-shadow:0 4px 15px var(--color-primary-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #ff336659}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--glass-border);color:var(--text-primary)}.btn-secondary:hover{background:var(--hover-bg-secondary);border-color:var(--glass-border-hover)}.btn:disabled,.btn:disabled:hover{cursor:not-allowed;opacity:.65;transform:none}.btn-primary:disabled,.btn-primary:disabled:hover{background:var(--bg-tertiary);border-color:var(--glass-border);box-shadow:none;color:var(--text-muted)}.panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--box-shadow-glow), inset 0 1px 1px #ffffff0d;transition:var(--transition-smooth);padding:1.5rem}.panel:hover{border-color:var(--glass-border-hover)}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.grid-2-3{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.metric-card{position:relative;overflow:hidden}.metric-card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.metric-card.heartrate:before{background-color:var(--color-primary)}.metric-card.spo2:before{background-color:var(--color-spo2)}.metric-card.bp:before{background-color:var(--color-bp)}.metric-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.metric-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.9rem;font-weight:600}.metric-icon-box{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.metric-card.heartrate .metric-icon-box{background:var(--color-primary-glow);color:var(--color-primary)}.metric-card.spo2 .metric-icon-box{background:var(--color-spo2-glow);color:var(--color-spo2)}.metric-card.bp .metric-icon-box{background:var(--color-bp-glow);color:var(--color-bp)}.metric-body{align-items:baseline;gap:6px;display:flex}.metric-value{font-family:var(--font-display);letter-spacing:-1px;font-size:2.75rem;font-weight:800;line-height:1}.metric-unit{color:var(--text-secondary);font-size:.95rem;font-weight:500}.metric-footer{color:var(--text-muted);align-items:center;gap:6px;margin-top:1rem;font-size:.8rem;display:flex}@keyframes heart-beat{0%{transform:scale(1)}14%{transform:scale(1.15)}28%{transform:scale(1)}42%{transform:scale(1.15)}70%{transform:scale(1)}}.beat-animated{transform-origin:50%;animation:1.2s infinite heart-beat;display:inline-block}@keyframes pulse-halo{0%{box-shadow:0 0 #f366}70%{box-shadow:0 0 0 10px #f360}to{box-shadow:0 0 #f360}}.critical-pulse{animation:1.5s infinite pulse-halo;border-color:var(--color-critical)!important}.ecg-container{flex-direction:column;gap:12px;display:flex}.ecg-canvas-wrapper{border:1px solid var(--glass-border);background:#0003;border-radius:12px;width:100%;height:240px;position:relative;overflow:hidden}.ecg-grid-overlay{pointer-events:none;background-image:linear-gradient(#ff336605 1px,#0000 1px),linear-gradient(90deg,#ff336605 1px,#0000 1px),linear-gradient(#ff33660f 1px,#0000 1px),linear-gradient(90deg,#ff33660f 1px,#0000 1px);background-size:20px 20px,100px 100px;position:absolute;inset:0}.alert-strip{background:var(--alert-strip-bg);border:1px solid var(--glass-border);transition:var(--transition-smooth);border-radius:12px;align-items:flex-start;gap:12px;margin-bottom:10px;padding:12px;display:flex}.alert-strip:hover{background:var(--alert-strip-hover-bg)}.alert-strip.high{border-left:3px solid var(--color-critical);background:#ff336608}.alert-strip.medium{border-left:3px solid var(--color-warning);background:#ffb60608}.alert-strip-icon{margin-top:2px}.alert-strip.high .alert-strip-icon{color:var(--color-critical)}.alert-strip.medium .alert-strip-icon{color:var(--color-warning)}.alert-strip-body{flex:1;min-width:0}.alert-strip-title{margin-bottom:2px;font-size:.85rem;font-weight:600}.alert-strip-desc{color:var(--text-secondary);font-size:.75rem}.alert-strip-time{color:var(--text-muted);margin-top:4px;font-size:.7rem}.patient-list{flex-direction:column;gap:12px;display:flex}.patient-row{background:var(--glass-bg);border:1px solid var(--glass-border);cursor:pointer;transition:var(--transition-smooth);border-radius:14px;align-items:center;padding:14px 20px;display:flex}.patient-row:hover{border-color:var(--glass-border-hover);transform:translate(4px)}.patient-row.selected{border-color:var(--color-primary);background:#ff336608}.patient-avatar{background:var(--bg-tertiary);width:44px;height:44px;color:var(--text-primary);font-weight:700;font-family:var(--font-display);border:1px solid var(--glass-border);border-radius:12px;justify-content:center;align-items:center;margin-right:16px;display:flex}.patient-main-info{flex:1}.patient-name{margin-bottom:2px;font-size:1rem;font-weight:600}.patient-meta{color:var(--text-secondary);font-size:.8rem}.patient-status{border-radius:20px;padding:6px 12px;font-size:.75rem;font-weight:600}.patient-status.normal{color:var(--color-bp);background:#39ff141a}.patient-status.critical{color:var(--color-critical);background:#ff33661a;animation:2s infinite pulse-halo}.patient-status.success{color:#10b981;background:#10b9811f}.patient-status.purple{color:#8b5cf6;background:#7c3aed1f}.patient-status.warning{color:#d97706;background:#f59e0b1f}.patient-status.danger{color:var(--color-critical);background:#ef44441f}.patient-status.muted{color:var(--text-secondary);background:#64748b1f}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;font-weight:500;display:block}.form-control{background:var(--input-bg);border:1px solid var(--glass-border);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-smooth);border-radius:12px;padding:12px 16px;font-size:.95rem}.form-control:focus{border-color:var(--color-primary);background:#ffffff0d;outline:none;box-shadow:0 0 10px #ff336626}.form-control:disabled{cursor:not-allowed;color:var(--text-muted);background:#ffffff05}.profile-page{flex-direction:column;gap:1.5rem;display:flex}.profile-loading,.profile-empty{color:var(--text-secondary);align-items:center;gap:12px;display:flex}.profile-spin{animation:.8s linear infinite profile-spin}@keyframes profile-spin{to{transform:rotate(360deg)}}.profile-success{border-left:3px solid var(--color-bp);background:#10b9810a}.profile-success .alert-strip-icon{color:var(--color-bp)}.onboarding-page-container{background:radial-gradient(circle at 5% 5%, #ef44440a 0%, transparent 50%), radial-gradient(circle at 95% 95%, #10b9810a 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:40px 20px;display:flex;position:relative;overflow:hidden}.onboarding-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);width:100%;max-width:800px;box-shadow:var(--box-shadow-glow), 0 20px 40px #0000004d;z-index:2;transition:var(--transition-smooth);border-radius:24px;padding:40px;position:relative}.onboarding-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-spo2), var(--color-bp));border-radius:24px 24px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.onboarding-card.doctor-card:before{background:linear-gradient(90deg,#0ea5e9,#06b6d4,#10b981)}.onboarding-header{text-align:center;margin-bottom:35px}.onboarding-header .icon-wrapper{border-radius:20px;justify-content:center;align-items:center;width:68px;height:68px;margin:0 auto 16px;display:flex;position:relative}.onboarding-header .icon-wrapper.bg-rose-soft{background:#ef44441a;border:1px solid #ef444433;box-shadow:0 0 20px #ef44440d}.onboarding-header .icon-wrapper.bg-teal-soft{background:#10b9811a;border:1px solid #10b98133;box-shadow:0 0 20px #10b9810d}.onboarding-header h1{font-family:var(--font-display);letter-spacing:-.5px;background:linear-gradient(90deg,#fff,#d1d5db);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:10px;font-size:2rem;font-weight:800}.onboarding-header .subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:.95rem;line-height:1.6}.onboarding-form{flex-direction:column;gap:24px;display:flex}.section-title{font-family:var(--font-display);letter-spacing:-.2px;color:var(--text-primary);align-items:center;margin-top:10px;margin-bottom:5px;padding-left:12px;font-size:1.15rem;font-weight:700;display:flex;position:relative}.section-title:before{content:"";background:var(--color-primary);border-radius:4px;width:3px;position:absolute;top:4px;bottom:4px;left:0}.onboarding-card.doctor-card .section-title:before{background:var(--color-bp)}.form-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (width<=768px){.form-grid{grid-template-columns:1fr}.onboarding-card{padding:24px}}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.2px;transition:var(--transition-smooth);font-size:.85rem;font-weight:600}.form-group:focus-within label{color:var(--text-primary)}.required-field:after{content:" *";color:var(--color-primary);font-weight:700}.form-control{border:1px solid var(--glass-border);color:var(--text-primary);font-size:.95rem;font-family:var(--font-sans);transition:var(--transition-smooth);background:#ffffff05;border-radius:12px;padding:12px 16px}.form-control:focus{background:#ffffff0a;border-color:#ef444480;outline:none;box-shadow:0 0 12px #ef44441a}.doctor-card .form-control:focus{border-color:#10b98180;box-shadow:0 0 12px #10b9811a}.form-control::placeholder{color:var(--text-muted)}.form-control:disabled{color:var(--text-muted);cursor:not-allowed;background:#ffffff03}.avatar-upload-center{flex-direction:column;align-items:center;gap:12px;margin:10px 0;display:flex}.avatar-preview-box{border:2px solid var(--glass-border);width:110px;height:110px;transition:var(--transition-smooth);background:#ffffff05;border-radius:30px;justify-content:center;align-items:center;display:flex;position:relative;overflow:visible;box-shadow:0 8px 24px #0003}.avatar-preview-box:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 12px 30px #ef444426}.doctor-card .avatar-preview-box:hover{border-color:var(--color-bp);box-shadow:0 12px 30px #10b98126}.avatar-img{object-fit:cover;border-radius:28px;width:100%;height:100%}.avatar-placeholder{justify-content:center;align-items:center;display:flex}.avatar-edit-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:2px solid var(--bg-secondary);width:32px;height:32px;transition:var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:-6px;right:-6px;box-shadow:0 4px 10px #0000004d}.doctor-card .avatar-edit-btn{background:var(--color-bp)}.avatar-edit-btn:hover{transform:scale(1.1)}.avatar-tip{color:var(--text-secondary);font-size:.78rem;font-weight:500}.document-upload-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}@media (width<=768px){.document-upload-grid{grid-template-columns:1fr}}.doc-upload-box{border:1px solid var(--glass-border);transition:var(--transition-smooth);background:#ffffff03;border-radius:16px;flex-direction:column;gap:12px;padding:16px;display:flex}.doc-upload-box:hover{background:#ffffff05;border-color:#ffffff1f}.doc-title{color:var(--text-secondary);text-align:center;font-size:.82rem;font-weight:600}.doc-preview-zone{border:1px dashed var(--glass-border-hover);background:#00000026;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:120px;display:flex;position:relative;overflow:hidden}.doc-preview-img{object-fit:cover;width:100%;height:100%;transition:var(--transition-smooth)}.doc-placeholder{color:var(--text-muted);flex-direction:column;align-items:center;gap:6px;font-size:.75rem;display:flex}.file-input-label{cursor:pointer;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:6px;padding:4px 10px;font-size:.75rem;position:absolute;bottom:8px;border:1px solid var(--glass-border)!important;background:#12161fd9!important}.upload-loader{color:var(--color-warning);text-align:center;font-size:.72rem}.divider{border:none;border-top:1px solid var(--glass-border);margin:10px 0}.alert-message{border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:14px 20px;font-size:.9rem;font-weight:500;display:flex}.alert-message.error{color:#f87171;background:#ef444414;border-color:#ef444433}.alert-message.success{color:#34d399;background:#10b98114;border-color:#10b98133}.profile-layout-container{grid-template-columns:280px minmax(0,1fr);align-items:start;gap:2rem;margin-top:1.5rem;display:grid}.profile-sidebar-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;flex-direction:column;align-items:center;gap:24px;padding:30px 20px;display:flex;box-shadow:0 10px 30px #0003}.profile-badge-avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-spo2));color:#fff;border:2px solid #ffffff1a;border-radius:28px;justify-content:center;align-items:center;width:96px;height:96px;font-size:2.5rem;font-weight:800;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px #ef444440}.profile-badge-avatar img{object-fit:cover;width:100%;height:100%}.profile-sidebar-info{text-align:center;width:100%}.profile-sidebar-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:1.25rem;font-weight:750;overflow:hidden}.profile-sidebar-email{color:var(--text-secondary);word-break:break-all;font-size:.85rem}.profile-navigation-tabs{flex-direction:column;gap:8px;width:100%;display:flex}.profile-tab-btn{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:.9rem;font-weight:600;display:flex}.profile-tab-btn:hover{color:var(--text-primary);background:var(--hover-bg)}.profile-tab-btn.active{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--glass-border);box-shadow:var(--box-shadow-glow)}.profile-tab-btn.active svg{color:var(--color-primary);filter:drop-shadow(0 0 5px var(--color-primary-glow))}.profile-tab-btn.active.tab-doctor-active svg{color:var(--color-bp);filter:drop-shadow(0 0 5px var(--color-bp-glow))}.profile-content-area{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;padding:30px;box-shadow:0 10px 30px #0003}.profile-form-header{border-bottom:1px solid var(--glass-border);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.profile-form-header h2{font-family:var(--font-display);color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:750}.profile-form-header svg{color:var(--color-primary)}.doctor-profile-header svg{color:var(--color-bp)}.profile-form{flex-direction:column;gap:20px;display:flex}.profile-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;display:grid}.profile-meta-list{color:var(--text-secondary);flex-direction:column;gap:6px;margin-bottom:.5rem;font-size:.85rem;display:flex}.profile-empty-inline{border:1px dashed var(--glass-border-hover);color:var(--text-secondary);border-radius:12px;margin-bottom:1rem;padding:12px}@media (width<=900px){.profile-layout-container{grid-template-columns:1fr}}@media (width<=600px){.profile-form-grid{grid-template-columns:1fr}}.cms-page{flex-direction:column;gap:1.5rem;display:flex}.cms-header{flex-wrap:wrap;gap:1rem}.cms-layout{grid-template-columns:230px minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}.cms-module-nav{flex-direction:column;gap:8px;display:flex;position:sticky;top:88px}.cms-module-nav button{width:100%;color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;display:flex}.cms-module-nav button.active,.cms-module-nav button:hover{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--glass-border)}.cms-workspace{min-width:0}.cms-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.cms-toolbar-title{align-items:center;gap:10px;display:flex}.cms-toolbar-title span{color:var(--text-muted);font-size:.85rem}.cms-toolbar-actions,.cms-row-actions,.cms-confirm-actions{flex-wrap:wrap;gap:8px;display:flex}.cms-filters{grid-template-columns:minmax(220px,1fr) minmax(220px,1fr);gap:12px;margin-bottom:1rem;display:grid}.cms-filters label{background:var(--input-bg);border:1px solid var(--glass-border);border-radius:12px;align-items:center;gap:8px;padding:0 12px;display:flex}.cms-filters input,.cms-filters label input{width:100%;color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:0;outline:0;padding:12px 0}.cms-filters>input{border:1px solid var(--glass-border);background:var(--input-bg);border-radius:12px;padding:12px 14px}.cms-table-wrap{border:1px solid var(--glass-border);border-radius:12px;width:100%;overflow-x:auto}.cms-table{border-collapse:collapse;width:100%;min-width:760px}.cms-table th,.cms-table td{border-bottom:1px solid var(--glass-border);text-align:left;vertical-align:top;padding:12px;font-size:.84rem}.cms-table th{color:var(--text-secondary);background:#ffffff08;position:sticky;top:0}.cms-table th button{color:inherit;font:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:5px;display:inline-flex}.cms-table td{color:var(--text-primary)}.cms-table tr:last-child td{border-bottom:0}.cms-row-actions button,.cms-modal-close{border:1px solid var(--glass-border);background:var(--bg-tertiary);min-width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 8px;display:inline-flex}.cms-modal-close{width:32px;padding:0}.cms-row-actions button:hover,.cms-modal-close:hover{color:var(--text-primary);border-color:var(--glass-border-hover)}.cms-pagination{color:var(--text-secondary);justify-content:flex-end;align-items:center;gap:12px;margin-top:1rem;display:flex}.cms-empty-state{color:var(--text-secondary);text-align:center;padding:2.5rem}.cms-modal{max-width:780px;max-height:88vh;overflow-y:auto}.cms-modal h2{margin-bottom:1rem}.cms-modal-close{position:absolute;top:16px;right:16px}.cms-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.cms-detail-list{gap:10px;display:grid}.cms-detail-list div{border-bottom:1px solid var(--glass-border);grid-template-columns:180px minmax(0,1fr);gap:12px;padding:10px 0;display:grid}.cms-detail-list span{color:var(--text-secondary)}.cms-detail-list strong{overflow-wrap:anywhere}.domain-links-page{flex-direction:column;gap:0;display:flex}.domain-links-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.domain-links-modal{max-width:1120px}.domain-links-editor{width:100%}.domain-links-editor-grid{grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:20px;display:grid}.domain-links-form{flex-direction:column;gap:14px;display:flex}.domain-links-preview-pane{flex-direction:column;gap:12px;display:flex}.domain-links-preview-card{background:#ffffff05;overflow:hidden}.domain-links-preview-image{aspect-ratio:1200/630;background:#ffffff08;width:100%}.domain-links-preview-image img{object-fit:cover;width:100%;height:100%;display:block}.domain-links-preview-placeholder{width:100%;height:100%;color:var(--text-muted);place-items:center;font-size:.875rem;display:grid}.domain-links-preview-body{padding:14px 16px 16px}.domain-links-preview-domain{color:var(--color-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-size:.75rem;overflow:hidden}.domain-links-preview-body h3{margin:0 0 8px;font-size:1rem;line-height:1.3}.domain-links-preview-body p{color:var(--text-secondary);margin:0;font-size:.875rem;line-height:1.5}.domain-links-preview-meta{border:1px solid var(--glass-border);background:#ffffff05;border-radius:12px;gap:8px;padding:12px 14px;display:grid}.domain-links-preview-meta div{gap:2px;display:grid}.domain-links-preview-meta span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:.72rem}.domain-links-preview-meta strong{color:var(--text-primary);word-break:break-word;font-size:.82rem}.domain-links-upload{flex-direction:column;gap:8px;display:flex}.domain-links-switch{color:var(--text-secondary);align-items:center;gap:8px;display:inline-flex}.domain-links-switch input{width:16px;height:16px}@media (width<=960px){.domain-links-editor-grid{grid-template-columns:1fr}}.cms-confirm{max-width:420px}.cms-confirm p{color:var(--text-secondary);margin:.75rem 0 1.25rem}.cms-dropzone{border:1px dashed var(--glass-border-hover);min-height:150px;color:var(--text-secondary);cursor:pointer;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:10px;margin-bottom:1rem;display:flex}.cms-dropzone input{display:none}.cms-template-note{color:var(--text-secondary);overflow-wrap:anywhere;margin-bottom:1rem}.cms-template-note code{color:var(--text-primary)}.cms-preview{gap:10px;margin-bottom:1rem;display:grid}.cms-inline-error,.cms-inline-success{border-radius:12px;margin-bottom:1rem;padding:12px;font-size:.85rem}.cms-inline-error{color:var(--color-primary);background:#ff33660f;border:1px solid #ff336640}.cms-inline-success{color:var(--color-bp);background:#39ff140f;border:1px solid #39ff1440}.cms-toast{z-index:1200;background:var(--bg-secondary);color:var(--color-bp);box-shadow:var(--box-shadow-glow);border:1px solid #39ff1440;border-radius:12px;padding:12px 16px;position:fixed;bottom:24px;right:24px}@media (width<=980px){.cms-layout{grid-template-columns:1fr}.cms-module-nav{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;position:static}.cms-filters,.cms-form-grid{grid-template-columns:1fr}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#05070acc;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:20px;width:100%;max-width:500px;padding:2rem;position:relative;box-shadow:0 20px 40px #0009}.otp-modal-card{text-align:center;max-width:460px;overflow:hidden}.otp-modal-card:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 0,#00f2fe24,#0000 34%),radial-gradient(circle at 80% 10%,#ff336629,#0000 32%);position:absolute;inset:0}.otp-modal-card>*{z-index:1;position:relative}.otp-back-btn{border:1px solid var(--glass-border);color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0a;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;font-size:.78rem;display:inline-flex;position:absolute;top:16px;left:16px}.otp-back-btn:hover{color:var(--text-primary);border-color:var(--glass-border-hover)}.otp-modal-brand{justify-content:center;margin:1rem 0}.otp-shield-icon{background:linear-gradient(135deg, var(--color-spo2), var(--color-primary))}.otp-modal-subtitle{flex-direction:column;align-items:center;gap:8px;margin-bottom:1.25rem;display:flex}.otp-email-chip{color:var(--color-spo2);background:#00f2fe14;border:1px solid #00f2fe3d;border-radius:999px;padding:7px 12px;font-weight:700;display:inline-flex}.otp-digit-grid{grid-template-columns:repeat(6,minmax(42px,1fr));gap:10px;margin:1.25rem 0 0;display:grid}.otp-digit-input{border:1px solid var(--glass-border);width:100%;height:58px;color:var(--text-primary);font-family:var(--font-display);text-align:center;transition:var(--transition-smooth);background:#ffffff0a;border-radius:14px;font-size:1.5rem;font-weight:800}.otp-digit-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow), 0 0 18px #ff33662e;background:#ffffff12;outline:none}.otp-digit-input:disabled{opacity:.65}.otp-actions-row{margin-top:1.5rem}.register-auth-shell{background:radial-gradient(circle at 15% 15%,#00f2fe14 0%,#0000 32%),radial-gradient(circle at 85% 0,#ff33661f 0%,#0000 30%),linear-gradient(135deg,#06080d 0%,#0d111a 52%,#08090d 100%);align-items:flex-start;padding-top:42px;padding-bottom:42px}.register-panel{border:1px solid #ffffff1a;max-width:520px;padding:2rem;position:relative;overflow:hidden;box-shadow:0 24px 80px #00000073}.register-card-topline{background:linear-gradient(90deg, var(--color-spo2), var(--color-primary), var(--color-warning));height:4px;position:absolute;top:0;left:0;right:0}.register-brand{justify-content:center;margin-bottom:1.2rem}.register-brand-icon{border-radius:16px;width:46px;height:46px}.auth-stepper{grid-template-columns:1fr 42px 1fr;align-items:center;gap:8px;margin:0 0 1.35rem;display:grid}.auth-step{color:var(--text-muted);justify-content:center;align-items:center;gap:8px;font-size:.8rem;font-weight:700;display:flex}.auth-step span{border:1px solid var(--glass-border);background:var(--input-bg);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.auth-step.active,.auth-step.done{color:var(--text-primary)}.auth-step.active span,.auth-step.done span{background:var(--color-primary-glow);color:var(--color-primary);border-color:#ff336673}.auth-step-line{background:linear-gradient(90deg, transparent, var(--glass-border-hover), transparent);height:1px}.auth-helper-card svg{color:var(--color-spo2);flex:none;margin-top:1px}.register-form{text-align:left}.password-rule svg{color:var(--text-muted)}.password-rule.valid,.password-rule.valid svg{color:var(--color-bp)}@media (width<=520px){.otp-digit-grid{gap:7px}.otp-digit-input{border-radius:12px;height:50px;font-size:1.25rem}.register-panel{padding:1.5rem}.password-rule-list{grid-template-columns:1fr}.auth-stepper{grid-template-columns:1fr 26px 1fr}}.auth-container{background:radial-gradient(circle,#ff336614 0%,#0000 60%);justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:20px;display:flex}.auth-panel{text-align:center;width:100%;max-width:420px}.auth-logo{margin-bottom:1rem;font-size:3rem}.auth-title{font-family:var(--font-display);margin-bottom:6px;font-size:1.75rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.auth-footer{color:var(--text-secondary);margin-top:1.5rem;font-size:.85rem}.global-notification-bar{z-index:10100;border:1px solid var(--color-critical);width:400px;max-width:calc(100vw - 48px);color:var(--text-primary);-webkit-backdrop-filter:blur(16px);background:#12161ff2;border-radius:16px;flex-direction:column;gap:12px;padding:16px;animation:.3s cubic-bezier(.25,.8,.25,1) slide-in-right;display:flex;position:fixed;top:24px;right:24px;box-shadow:0 12px 40px #ef444447}@keyframes slide-in-right{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.global-notification-bar.critical{border-color:var(--color-critical);box-shadow:0 12px 40px #ef444452}.global-notification-bar.high{border-color:var(--color-critical);box-shadow:0 12px 40px #ef44443d}.global-notification-bar.warning,.global-notification-bar.medium{border-color:var(--color-warning);box-shadow:0 12px 40px #f59e0b3d}.banner-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.banner-title-box{font-weight:700;font-family:var(--font-display);align-items:center;gap:8px;display:flex}.banner-close-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;padding:4px}.banner-close-btn:hover{color:var(--text-primary)}.banner-body{font-size:.88rem;line-height:1.4}.banner-footer{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.connection-status-dot{width:8px;height:8px;transition:var(--transition-smooth);border-radius:50%;display:inline-block}.connection-status-dot.connected{background-color:var(--color-safe);box-shadow:0 0 8px var(--color-safe)}.connection-status-dot.disconnected{background-color:var(--color-critical);box-shadow:0 0 8px var(--color-critical)}.stale-vitals-banner{color:var(--color-warning);background:#f59e0b14;border:1px solid #f59e0b40;border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;font-size:.8rem;font-weight:500;display:flex}.alert-strip.critical{border-left:3px solid var(--color-critical);background:#ef444408}.alert-strip.low{border-left:3px solid var(--color-info);background:#3b82f608}.alert-strip.resolved{border-left:3px solid var(--color-safe);background:#10b98108}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.beat-animated{animation:none!important}}.mobile-more-menu-overlay{-webkit-backdrop-filter:blur(8px);z-index:10200;background:#000000b3;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-more-menu-sheet{background:var(--bg-secondary);border-top:1px solid var(--glass-border);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;gap:16px;width:100%;max-height:80vh;padding:24px;animation:.25s ease-out slide-up;display:flex;overflow-y:auto}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-more-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.mobile-more-btn{background:var(--bg-tertiary);border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);transition:var(--transition-smooth);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px 8px;font-size:.8rem;font-weight:500;display:flex}.mobile-more-btn.active,.mobile-more-btn:hover{background:var(--hover-bg-secondary);border-color:var(--glass-border-hover);color:var(--text-primary)}.mobile-more-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.badge{text-transform:uppercase;border-radius:12px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge.high{color:var(--color-primary);background:#ff33661a;border:1px solid #f363}.badge.medium{color:var(--color-warning);background:#ffb6061a;border:1px solid #ffb60633}.badge.low{color:var(--color-bp);background:#39ff141a;border:1px solid #39ff1433}@media (width<=1024px){.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2-3{grid-template-columns:1fr}}@media (width<=768px){.app-container{flex-direction:column}.sidebar{display:none}.mobile-nav-bar{display:flex}.main-content{padding:1.5rem;padding-bottom:calc(var(--bottom-bar-height) + 1.5rem)}.grid-3{grid-template-columns:1fr}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.6rem}}.top-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:999;justify-content:space-between;align-items:center;height:70px;padding:0 2.5rem;display:flex;position:sticky;top:0;left:0;right:0}.top-header-menu{align-items:center;gap:12px;display:flex}.top-header-menu .nav-item{border-radius:10px;padding:8px 16px;font-size:.9rem}.top-header-right{align-items:center;gap:16px;display:flex}.app-vertical-layout{background-color:var(--bg-primary);background-image:radial-gradient(circle at 10% 20%,#ff336608 0%,#0000 40%),radial-gradient(circle at 90% 80%,#00f2fe08 0%,#0000 40%);flex-direction:column;min-height:100vh;display:flex}.app-vertical-layout .main-content{min-height:calc(100vh - 70px);padding:2.5rem}.heart-3d-container{flex-direction:column;justify-content:center;align-items:center;height:100%;min-height:250px;display:flex;position:relative}.heart-3d-canvas{cursor:pointer;width:100%;max-width:250px;height:220px;filter:drop-shadow(0 0 15px var(--color-primary-glow))}.camera-monitor-wrapper{background-color:#030a03;border:1px solid #39ff1433;border-radius:20px;width:100%;height:480px;position:relative;overflow:hidden;box-shadow:0 10px 40px #000c}.camera-canvas{width:100%;height:100%;display:block}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.camera-scanline{pointer-events:none;z-index:10;background:#39ff1426;height:4px;animation:8s linear infinite scanline;position:absolute;top:0;left:0;right:0;box-shadow:0 0 10px #39ff1480}.camera-noise{pointer-events:none;z-index:5;background:linear-gradient(#12101000 50%,#00000040 50%) 0 0/100% 4px,linear-gradient(90deg,#ff00000f,#00ff0005,#0000ff0f) 0 0/6px 100%;position:absolute;inset:0}@keyframes flash-rec{0%,to{opacity:1}50%{opacity:0}}.rec-dot{background-color:#ff073a;border-radius:50%;width:10px;height:10px;animation:1.2s infinite flash-rec;display:inline-block;box-shadow:0 0 8px #ff073a}.stat-widget-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.stat-widget{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.stat-widget-label{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem;font-weight:500}.stat-widget-value{font-family:var(--font-display);font-size:1.85rem;font-weight:700}.chart-panel-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.svg-chart-container{justify-content:center;align-items:center;width:100%;height:280px;display:flex;position:relative}.svg-donut-chart{max-width:220px;max-height:220px;transform:rotate(-90deg)}.chart-legend{flex-direction:column;gap:8px;margin-top:1rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:10px;font-size:.82rem;display:flex}.legend-color-dot{border-radius:4px;width:12px;height:12px}@media (width<=768px){.top-header{padding:0 1.25rem}.top-header-menu{display:none}.app-vertical-layout .main-content{padding:1.5rem;padding-bottom:calc(var(--bottom-bar-height) + 1.5rem)}.stat-widget-grid{grid-template-columns:repeat(2,1fr)}.chart-panel-grid{grid-template-columns:1fr}}[data-theme=light]{--bg-primary:#e4f4fd;--bg-secondary:#fff;--bg-tertiary:#d0e7f7;--glass-bg:#ffffffbf;--glass-border:#00000014;--glass-border-hover:#00000026;--text-primary:#1d2939;--text-secondary:#475467;--text-muted:#8592ad;--input-bg:#00000008;--hover-bg:#00000008;--hover-bg-secondary:#0000000d;--alert-strip-bg:#00000004;--alert-strip-hover-bg:#00000008;--color-primary-glow:#0369a11f;--color-spo2-glow:#00f2fe1f;--color-bp-glow:#39ff141f;--color-warning-glow:#ffb6061f;--box-shadow-glow:0 8px 32px 0 #0000000f}[data-theme=light] .brand-name{background:linear-gradient(135deg, var(--text-primary) 40%, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}[data-theme=light] .ecg-canvas-wrapper{background-color:#fafafa;border:1px solid #00000014}[data-theme=light] .avatar{background:linear-gradient(135deg,#6366f1,#06b6d4)}[data-theme=light] .patient-status.normal{color:#27ae60;background:#2ecc711f}[data-theme=light] .patient-status.critical{color:#c0392b;background:#e74c3c1f}[data-theme=light] .btn-secondary{color:var(--text-primary)}[data-theme=light] ::-webkit-scrollbar-track{background:var(--bg-primary)}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--bg-tertiary)}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.route-loading{min-height:100vh;color:var(--text-secondary);background:var(--bg-primary);justify-content:center;align-items:center;font-weight:700;display:flex}.role-shell{background:radial-gradient(circle at 0% 0%, #ff33661f, transparent 32%), radial-gradient(circle at 100% 20%, #00f2fe14, transparent 30%), var(--bg-primary);grid-template-columns:290px 1fr;min-height:100vh;display:grid}.role-sidebar{border-right:1px solid var(--glass-border);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);background:#0b1020bd;flex-direction:column;gap:18px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}[data-theme=light] .role-sidebar{background:#ffffffc7}.role-brand{border-bottom:1px solid var(--glass-border);align-items:center;gap:12px;padding:6px 6px 18px;display:flex}.role-brand-subtitle{color:var(--text-muted);margin-top:4px;font-size:.78rem;font-weight:700}.role-menu{flex-direction:column;gap:6px;padding-right:4px;display:flex;overflow-y:auto}.role-menu-item{color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;min-height:42px;transition:var(--transition-smooth);background:0 0;border:1px solid #0000;border-radius:14px;align-items:center;gap:11px;padding:10px 12px;font-weight:750;display:flex}.role-menu-item:hover,.role-menu-item.active{color:var(--text-primary);border-color:var(--glass-border-hover);background:linear-gradient(135deg, var(--color-primary-glow), #00f2fe14)}.role-menu-item.logout{color:#e05c72;background:#e05c7214;border:1px solid #e05c721f;margin-top:auto;transition:background .22s,color .22s,border-color .22s}.role-menu-item.logout:hover{color:#f87192;background:#e05c722e;border-color:#e05c7252}.logout-modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:1200;background:#0009;justify-content:center;align-items:center;display:flex}.logout-modal-content{background:var(--glass-bg,#101624f2);border:1px solid var(--glass-border,#ffffff1a);text-align:center;border-radius:20px;width:90%;max-width:400px;padding:32px 28px 24px;animation:.2s fadeInScale;box-shadow:0 20px 60px #0006}@keyframes fadeInScale{0%{opacity:0;transform:scale(.93)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.logout-modal-icon-wrap{justify-content:center;margin-bottom:16px;display:flex}.logout-modal-icon{color:#e05c72;background:#e05c721f;border:2px solid #e05c7247;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.logout-modal-title{color:var(--text-primary);margin:0 0 8px;font-size:1.15rem;font-weight:700}.logout-modal-body{color:var(--text-secondary);margin:0 0 20px;font-size:.875rem;line-height:1.55}.logout-modal-error{color:#e05c72;background:#e05c721a;border:1px solid #e05c7240;border-radius:8px;margin-bottom:16px;padding:8px 12px;font-size:.8rem}.logout-modal-actions{justify-content:center;gap:10px;display:flex}.logout-cancel-btn{flex:1;max-width:140px}.logout-confirm-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e05c72 0%,#c0392b 100%);border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;max-width:160px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:opacity .2s,transform .15s;display:flex}.logout-confirm-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.logout-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.spin-icon{animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.facebook-login-btn{color:#4a9ff5;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#1877f21a;border:1.5px solid #1877f259;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;height:44px;padding:0 18px;font-size:.875rem;font-weight:600;transition:background .2s,border-color .2s,color .2s,transform .15s;display:flex}.facebook-login-btn:hover:not(:disabled){color:#74b9ff;background:#1877f233;border-color:#1877f299;transform:translateY(-1px)}.facebook-login-btn:active:not(:disabled){transform:translateY(0)}.facebook-login-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}[data-theme=light] .facebook-login-btn{color:#1877f2;background:#1877f214;border-color:#1877f24d}[data-theme=light] .facebook-login-btn:hover:not(:disabled){color:#0a5dc2;background:#1877f226;border-color:#1877f2}.facebook-login-btn--unconfigured{opacity:.7;cursor:pointer}.social-login-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:12px;margin:1.25rem 0 0;font-size:.75rem;display:flex}.social-login-divider span:not(.divider-label){background:var(--glass-border);flex:1;height:1px}.social-login-buttons{flex-direction:column;gap:10px;margin-top:10px;display:flex}.role-main{flex-direction:column;min-width:0;display:flex}.role-header{z-index:20;border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0b1020a8;justify-content:space-between;align-items:center;height:78px;padding:0 28px;display:flex;position:sticky;top:0}[data-theme=light] .role-header{background:#ffffffb8}.role-header-left,.role-header-actions,.role-user-card{align-items:center;gap:12px;display:flex}.locale-switch{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:999px;align-items:center;padding:4px;display:inline-flex}.locale-switch button{color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:999px;min-width:34px;height:30px;padding:0 10px;font-weight:800}.locale-switch button.active{background:var(--hover-bg-secondary);color:var(--text-primary)}.role-header h1{letter-spacing:-.02em;margin:0;font-size:1.2rem}.role-header-kicker{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:850}.role-mobile-icon{display:none}.role-user-card{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:999px;padding:7px 10px}.role-content{padding:28px 28px 110px}.role-page-stack{flex-direction:column;gap:22px;display:flex}.settings-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:20px;display:grid}.settings-card{flex-direction:column;grid-column:span 12;gap:18px;padding:22px;display:flex}.settings-card:first-child,.settings-card:nth-child(2){grid-column:span 6}.settings-card-heading{align-items:flex-start;gap:12px;display:flex}.settings-card-heading h3{margin:0;font-size:1rem}.settings-card-heading p{color:var(--text-secondary);margin:4px 0 0;font-size:.92rem}.settings-segmented-control{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;align-items:center;gap:6px;width:fit-content;padding:4px;display:inline-flex}.settings-segmented-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:10px;min-width:96px;height:38px;padding:0 14px;font-weight:800}.settings-segmented-btn.active{color:var(--text-primary);background:var(--hover-bg-secondary)}.settings-helper-note{color:var(--text-secondary);font-size:.92rem;line-height:1.6}.settings-switch-list{flex-direction:column;gap:12px;display:flex}.settings-switch-row{border:1px solid var(--glass-border);background:#ffffff05;border-radius:14px;justify-content:space-between;align-items:center;gap:18px;padding:14px 16px;display:flex}.settings-switch-row input{width:18px;height:18px;accent-color:var(--color-primary)}.settings-switch-label{color:var(--text-primary);font-weight:750}.settings-switch-desc{color:var(--text-secondary);margin-top:4px;font-size:.9rem;line-height:1.5}.settings-action-grid{flex-wrap:wrap;gap:12px;display:flex}.settings-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.settings-summary>div{border:1px solid var(--glass-border);background:#ffffff05;border-radius:14px;padding:14px 16px}.settings-summary span{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;display:block}.settings-summary strong{color:var(--text-primary);word-break:break-word;align-items:center;gap:6px;margin-top:6px;font-size:.96rem;display:inline-flex}.settings-saved-indicator{color:var(--color-bp)}@media (width<=1024px){.settings-card:first-child,.settings-card:nth-child(2),.settings-card:nth-child(3){grid-column:span 12}.settings-summary{grid-template-columns:1fr}}.role-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.role-stat-card{border:1px solid var(--glass-border);background:var(--glass-bg);box-shadow:var(--box-shadow-glow);border-radius:20px;align-items:flex-start;gap:14px;padding:18px;display:flex}.role-stat-card.danger .role-stat-icon{color:var(--color-critical);background:var(--color-primary-glow)}.role-stat-icon{width:44px;height:44px;color:var(--color-spo2);background:var(--color-spo2-glow);border-radius:16px;place-items:center;display:grid}.role-stat-label,.role-stat-hint,.role-muted{color:var(--text-muted)}.role-stat-label{font-size:.82rem;font-weight:750}.role-stat-value{color:var(--text-primary);margin:4px 0;font-size:1.65rem;font-weight:900;line-height:1}.role-stat-hint{font-size:.78rem}.role-page-grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:18px;display:grid}.real-chart-bars{align-items:end;gap:14px;height:260px;padding:20px 6px;display:flex}.real-chart-bars span{background:linear-gradient(180deg, var(--color-primary), var(--color-spo2));border-radius:999px 999px 6px 6px;flex:1;min-width:24px;box-shadow:0 12px 28px #00f2fe29}.activity-list{color:var(--text-secondary);flex-direction:column;gap:10px;display:flex}.activity-list>div{border:1px solid var(--glass-border);background:var(--hover-bg);border-radius:14px;padding:12px 14px}.quick-action-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.quick-action-card{border:1px solid var(--glass-border);background:var(--hover-bg);color:var(--text-primary);border-radius:18px;padding:18px;font-weight:850}.sos-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f36,#ff6b35);border:0;border-radius:999px;padding:13px 22px;font-weight:900;box-shadow:0 14px 30px #ff336647}.placeholder-panel{max-width:860px}.module-detail-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.7fr);gap:18px;display:grid}.module-hero-card{background:radial-gradient(circle at 16% 12%, var(--color-primary-glow), transparent 34%), radial-gradient(circle at 86% 20%, var(--color-spo2-glow), transparent 36%), var(--glass-bg);flex-direction:column;justify-content:flex-end;min-height:250px;display:flex;position:relative;overflow:hidden}.module-hero-card h2{color:var(--text-primary);letter-spacing:-.03em;margin:0 0 10px;font-size:1.7rem}.module-hero-card p{max-width:720px;color:var(--text-secondary);margin:0;line-height:1.65}.module-hero-mark{width:72px;height:72px;color:var(--text-primary);border:1px solid var(--glass-border);background:var(--hover-bg);font-family:var(--font-display);letter-spacing:-.08em;border-radius:24px;place-items:center;font-weight:950;display:grid;position:absolute;top:20px;right:22px}.role-mobile-nav{display:none}@media (width<=1180px){.role-shell{grid-template-columns:1fr}.role-sidebar{display:none}.role-mobile-icon{display:block}.role-stat-grid,.quick-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.role-page-grid,.module-detail-grid{grid-template-columns:1fr}.role-mobile-nav{z-index:50;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);background:#0b1020d1;border-radius:22px;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;display:grid;position:fixed;bottom:14px;left:14px;right:14px}[data-theme=light] .role-mobile-nav{background:#ffffffdb}.role-mobile-nav-item{color:var(--text-muted);background:0 0;border:0;border-radius:15px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:.68rem;font-weight:800;display:flex}.role-mobile-nav-item span{-webkit-line-clamp:2;text-align:center;-webkit-box-orient:vertical;max-width:72px;line-height:1.1;display:-webkit-box;overflow:hidden}.role-mobile-nav-item.active{color:var(--text-primary);background:var(--hover-bg-secondary)}}@media (width<=720px){.role-header{align-items:flex-start;gap:12px;height:auto;min-height:74px;padding:14px 16px}.role-header-actions .role-user-card .user-info{display:none}.role-content{padding:18px 14px 104px}.role-stat-grid,.quick-action-grid{grid-template-columns:1fr}.real-chart-bars{height:180px}}.email-cms-page{flex-direction:column;gap:0;display:flex}.email-cms-panel{border-radius:0 0 var(--border-radius) var(--border-radius);border-top:none;margin-top:0}.email-cms-tabs{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--border-radius) var(--border-radius) 0 0;border-bottom:none;gap:0;padding:0 20px;display:flex;overflow-x:auto}.email-cms-tab-btn{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;padding:14px 20px;font-size:.875rem;font-weight:500;display:flex}.email-cms-tab-btn:hover{color:var(--text-primary)}.email-cms-tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.email-templates-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.email-templates-count{color:var(--text-muted);margin-left:auto;font-size:.8rem}.email-logs-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.email-logs-filters{flex-wrap:wrap;flex:1;gap:10px;display:flex}.email-logs-actions{gap:8px;display:flex}.email-logs-search-wrap{background:var(--input-bg);border:1px solid var(--glass-border);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:200px;padding:8px 12px;display:flex}.email-logs-search{color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;width:100%;font-size:.875rem}.email-logs-search:focus{outline:none}.email-logs-status-filter{min-width:150px;padding:8px 12px;font-size:.875rem}.email-logs-table-wrap{border:1px solid var(--glass-border);border-radius:12px;margin-bottom:16px;overflow-x:auto}.email-logs-table{border-collapse:collapse;width:100%;font-size:.875rem}.email-logs-table thead tr{border-bottom:1px solid var(--glass-border);background:#ffffff05}.email-logs-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:12px 16px;font-size:.78rem;font-weight:600}.email-logs-row{border-bottom:1px solid var(--glass-border);transition:background .15s}.email-logs-row:last-child{border-bottom:none}.email-logs-row:hover{background:#ffffff05}.email-logs-cell{vertical-align:middle;padding:12px 16px}.email-cell{text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.85rem;overflow:hidden}.subject-cell{color:var(--text-secondary);max-width:240px}.muted-cell{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.email-logs-empty{text-align:center;color:var(--text-muted);padding:48px 16px;font-size:.9rem}.email-logs-container{position:relative}.email-status-badge{align-items:center;gap:4px;font-size:.8rem;font-weight:600;display:inline-flex}.email-type-badge{border:1px solid var(--glass-border);color:var(--text-secondary);white-space:nowrap;background:#ffffff0d;border-radius:20px;padding:3px 10px;font-size:.75rem;display:inline-block}.template-name-badge{color:var(--text-secondary);font-size:.8rem;font-style:italic}.template-name-main{color:var(--text-primary);font-weight:600}.email-log-error-msg{color:var(--color-critical);opacity:.75;margin-top:3px;font-size:.72rem}.email-template-actions{align-items:center;gap:4px;display:flex}.email-action-btn{border:1px solid var(--glass-border);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0a;border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.email-action-btn:hover{color:var(--text-primary);border-color:var(--glass-border-hover);background:#ffffff14}.email-action-btn.danger:hover{color:var(--color-critical);background:#ff33661f;border-color:#ff33664d}.email-retry-btn{align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;display:inline-flex}.email-editor-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:stretch;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.email-editor-modal{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:20px;flex-direction:column;width:100%;max-width:1400px;margin:16px;animation:.25s slideUp;display:flex;overflow:hidden;box-shadow:0 32px 80px #0009}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.email-editor-header{border-bottom:1px solid var(--glass-border);background:#ffffff05;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.email-editor-title{font-size:1.15rem;font-weight:700}.email-editor-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8rem}.email-editor-header-actions{align-items:center;gap:8px;display:flex}.email-editor-body{flex:1;grid-template-columns:420px 1fr;min-height:0;display:grid;overflow:hidden}.email-editor-left{border-right:1px solid var(--glass-border);background:#ffffff03;flex-direction:column;gap:0;padding:20px;display:flex;overflow-y:auto}.email-editor-variables-drawer{border:1px solid var(--glass-border);border-radius:12px;max-height:260px;margin-bottom:16px;overflow:hidden auto}.email-editor-row{align-items:flex-start;gap:12px;display:flex}.email-editor-toggle-label{color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;font-size:.85rem;display:flex}.email-editor-textarea-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.email-editor-char-count{color:var(--text-muted);font-size:.75rem}.email-editor-html-textarea{resize:vertical;tab-size:2;white-space:pre;color:#a8d8a0;background:#0000004d;min-height:240px;font-family:Courier New,Consolas,monospace;font-size:.78rem;line-height:1.6;overflow-x:auto}.email-editor-right{background:#f3f4f6;flex-direction:column;display:flex;overflow:hidden}.email-preview-toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--glass-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.email-preview-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:600}.email-preview-mode-btns{gap:4px;display:flex}.email-preview-mode-btn{border:1px solid var(--glass-border);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0a;border-radius:7px;justify-content:center;align-items:center;display:flex}.email-preview-mode-btn.active{border-color:var(--color-primary);color:var(--color-primary);background:#ff33661a}.email-preview-frame-wrap{background:#e5e7eb;flex:1;justify-content:center;align-items:flex-start;padding:20px;display:flex;overflow:auto}.email-preview-frame-wrap.desktop .email-preview-iframe{width:100%;max-width:680px}.email-preview-frame-wrap.mobile .email-preview-iframe{width:375px;max-width:375px}.email-preview-iframe{background:#fff;border:none;border-radius:8px;min-height:500px;box-shadow:0 4px 24px #00000026}.email-send-layout{align-items:flex-start;gap:20px;display:flex}.email-send-form-panel{flex:0 0 480px;min-width:0}.email-send-preview-panel{flex:1;min-width:0}.email-send-title{margin-bottom:4px;font-size:1rem;font-weight:700}.email-send-subtitle{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem}.email-send-form-row{gap:12px;display:flex}.email-send-actions{gap:10px;margin-top:8px;display:flex}.email-variables-json{color:#a8d8a0;background:#00000040;font-family:Courier New,monospace;font-size:.82rem;line-height:1.6}.email-variables-json.error{border-color:var(--color-critical)}.email-variables-panel{padding:20px}.email-variables-header{margin-bottom:16px}.email-variables-title{margin-bottom:4px;font-size:1rem;font-weight:700}.email-variables-subtitle{color:var(--text-secondary);font-size:.85rem}.email-variables-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-bottom:24px;display:grid}.email-variable-card{border:1px solid var(--glass-border);cursor:pointer;text-align:left;transition:var(--transition-smooth);background:#ffffff08;border-radius:10px;flex-direction:column;gap:4px;padding:12px 14px;display:flex}.email-variable-card:hover{background:#ff33660f;border-color:#ff33664d}.email-variable-syntax{color:var(--color-spo2);font-family:Courier New,monospace;font-size:.82rem;font-weight:600}.email-variable-desc{color:var(--text-muted);font-size:.78rem}.email-variables-example{border:1px solid var(--glass-border);background:#0003;border-radius:10px;padding:16px}.email-variables-example h4{color:var(--text-secondary);margin-bottom:10px;font-size:.85rem;font-weight:600}.email-variables-code{color:#a8d8a0;white-space:pre;font-family:Courier New,monospace;font-size:.8rem;line-height:1.7;overflow-x:auto}@media (width<=900px){.email-editor-body{grid-template-columns:1fr}.email-editor-right{min-height:300px}.email-send-layout{flex-direction:column}.email-send-form-panel{flex:none;width:100%}}@media (width<=600px){.email-cms-tabs{padding:0 12px}.email-cms-tab-btn{padding:12px 14px;font-size:.8rem}.email-variables-grid{grid-template-columns:1fr 1fr}}.patient-chatbot-page,.doctor-chatbot-page{flex-direction:column;height:calc(100vh - 120px);display:flex}.chatbot-layout{flex:1;gap:24px;display:flex;overflow:hidden}.chatbot-main-col{flex-direction:column;flex:1;min-width:0;display:flex}.chatbot-side-col{flex-direction:column;gap:16px;width:300px;display:flex;overflow-y:auto}.doctor-layout .chatbot-side-col{width:320px}.chat-panel{flex-direction:column;flex:1;padding:0;display:flex;overflow:hidden}.chat-window-container{flex-direction:column;height:100%;display:flex}.chat-messages-area{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.chat-empty-state{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.chat-empty-icon{color:var(--color-primary);opacity:.6;margin-bottom:16px}.chat-input-area{border-top:1px solid var(--glass-border);background:#ffffff05;padding:20px}.chat-input-form{background:var(--input-bg);border:1px solid var(--glass-border);transition:var(--transition-smooth);border-radius:12px;align-items:center;gap:12px;padding:6px;display:flex}.chat-input-form:focus-within{border-color:var(--color-primary);background:#ffffff0d}.chat-input{color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;flex:1;padding:10px 14px;font-size:.95rem}.chat-input:focus{outline:none}.chat-send-btn{background:var(--color-primary);color:#fff;cursor:pointer;width:40px;height:40px;transition:var(--transition-smooth);border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.chat-send-btn:disabled{color:var(--text-muted);cursor:not-allowed;background:#ffffff1a}.chat-disclaimer{text-align:center;color:var(--text-muted);margin-top:12px;font-size:.75rem}.chat-message-row{gap:16px;max-width:85%;display:flex}.chat-message-row.user{flex-direction:row-reverse;align-self:flex-end}.chat-message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.chat-message-row.ai .chat-message-avatar{background:linear-gradient(135deg, var(--color-primary), #f05);color:#fff;box-shadow:0 0 10px var(--color-primary-glow)}.chat-message-row.user .chat-message-avatar{background:var(--bg-tertiary);border:1px solid var(--glass-border);color:var(--text-secondary)}.chat-message-bubble{border-radius:16px;padding:14px 18px;font-size:.95rem;line-height:1.5}.chat-message-row.user .chat-message-bubble{border:1px solid var(--glass-border);background:#ffffff0d;border-top-right-radius:4px}.chat-message-row.ai .chat-message-bubble{background:0 0;padding:8px 0}.markdown-body h1,.markdown-body h2,.markdown-body h3{color:var(--text-primary);margin-top:16px;margin-bottom:10px;font-weight:600}.markdown-body p{margin-bottom:10px}.markdown-body ul,.markdown-body ol{margin-bottom:10px;margin-left:20px}.markdown-body li{margin-bottom:4px}.markdown-body strong{color:var(--color-primary)}.typing-cursor{background-color:var(--text-primary);vertical-align:middle;width:8px;height:16px;margin-left:4px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.spin-anim{animation:1s linear infinite spin}.ai-quick-actions{margin-top:auto;padding:16px}.quick-actions-title{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem}.quick-actions-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.quick-action-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;text-align:left;transition:var(--transition-smooth);background:#ffffff08;border-radius:10px;align-items:center;gap:10px;padding:12px;display:flex}.quick-action-btn:hover{color:var(--text-primary);background:#ff33660d;border-color:#ff33664d}.qa-icon{color:var(--color-primary)}.qa-label{font-size:.8rem;font-weight:500}.info-panel-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.info-panel-header h3{font-size:.95rem;font-weight:600}.info-panel-desc{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.patient-list-compact{flex-direction:column;gap:8px;display:flex}.patient-row-compact{cursor:pointer;background:#ffffff05;border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:10px;transition:all .2s;display:flex}.patient-row-compact:hover{background:#ffffff0d}.patient-row-compact.active{background:#ff33660d;border-color:#ff33664d}.avatar-mini{background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-primary);border-radius:6px;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.p-name{font-size:.9rem;font-weight:500}.p-meta{color:var(--text-muted);font-size:.75rem}.mobile-drawer-overlay{-webkit-backdrop-filter:blur(8px);z-index:10200;background:#0009;animation:.25s ease-out fade-in;position:fixed;inset:0}.mobile-drawer{background:var(--bg-secondary);border-top:1px solid var(--glass-border);z-index:10201;border-top-left-radius:24px;border-top-right-radius:24px;max-height:85vh;padding:16px 20px 32px;animation:.3s cubic-bezier(.16,1,.3,1) slide-up;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -10px 30px #0000004d}.mobile-drawer-handle{background:#fff3;border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.mobile-drawer-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.mobile-drawer-title{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem;font-weight:700}.mobile-drawer-close-btn{color:var(--text-primary);cursor:pointer;width:32px;height:32px;transition:var(--transition-smooth);background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.mobile-drawer-close-btn:hover{background:#ffffff26}.mobile-drawer-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.mobile-drawer-item{border:1px solid var(--glass-border);cursor:pointer;transition:var(--transition-smooth);color:var(--text-secondary);background:#ffffff08;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px 12px;display:flex}.mobile-drawer-item:hover,.mobile-drawer-item.active{color:var(--color-primary);background:#ff336614;border-color:#ff33664d}.mobile-drawer-item span{text-align:center;word-break:break-word;font-size:.75rem;font-weight:500}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.realtime-status-strip{border:1px solid var(--glass-border);background:#0c0e1299;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:1.5rem;padding:.75rem 1.25rem;display:flex}.realtime-status-indicator{align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.realtime-status-indicator:before{content:"";border-radius:50%;width:8px;height:8px;display:inline-block}.realtime-status-indicator.live{color:var(--color-safe)}.realtime-status-indicator.live:before{background-color:var(--color-safe);box-shadow:0 0 8px var(--color-safe);animation:1.5s infinite pulse-indicator}.realtime-status-indicator.waiting{color:var(--text-secondary)}.realtime-status-indicator.waiting:before{background-color:var(--text-muted)}.realtime-status-meta{color:var(--text-muted);font-size:.8rem;font-family:var(--font-sans)}@keyframes pulse-indicator{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.metric-status-badge{text-transform:uppercase;border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:700}.metric-status-badge.normal{color:var(--color-safe);background:#10b9811a;border:1px solid #10b98133}.metric-status-badge.warning{color:var(--color-warning);background:#f59e0b1a;border:1px solid #f59e0b33}.metric-status-badge.critical,.metric-status-badge.high{color:var(--color-critical);background:#ef444426;border:1px solid #ef44444d;animation:1.5s infinite pulse-border}.metric-status-badge.low{color:var(--color-info);background:#3b82f61f;border:1px solid #3b82f633}.metric-range{color:var(--text-muted);font-size:.75rem}.metric-source{color:var(--text-muted);font-size:.75rem;font-style:italic}.bp-value{font-size:clamp(2rem,4.5vw,2.75rem)!important}.tabular-nums{font-variant-numeric:tabular-nums;-moz-font-feature-settings:"tnum";-webkit-font-feature-settings:"tnum";font-feature-settings:"tnum";letter-spacing:normal!important}.ecg-panel-header{border-bottom:1px solid var(--glass-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.ecg-panel-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.ecg-panel-meta{align-items:center;gap:12px;display:flex}.ecg-status-badge{color:var(--text-secondary);border:1px solid var(--glass-border);background:#ffffff0d;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:600}.simulation-controls-panel{border:1px dashed var(--glass-border);border-radius:var(--border-radius);background:#ffffff03;margin-top:1.5rem;padding:1.25rem}.simulation-label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:.5rem;font-size:.85rem;font-weight:700;display:flex}@media (prefers-reduced-motion:reduce){.beat-animated,.critical-pulse,.realtime-status-indicator.live:before{animation:none!important;transform:none!important}}.btn:focus-visible,.form-control:focus-visible{outline:2px solid var(--color-info);outline-offset:2px}@keyframes pulse-border{0%{border-color:#ef44444d}50%{border-color:#ef4444cc}to{border-color:#ef44444d}}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:1.5rem;display:flex}.dashboard-header-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.patient-summary-panel{flex-direction:column;gap:1.25rem;display:flex}.patient-summary-row{font-size:.85rem}.dashboard-side-column{flex-direction:column;gap:1.5rem;display:flex}.dashboard-empty-state{text-align:center;padding:4rem 1.5rem}.dashboard-empty-icon{color:var(--text-muted);margin-bottom:1.5rem;font-size:3rem}.patient-selector-wrapper{align-items:center;gap:8px;display:flex}.patient-selector-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.patient-selector{width:220px;height:42px;padding:6px 12px}.connection-badge{text-transform:uppercase;border-radius:12px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.connection-badge.offline{color:var(--color-critical);background:#ef44441a;border:1px solid #ef444433}.connection-badge.stale{color:var(--color-warning);background:#f59e0b1a;border:1px solid #f59e0b33}.connection-badge.live{color:var(--color-safe);background:#10b9811a;border:1px solid #10b98133}.connection-badge.waiting{color:var(--text-muted);border:1px solid var(--glass-border);background:#ffffff0d}.realtime-status-highlight{color:var(--text-primary)}.metric-header-right{align-items:center;gap:6px;display:flex}.metric-value--muted{color:var(--text-muted)}.heart-panel-center{justify-content:center;padding:1rem;display:flex}.patient-summary-title{border-bottom:1px solid var(--glass-border);padding-bottom:8px}.patient-info-name{font-size:1.15rem;font-weight:700;font-family:var(--font-display);margin-bottom:4px}.patient-info-meta{color:var(--text-secondary);font-size:.85rem}.patient-info-label{color:var(--text-muted);margin-bottom:2px;display:block}.patient-info-address{text-overflow:ellipsis;max-height:44px;display:block;overflow:hidden}.patient-info-medical{color:var(--color-warning);font-weight:500}.alert-section-title{align-items:center;gap:8px;margin-bottom:1rem;display:flex}.alert-section-icon{color:var(--color-primary)}.alert-empty-state{text-align:center;color:var(--text-muted);padding:2rem 1rem;font-size:.9rem}.alert-list-scroll{max-height:200px;padding-right:8px;overflow-y:auto}.alert-strip.warning{border-left:3px solid var(--color-warning);background:#f59e0b08}.alert-strip.critical .alert-strip-icon{color:var(--color-critical)}.alert-strip.warning .alert-strip-icon{color:var(--color-warning)}.alert-strip.low .alert-strip-icon{color:var(--color-info)}.alert-strip.critical .alert-strip-title{color:var(--color-critical);font-weight:800}.alert-strip.high .alert-strip-title{color:var(--color-critical);font-weight:700}.alert-strip.warning .alert-strip-title{color:var(--color-warning);font-weight:600}.alert-strip.low .alert-strip-title{color:var(--color-info);font-weight:500}.alert-severity-badge{text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:.7rem;font-weight:600}.alert-strip.critical .alert-severity-badge,.alert-strip.high .alert-severity-badge{color:var(--color-critical);border:1px solid #ef444445}.alert-strip.warning .alert-severity-badge{color:var(--color-warning);border:1px solid #f59e0b45}.alert-strip.low .alert-severity-badge{color:var(--color-info);border:1px solid #3b82f645}.sim-description{color:var(--text-muted);margin:8px 0 16px;font-size:.8rem}.sim-buttons-row{flex-wrap:wrap;gap:12px;display:flex}.btn-abnormal{background:linear-gradient(135deg, var(--color-critical), #c2003c);box-shadow:0 4px 15px #ef444440}.theme-toggle-btn{background:var(--glass-bg,#ffffff08);border:1px solid var(--glass-border,#ffffff14);width:38px;height:38px;color:var(--text-primary,#fff);cursor:pointer;border-radius:50%;outline:none;justify-content:center;align-items:center;padding:0;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 12px #00000026}[data-theme=light] .theme-toggle-btn{color:#1f2937;background:#00000008;border:1px solid #00000014;box-shadow:0 4px 12px #0000000a}.theme-toggle-btn:hover{color:#eab308;background:#ffffff14;border-color:#ffffff2e;transform:translateY(-2px)scale(1.05);box-shadow:0 6px 20px #eab30840}[data-theme=light] .theme-toggle-btn:hover{color:#3b82f6;background:#0000000f;border-color:#00000026;box-shadow:0 6px 20px #3b82f626}.theme-toggle-btn:active{transform:translateY(0)scale(.95)}.tabular-nums{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#ffffff05 25%,#ffffff12 50%,#ffffff05 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite shimmer}.flex-row{flex-direction:row;display:flex}.flex-col{flex-direction:column;display:flex}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.align-center{align-items:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-14{gap:14px}.gap-16{gap:16px}.gap-20{gap:20px}.text-center{text-align:center}.w-full{width:100%}.m-auto-12{margin:0 auto 12px}.tabular-nums{font-variant-numeric:tabular-nums}.menu-group-section{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.menu-group-header{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);opacity:.85;margin-top:4px;padding:6px 12px 2px;font-size:.68rem;font-weight:850}.menu-group-items{flex-direction:column;gap:4px;display:flex}.mobile-drawer-sections{flex-direction:column;gap:18px;margin-top:8px;display:flex}.mobile-drawer-section{flex-direction:column;gap:10px;display:flex}.mobile-drawer-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);opacity:.8;margin:0;padding-left:4px;font-size:.72rem;font-weight:850}.menu-group-section,.mobile-drawer-section{animation:.3s ease-out fade-in}.menu-group-container{flex-direction:column;gap:2px;display:flex}.menu-group-toggle{color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;min-height:42px;transition:var(--transition-smooth);background:0 0;border:1px solid #0000;border-radius:14px;justify-content:space-between;align-items:center;padding:10px 12px;font-weight:750;display:flex}.menu-group-toggle:hover,.menu-group-toggle.expanded{color:var(--text-primary);background:var(--hover-bg)}.menu-group-container.has-active .menu-group-toggle{color:var(--text-primary);font-weight:800}.group-toggle-left{align-items:center;gap:11px;display:flex}.menu-group-sub-items{border-left:1px dashed var(--glass-border);flex-direction:column;gap:2px;margin-top:2px;margin-left:20px;padding-left:12px;display:flex}.role-menu-item.sub-item{border-radius:10px;min-height:38px;padding:8px 12px;font-size:.88rem;font-weight:650}.mobile-drawer-section{border:1px solid var(--glass-border);background:#ffffff03;border-radius:16px;flex-direction:column;gap:8px;padding:12px;display:flex}.mobile-drawer-section-toggle{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:6px 4px;font-size:.82rem;font-weight:800;display:flex}.mobile-drawer-flat-items{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.admin-toolbar-responsive{flex-flow:wrap;align-items:center;gap:16px;width:100%;display:flex}.admin-toolbar-search{flex:300px}.admin-toolbar-selects{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.admin-stat-card-link{cursor:pointer;transition:var(--transition-smooth);position:relative;overflow:hidden}.admin-stat-card-link:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-info));opacity:0;width:100%;height:3px;transition:var(--transition-smooth);position:absolute;top:0;left:0}.admin-stat-card-link:hover:before{opacity:1}.admin-stat-card-link:hover{background-color:var(--bg-tertiary);box-shadow:var(--box-shadow-glow);border-color:var(--color-primary-glow);transform:translateY(-4px)}.admin-chart-wrapper{border-bottom:1px solid var(--glass-border);height:240px;margin-top:24px;padding:12px 0;display:flex;position:relative}.admin-chart-y-axis{height:100%;color:var(--text-muted);text-align:right;border-right:1px solid var(--glass-border);flex-direction:column;justify-content:space-between;width:40px;padding-right:8px;font-size:.72rem;display:flex}.admin-chart-bars-container{flex:1;justify-content:space-around;align-items:flex-end;height:100%;padding:0 16px;display:flex;position:relative}.admin-chart-grid-lines{pointer-events:none;flex-direction:column;justify-content:space-between;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.admin-chart-grid-line{border-top:1px dashed #ffffff08;width:100%;height:0}.admin-chart-bar-col{z-index:2;flex-direction:column;justify-content:flex-end;align-items:center;width:15%;height:100%;display:flex;position:relative}.admin-chart-bar-pillar{background:linear-gradient(180deg, var(--color-primary), var(--color-primary-glow));border-radius:8px 8px 0 0;width:100%;max-width:48px;transition:height .8s cubic-bezier(.25,.8,.25,1);position:relative}.admin-chart-bar-pillar.accent-blue{background:linear-gradient(180deg, var(--color-spo2), var(--color-spo2-glow))}.admin-chart-bar-pillar.accent-green{background:linear-gradient(180deg, var(--color-bp), var(--color-bp-glow))}.admin-chart-bar-pillar.accent-warning{background:linear-gradient(180deg, var(--color-warning), var(--color-warning-glow))}.admin-chart-bar-tooltip{background:var(--bg-primary);border:1px solid var(--glass-border);color:var(--text-primary);opacity:0;pointer-events:none;transition:var(--transition-smooth);white-space:nowrap;z-index:10;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:700;position:absolute;top:-36px;transform:translateY(8px);box-shadow:0 4px 12px #00000080}.admin-chart-bar-pillar:hover .admin-chart-bar-tooltip{opacity:1;transform:translateY(0)}.admin-chart-x-axis-labels{justify-content:space-around;margin-left:40px;padding-top:10px;display:flex}.admin-chart-x-label{text-align:center;width:15%;color:var(--text-secondary);font-size:.75rem;font-weight:600}.admin-quick-actions-panel{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px;display:grid}.admin-quick-action-btn{background:var(--bg-secondary);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);text-align:left;border-radius:14px;align-items:center;gap:12px;padding:16px;font-weight:600;display:flex}.admin-quick-action-btn:hover{background:var(--bg-tertiary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #ef44441a}.admin-quick-action-icon{background:var(--color-primary-glow);width:36px;height:36px;color:var(--color-primary);border-radius:10px;justify-content:center;align-items:center;display:flex}.admin-quick-action-btn:hover .admin-quick-action-icon{background:var(--color-primary);color:#fff}.admin-role-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.admin-role-badge.admin{color:#ef4444;background:#ef44441f;border:1px solid #ef444433}.admin-role-badge.doctor{color:#0ea5e9;background:#0ea5e91f;border:1px solid #0ea5e933}.admin-role-badge.patient{color:#10b981;background:#10b9811f;border:1px solid #10b98133}.admin-verif-grid{grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:24px;width:100%;display:grid}@media (width<=900px){.admin-verif-grid{grid-template-columns:1fr}}.verif-doc-card-preview{cursor:pointer;border:1px solid var(--glass-border);border-radius:10px;height:96px;position:relative;overflow:hidden}.verif-doc-card-preview:hover{border-color:var(--color-primary)}.verif-doc-card-preview:after{content:"Phóng to";color:#fff;opacity:0;transition:var(--transition-smooth);background:#00000080;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex;position:absolute;inset:0}.verif-doc-card-preview:hover:after{opacity:1}.clinical-range-slider{-webkit-appearance:none;background:var(--bg-tertiary);width:100%;height:6px;transition:var(--transition-smooth);border-radius:3px;outline:none}.clinical-range-slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;border-radius:50%;width:16px;height:16px;transition:transform .1s;box-shadow:0 0 10px #ef444480}.clinical-range-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}@keyframes slideInRight{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:translate(0)}}.premium-toast{transition:all .3s;position:relative}.premium-toast:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0000001f,0 4px 12px #0000000f}[data-theme=dark] .premium-toast{color:#f1f5f9;background:#1e293bcc!important;border:1px solid #ffffff14!important}[data-theme=light] .premium-toast{color:#1e293b;background:#ffffffe6!important;border:1px solid #0000000f!important}.notification-bell-container{background:var(--glass-bg,#ffffff08);border:1px solid var(--glass-border,#ffffff14);width:38px;height:38px;color:var(--text-primary,#fff);cursor:pointer;border-radius:50%;outline:none;justify-content:center;align-items:center;margin-right:8px;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;box-shadow:0 4px 12px #00000026}[data-theme=light] .notification-bell-container{color:#1f2937;background:#00000008;border:1px solid #00000014;box-shadow:0 4px 12px #0000000a}.notification-bell-container:hover{background:#ffffff14;border-color:#ffffff2e;transform:translateY(-2px)scale(1.05);box-shadow:0 6px 20px #ffffff1a}.notification-bell-container .bell-icon.has-unread{animation:1s ease-in-out infinite bellRing}@keyframes bellRing{0%{transform:rotate(0)}15%{transform:rotate(10deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(5deg)}60%{transform:rotate(-5deg)}75%{transform:rotate(2deg)}90%{transform:rotate(-2deg)}to{transform:rotate(0)}}.notification-badge-count{background:linear-gradient(135deg, var(--color-critical), #b91c1c);color:#fff;border:1px solid var(--bg-primary,#1e293b);border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.65rem;font-weight:800;animation:.3s cubic-bezier(.175,.885,.32,1.275) popScale;display:flex;position:absolute;top:-2px;right:-2px;box-shadow:0 0 8px #ef444499}@keyframes popScale{0%{transform:scale(0)}to{transform:scale(1)}}.auth-shell{background:radial-gradient(circle at 50% 40%,#ff336612 0%,#0000 65%);flex-direction:column;width:100vw;min-height:100vh;display:flex}.auth-shell-body{flex:1;justify-content:center;align-items:center;padding:32px 16px 24px;display:flex}.auth-panel{text-align:center;width:100%;max-width:420px;padding:2rem 2rem 1.5rem}.register-panel{max-width:480px;position:relative;overflow:hidden}.auth-brand{justify-content:center;align-items:center;gap:10px;margin-bottom:1.25rem;display:flex}.auth-title{font-family:var(--font-display);margin-bottom:4px;font-size:1.5rem;font-weight:700;line-height:1.25}.auth-subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem;line-height:1.5}.auth-error-strip{color:var(--color-critical);text-align:left;background:#d92d201a;border:1px solid #d92d2040;border-radius:10px;align-items:flex-start;gap:6px;margin-bottom:1.25rem;padding:10px 14px;font-size:.82rem;line-height:1.45;display:flex}.auth-error-label{white-space:nowrap;font-weight:700}.auth-success-strip{color:var(--color-spo2);text-align:left;background:#0891b21a;border:1px solid #0891b240;border-radius:10px;margin-bottom:1.25rem;padding:10px 14px;font-size:.82rem;line-height:1.45}.auth-form{text-align:left}.auth-label-row{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.auth-label-row label{margin-bottom:0!important}.auth-link-sm{color:var(--color-primary);cursor:pointer;opacity:.9;font-size:.78rem;font-weight:500}.auth-link-sm:hover{opacity:1}.input-icon-wrap{position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.input-with-icon{padding-left:40px!important}.input-with-icon-right{padding-right:40px!important}.input-icon-btn-right{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:0;line-height:1;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.input-icon-btn-right:hover{color:var(--text-secondary)}.auth-submit-btn{justify-content:center;gap:6px;width:100%;height:44px;margin-top:.25rem;font-size:.9rem}.auth-footer{color:var(--text-secondary);text-align:center;margin-top:1.25rem;font-size:.83rem}.auth-link{color:var(--color-primary);cursor:pointer;font-weight:600;text-decoration:none}.auth-link:hover{opacity:.85}.auth-page-footer{text-align:center;color:var(--text-muted);border-top:1px solid #ffffff0a;flex-direction:column;gap:6px;padding:14px 16px;font-size:.78rem;display:flex}.social-icons-section{margin:1.25rem 0 1rem}.social-icons-divider{align-items:center;gap:10px;margin-bottom:12px;display:flex}.social-icons-line{background:var(--glass-border);flex:1;height:1px}.social-icons-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;font-size:.72rem;font-weight:500}.social-icons-row{flex-direction:row;justify-content:center;gap:14px;display:flex}.social-icon-wrapper{flex-direction:column;align-items:center;gap:6px;display:flex}.social-icon-btn{border:1.5px solid var(--glass-border);background:var(--glass-bg);cursor:pointer;width:48px;height:48px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s,border-color .2s,transform .15s,box-shadow .2s;display:flex;position:relative}.social-icon-btn:hover:not(:disabled){border-color:var(--glass-border-hover);background:#ffffff1a;transform:translateY(-2px);box-shadow:0 4px 16px #00000040}.social-icon-btn:active:not(:disabled){transform:translateY(0)}.social-icon-btn:disabled{opacity:.5;cursor:not-allowed}.social-icon-btn--google{background:#ffffff0f;border-color:#ffffff26}.social-icon-btn--google:hover:not(:disabled){background:#ffffff24;border-color:#ffffff4d}.social-icon-btn--facebook{color:#4a9ff5;background:#1877f20f;border-color:#1877f24d}.social-icon-btn--facebook:hover:not(:disabled){color:#74b9ff;background:#1877f226;border-color:#1877f28c}[data-theme=light] .social-icon-btn--google{background:#fff;border-color:#dadce0}[data-theme=light] .social-icon-btn--google:hover:not(:disabled){background:#f8f9fa;border-color:#bdc1c6}[data-theme=light] .social-icon-btn--facebook{color:#1877f2;background:#1877f20f;border-color:#1877f240}[data-theme=light] .social-icon-btn--facebook:hover:not(:disabled){background:#1877f21f;border-color:#1877f2}.social-icon-badge-warn{color:var(--color-warning);background:var(--glass-bg);border-radius:50%;position:absolute;bottom:2px;right:2px}.social-icon-error{color:var(--color-critical);text-align:center;max-width:200px;font-size:.72rem;line-height:1.35}.register-subtitle{max-width:400px;margin-left:auto;margin-right:auto}.reg-2col{grid-template-columns:1fr 1fr;gap:0 12px;display:grid}.reg-doctor-fields .form-group{margin-bottom:.9rem}.consent-row{align-items:flex-start;gap:9px;margin:1rem 0 1.25rem;display:flex}.consent-checkbox{width:15px;height:15px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;margin-top:2px}.consent-label{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;font-size:.8rem;line-height:1.45}.auth-helper-card{color:var(--text-secondary);text-align:left;background:#00f2fe0d;border:1px solid #00f2fe1f;border-radius:10px;align-items:flex-start;gap:8px;margin-bottom:1rem;padding:9px 12px;font-size:.8rem;line-height:1.45;display:flex}.auth-helper-card svg{color:var(--color-spo2);flex-shrink:0;margin-top:1px}.auth-panel .form-group,.register-panel .form-group{margin-bottom:1rem}.password-rule-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 8px;margin-top:8px;display:grid}.password-rule{color:var(--text-muted);align-items:center;gap:4px;font-size:.7rem;display:flex}.password-rule.valid,.password-rule.valid svg{color:var(--color-bp)}@media (width<=480px){.auth-panel{padding:1.5rem 1.25rem 1.25rem}.auth-shell-body{align-items:flex-start;padding:20px 12px 16px}.register-panel{max-width:100%}.reg-2col{grid-template-columns:1fr;gap:0}.social-icons-row{gap:18px}.social-icon-btn{width:50px;height:50px}}
