@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+Arabic:wght@400;500;600;700&display=swap";:root{--brand-primary: #0d9488;--brand-primary-dk: #0f766e;--brand-primary-lt: #f0fdfa;--brand-accent: #14b8a6;--brand-gold: #f59e0b;--shell-bg: #0f172a;--shell-surface: #1e293b;--shell-border: rgba(255,255,255,.06);--shell-text: #94a3b8;--shell-text-active: #f1f5f9;--shell-hover: rgba(255,255,255,.05);--shell-active: rgba(13,148,136,.15);--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--border: #e2e8f0;--border-focus: #0d9488;--text-1: #0f172a;--text-2: #475569;--text-3: #94a3b8;--success: #059669;--success-bg: #ecfdf5;--warn: #d97706;--warn-bg: #fffbeb;--error: #dc2626;--error-bg: #fef2f2;--info: #2563eb;--info-bg: #eff6ff;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-full: 9999px;--shadow-xs: 0 1px 2px rgba(15,23,42,.06);--shadow-sm: 0 1px 4px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 16px rgba(15,23,42,.1);--shadow-lg: 0 12px 32px rgba(15,23,42,.14);--sidebar-w: 248px;--topbar-h: 56px;--nav-h: 60px;--content-max:640px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;height:100%;-webkit-text-size-adjust:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;color:var(--text-1);background:var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ku{font-family:Noto Sans Arabic,sans-serif;direction:rtl;text-align:right}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}h1{font-size:22px;font-weight:700;line-height:1.25;letter-spacing:-.3px}h2{font-size:17px;font-weight:700;line-height:1.3}h3{font-size:14px;font-weight:600}h4{font-size:13px;font-weight:600}a{color:var(--brand-primary);text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--shell-bg);display:none;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;border-right:1px solid var(--shell-border)}.sidebar-logo{height:var(--topbar-h);display:flex;align-items:center;padding:0 var(--sp-5);border-bottom:1px solid var(--shell-border);gap:var(--sp-3);flex-shrink:0}.logo-mark{width:30px;height:30px;background:var(--brand-primary);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-mark svg{color:#fff}.logo-text{font-size:15px;font-weight:700;color:var(--shell-text-active);letter-spacing:-.2px}.logo-text span{color:var(--brand-accent)}.sidebar-section-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--shell-text);padding:var(--sp-5) var(--sp-5) var(--sp-2);opacity:.6}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--sp-3) var(--sp-3);display:flex;flex-direction:column;gap:2px}.sidebar-item{display:flex;align-items:center;gap:var(--sp-3);padding:9px var(--sp-3);border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--shell-text);text-decoration:none;cursor:pointer;border:none;background:transparent;width:100%;transition:background .15s,color .15s;letter-spacing:-.1px}.sidebar-item .si-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--shell-text);flex-shrink:0;transition:color .15s}.sidebar-item:hover{background:var(--shell-hover);color:var(--shell-text-active)}.sidebar-item:hover .si-icon{color:var(--shell-text-active)}.sidebar-item.active{background:var(--shell-active);color:var(--brand-accent)}.sidebar-item.active .si-icon{color:var(--brand-accent)}.sidebar-divider{height:1px;background:var(--shell-border);margin:var(--sp-2) var(--sp-3)}.sidebar-bottom{padding:var(--sp-3);border-top:1px solid var(--shell-border)}.sidebar-user-card{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--r-md);background:var(--shell-surface);margin-bottom:var(--sp-2)}.sidebar-avatar{width:32px;height:32px;border-radius:var(--r-md);background:var(--brand-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--shell-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--shell-text);margin-top:1px}.sidebar-lang-toggle{display:flex;background:var(--shell-surface);border-radius:var(--r-md);padding:3px;gap:2px;margin-bottom:var(--sp-2)}.sidebar-lang-toggle button{flex:1;padding:6px;border:none;border-radius:7px;background:transparent;color:var(--shell-text);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.sidebar-lang-toggle button.active{background:var(--brand-primary);color:#fff}.topbar{position:fixed;top:0;left:0;right:0;z-index:150;height:var(--topbar-h);background:var(--shell-bg);border-bottom:1px solid var(--shell-border);display:flex;align-items:center;padding:0 var(--sp-4);gap:var(--sp-3)}.topbar-logo{display:flex;align-items:center;gap:var(--sp-2)}.topbar-logo-text{font-size:15px;font-weight:700;color:var(--shell-text-active)}.topbar-logo-text span{color:var(--brand-accent)}.topbar-spacer{flex:1}.topbar-lang-btn{background:var(--shell-surface);border:1px solid var(--shell-border);color:var(--shell-text);padding:5px 10px;border-radius:var(--r-sm);font-size:11px;font-weight:700;cursor:pointer;transition:background .15s;letter-spacing:.04em}.topbar-lang-btn:hover{background:#ffffff14;color:var(--shell-text-active)}.topbar-avatar{width:30px;height:30px;background:var(--brand-primary);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.main-content{flex:1;padding:var(--sp-6) var(--sp-5) calc(var(--nav-h) + var(--sp-6));margin-top:var(--topbar-h);max-width:var(--content-max);width:100%;margin-left:auto;margin-right:auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:150;height:var(--nav-h);background:var(--shell-bg);border-top:1px solid var(--shell-border);display:flex}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--shell-text);font-size:10px;font-weight:600;cursor:pointer;text-decoration:none;transition:color .15s;border:none;background:transparent;letter-spacing:.02em}.bottom-nav-item svg{width:20px;height:20px}.bottom-nav-item.active{color:var(--brand-accent)}.bottom-nav-item:hover{color:var(--shell-text-active)}@media(min-width:768px){.sidebar{display:flex}.topbar,.bottom-nav{display:none}.main-content{margin-left:var(--sidebar-w);margin-top:0;padding:var(--sp-8) var(--sp-8) var(--sp-8);max-width:none}}.card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-xs);padding:var(--sp-5)}.card+.card{margin-top:var(--sp-3)}.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:var(--sp-4)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2);box-shadow:var(--shadow-xs)}.stat-card-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.stat-card-value{font-size:30px;font-weight:800;color:var(--text-1);line-height:1;letter-spacing:-1px}.stat-card-sub{font-size:12px;color:var(--text-3);font-weight:500}.stat-card-bar{height:3px;background:var(--surface-2);border-radius:99px;margin-top:var(--sp-2);overflow:hidden}.stat-card-bar-fill{height:100%;background:var(--brand-primary);border-radius:99px;transition:width .6s ease}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-6)}.qa-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);text-decoration:none;color:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.qa-card:after{content:"";position:absolute;top:0;right:0;width:3px;height:100%;background:var(--brand-primary);opacity:0;transition:opacity .15s}.qa-card:hover{border-color:var(--brand-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.qa-card:hover:after{opacity:1}.qa-card:hover{text-decoration:none}.qa-icon-wrap{width:36px;height:36px;border-radius:var(--r-md);background:var(--brand-primary-lt);display:flex;align-items:center;justify-content:center;color:var(--brand-primary)}.qa-icon-wrap svg{width:18px;height:18px}.qa-title{font-size:13px;font-weight:700;color:var(--text-1)}.qa-sub{font-size:11px;color:var(--text-3);font-weight:500}.patient-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;gap:var(--sp-4);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-xs)}.patient-card:hover{border-color:var(--brand-primary);box-shadow:var(--shadow-sm)}.patient-card:hover{text-decoration:none}.patient-avatar{width:40px;height:40px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;letter-spacing:-.5px}.patient-info{flex:1;min-width:0}.patient-name{font-weight:600;font-size:14px;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patient-sub{font-size:12px;color:var(--text-3);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:0 var(--sp-5);height:40px;border-radius:var(--r-md);font-family:Inter,sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;text-decoration:none;letter-spacing:-.1px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary-dk);box-shadow:0 1px 3px #0d94884d,inset 0 1px #ffffff1f}.btn-primary:hover{background:var(--brand-primary-dk);box-shadow:0 3px 8px #0d948859}.btn-accent{background:var(--brand-gold);color:#fff;border-color:#d97706;box-shadow:0 1px 3px #f59e0b4d}.btn-accent:hover{background:#d97706}.btn-ghost{background:transparent;color:var(--brand-primary);border-color:var(--border)}.btn-ghost:hover{background:var(--brand-primary-lt);border-color:var(--brand-primary)}.btn-danger{background:var(--error);color:#fff;border-color:#b91c1c}.btn-danger:hover{background:#b91c1c}.btn-neutral{background:var(--surface);color:var(--text-2);border-color:var(--border);box-shadow:var(--shadow-xs)}.btn-neutral:hover{background:var(--surface-2);color:var(--text-1)}.btn-sm{height:32px;padding:0 var(--sp-3);font-size:12px;border-radius:var(--r-sm)}.btn-lg{height:48px;padding:0 var(--sp-6);font-size:15px;border-radius:var(--r-md)}.btn-full{width:100%}.btn-icon{width:36px;height:36px;padding:0}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.02em;border:1px solid transparent}.badge-primary{background:var(--brand-primary-lt);color:var(--brand-primary-dk);border-color:#99f6e4}.badge-success{background:var(--success-bg);color:var(--success);border-color:#a7f3d0}.badge-warn{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}.badge-error{background:var(--error-bg);color:var(--error);border-color:#fecaca}.badge-neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}.badge-info{background:var(--info-bg);color:var(--info);border-color:#bfdbfe}.badge-accent{background:#fffbeb;color:var(--brand-gold);border-color:#fde68a}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--sp-5)}.form-label{font-size:13px;font-weight:600;color:var(--text-1);display:flex;align-items:center;gap:var(--sp-2)}.form-label-ku{font-family:Noto Sans Arabic,sans-serif;font-size:12px;color:var(--text-3);direction:rtl;display:block;margin-top:1px}.required-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--error)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=tel],textarea,select{width:100%;padding:0 var(--sp-4);height:40px;border:1px solid var(--border);border-radius:var(--r-md);font-family:Inter,sans-serif;font-size:14px;color:var(--text-1);background:var(--surface);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-shadow:var(--shadow-xs)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #0d94881f}input.error,textarea.error,select.error{border-color:var(--error)}textarea{height:auto;min-height:90px;padding:var(--sp-3) var(--sp-4);resize:vertical}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:36px}.form-error{font-size:12px;color:var(--error);display:flex;align-items:center;gap:4px}.form-hint{font-size:11px;color:var(--text-3)}.radio-group,.check-group{display:flex;flex-direction:column;gap:var(--sp-2)}.radio-option,.check-option{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;color:var(--text-2);background:var(--surface);min-height:48px;box-shadow:var(--shadow-xs)}.radio-option:hover,.check-option:hover{border-color:var(--brand-primary);color:var(--text-1);background:var(--brand-primary-lt)}.radio-option.selected,.check-option.selected{border-color:var(--brand-primary);background:var(--brand-primary-lt);color:var(--brand-primary-dk);font-weight:600}.radio-option input,.check-option input{display:none}.radio-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .15s}.radio-option.selected .radio-dot{border-color:var(--brand-primary);background:var(--brand-primary);box-shadow:inset 0 0 0 3px #fff}.check-box{width:16px;height:16px;border-radius:4px;border:2px solid var(--border);flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff}.check-option.selected .check-box{background:var(--brand-primary);border-color:var(--brand-primary)}.toggle-wrap{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color .15s;background:var(--surface);min-height:52px;box-shadow:var(--shadow-xs)}.toggle-wrap:hover{border-color:var(--brand-primary);background:var(--brand-primary-lt)}.toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}.toggle-switch input{display:none}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:99px;transition:background .15s}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:0 1px 3px #00000026}input:checked~.toggle-slider{background:var(--brand-primary)}input:checked~.toggle-slider:after{transform:translate(18px)}.step-bar{display:flex;align-items:center;padding:var(--sp-4) var(--sp-5);background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0}.step-bar::-webkit-scrollbar{height:0}.step-item{display:flex;align-items:center;flex-shrink:0;gap:var(--sp-2)}.step-dot{width:26px;height:26px;border-radius:50%;background:var(--surface-2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-3);transition:all .2s}.step-dot.done{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff}.step-dot.active{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff;box-shadow:0 0 0 4px #0d948826}.step-label{font-size:11px;font-weight:600;color:var(--text-3);display:none}.step-label.active{color:var(--brand-primary);display:block}.step-line{flex:1;min-width:16px;height:2px;background:var(--border);margin:0 var(--sp-2)}.step-line.done{background:var(--brand-primary)}.tab-bar{display:flex;border-bottom:1px solid var(--border);margin-bottom:var(--sp-5);overflow-x:auto;background:var(--surface);border-radius:var(--r-lg) var(--r-lg) 0 0}.tab-item{padding:var(--sp-3) var(--sp-4);font-size:13px;font-weight:600;color:var(--text-3);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:all .15s;background:transparent;flex-shrink:0}.tab-item.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}.tab-item:hover{color:var(--text-1)}.banner{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-4);border-radius:var(--r-md);font-size:13px;font-weight:500;margin-bottom:var(--sp-4);border:1px solid}.banner-success{background:var(--success-bg);color:var(--success);border-color:#a7f3d0}.banner-error{background:var(--error-bg);color:var(--error);border-color:#fecaca}.banner-warn{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}.banner-info{background:var(--info-bg);color:var(--info);border-color:#bfdbfe}.toast-container{position:fixed;bottom:calc(var(--nav-h) + var(--sp-4));left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--sp-2);pointer-events:none;width:min(90vw,340px)}@media(min-width:768px){.toast-container{bottom:var(--sp-6);left:auto;right:var(--sp-6);transform:none}}.toast{background:var(--shell-bg);color:var(--shell-text-active);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--sp-3);animation:toastIn .2s ease forwards;border:1px solid var(--shell-border);border-left:3px solid var(--brand-accent)}.toast.toast-error{border-left-color:var(--error)}.toast.toast-warn{border-left-color:var(--warn)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.upload-zone{border:1.5px dashed var(--border);border-radius:var(--r-lg);padding:var(--sp-8) var(--sp-5);text-align:center;cursor:pointer;transition:all .15s;background:var(--surface-2)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--brand-primary);background:var(--brand-primary-lt)}.upload-zone input{display:none}.upload-previews{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-3)}.upload-thumb{position:relative;width:72px;height:72px;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border)}.upload-thumb img{width:100%;height:100%;object-fit:cover}.thumb-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:#0f172ab3;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.upload-doc-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--surface-2);border-radius:var(--r-sm);font-size:12px;border:1px solid var(--border)}.page-header{margin-bottom:var(--sp-6)}.page-header h1{color:var(--text-1)}.page-header p{font-size:13px;color:var(--text-3);margin-top:4px}.section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:var(--sp-3)}.divider{height:1px;background:var(--border);margin:var(--sp-5) 0}.timeline{position:relative;padding-left:var(--sp-8)}.timeline:before{content:"";position:absolute;left:18px;top:0;bottom:0;width:1px;background:var(--border)}.timeline-item{position:relative;margin-bottom:var(--sp-4)}.timeline-dot{position:absolute;left:calc(-1 * var(--sp-8) + 10px);top:18px;width:20px;height:20px;border-radius:50%;border:3px solid var(--bg);z-index:1}.timeline-dot.pending{background:var(--border)}.perm-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:var(--surface-2)}.perm-toggle-btn{padding:5px 10px;font-size:11px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text-3);transition:all .15s}.perm-toggle-btn.active-inherit{background:var(--surface-2);color:var(--text-2)}.perm-toggle-btn.active-grant{background:var(--success);color:#fff}.perm-toggle-btn.active-deny{background:var(--error);color:#fff}.login-page{min-height:100vh;background:var(--shell-bg);background-image:radial-gradient(ellipse at 30% 50%,rgba(13,148,136,.18) 0%,transparent 60%),radial-gradient(ellipse at 70% 20%,rgba(20,184,166,.08) 0%,transparent 50%);display:flex;align-items:center;justify-content:center;padding:var(--sp-5)}.login-card{background:var(--shell-surface);border:1px solid var(--shell-border);border-radius:var(--r-xl);padding:var(--sp-8) var(--sp-6) var(--sp-6);width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.login-logo{text-align:center;margin-bottom:var(--sp-8)}.login-logo-mark{width:52px;height:52px;background:var(--brand-primary);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-4);box-shadow:0 8px 24px #0d948859}.login-logo h1{font-size:20px;color:var(--shell-text-active);font-weight:700;letter-spacing:-.3px}.login-logo h1 span{color:var(--brand-accent)}.login-logo p{color:var(--shell-text);font-size:13px;margin-top:4px}.login-card input{background:#ffffff0d;border-color:var(--shell-border);color:var(--shell-text-active)}.login-card input::placeholder{color:#94a3b866}.login-card input:focus{border-color:var(--brand-primary);background:#0d94880f;box-shadow:0 0 0 3px #0d948826}.login-card .form-label{color:var(--shell-text-active)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.25);border-top-color:currentColor;border-radius:50%;animation:spin .65s linear infinite;display:inline-block;flex-shrink:0}.spinner-dark{border-color:#0f172a26;border-top-color:var(--brand-primary)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-5)}.empty-state-icon{font-size:40px;opacity:.25;margin-bottom:var(--sp-4)}.empty-state h3{font-size:15px;font-weight:700;color:var(--text-1);margin-bottom:var(--sp-2)}.empty-state p{font-size:13px;color:var(--text-3)}.data-table-wrap{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--surface-2);padding:var(--sp-3) var(--sp-4);text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-1)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface-2)}.role-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col{display:flex;flex-direction:column}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-5{gap:var(--sp-5)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mb-2{margin-bottom:var(--sp-2)}.mb-4{margin-bottom:var(--sp-4)}.mb-6{margin-bottom:var(--sp-6)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-muted{color:var(--text-3)}.text-center{text-align:center}.font-semibold{font-weight:600}.font-bold{font-weight:700}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}
