:root{color-scheme:light;--bg:#f2f6ff;--bg-soft:#ecf2ff;--surface:#fff;--panel:#fff;--muted:#617297;--text:#13264d;--text-soft:#2b406d;--accent:#2460f2;--accent-strong:#1b4ed0;--accent-soft:#e9f0ff;--success:#0f9f70;--success-soft:#e8faf3;--danger:#ce4964;--danger-soft:#fff0f3;--border:#d8e3f8;--border-strong:#c6d5f5;--ring:#97b2ff;--shadow-soft:0 10px 28px rgba(32,67,139,.08);--shadow-card:0 16px 44px rgba(31,66,136,.09)}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;width:100%;font-family:Cairo,Tajawal,Noto Sans Arabic,Segoe UI,sans-serif;background:radial-gradient(circle at 6% -8%,rgba(38,96,242,.2) 0,rgba(38,96,242,0) 35%),radial-gradient(circle at 93% 0,rgba(102,84,240,.16) 0,rgba(102,84,240,0) 38%),linear-gradient(180deg,#f8faff 0,var(--bg) 100%);color:var(--text);text-align:start;overflow-x:hidden}body[dir=rtl],html[dir=rtl] body{direction:rtl}body[dir=ltr],html[dir=ltr] body{direction:ltr}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.layout{display:flex;flex-direction:row;gap:20px;min-height:100vh;padding:20px;width:100%}.sidebar{width:300px;min-width:300px;flex:0 0 300px;position:-webkit-sticky;position:sticky;top:20px;align-self:flex-start;max-height:calc(100vh - 40px);overflow:auto;background:linear-gradient(180deg,hsla(0,0%,100%,.98),rgba(246,250,255,.96));border:1px solid var(--border);border-radius:26px;padding:20px 16px;box-shadow:var(--shadow-soft)}.sidebar-drawer{--sidebar-hidden-shift:calc(-100% - 24px)}html[dir=rtl] .sidebar-drawer{--sidebar-hidden-shift:calc(100% + 24px)}.mobile-menu-button,.sidebar-mobile-head,.sidebar-overlay{display:none}.sidebar-mobile-head{align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.sidebar-mobile-title{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sidebar-close{width:40px;height:40px;border-radius:12px;border:1px solid var(--border-strong);background:#fff;color:var(--text-soft);cursor:pointer}.brand{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:4px}.brand-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-weight:800;font-size:13px;letter-spacing:.08em;color:#f6f9ff;background:linear-gradient(135deg,#2f66f4,#2357e4);box-shadow:0 8px 18px rgba(36,96,242,.28)}.brand-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.brand-copy strong{color:var(--text);font-size:20px;line-height:1.1}.brand-copy small{color:var(--muted);font-size:12px}.nav{gap:18px}.nav,.nav-section{display:flex;flex-direction:column}.nav-section{gap:10px}.nav-section+.nav-section{padding-top:18px;border-top:1px solid rgba(198,213,245,.8)}.nav-section-title{margin:0;padding-inline:8px;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.nav-group,.nav-section-items,.nav-subnav{display:flex;flex-direction:column}.nav-section-items,.nav-subnav{gap:6px}.nav-group-toggle,.nav-link{display:flex;width:100%;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;color:var(--text-soft);background:transparent;border:1px solid transparent;transition:all .2s ease;text-align:start}.nav-group-toggle{cursor:pointer}.nav-group-main,.nav-link-main{min-width:0;display:flex;align-items:center;gap:10px;flex:1 1 auto}.nav-key{width:34px;height:26px;flex:0 0 34px;border-radius:8px;display:grid;place-items:center;font-size:10px;font-weight:700;letter-spacing:.06em;color:#55709f;background:#eef3ff;border:1px solid #d8e2fb}.nav-label{min-width:0;font-weight:600}.nav-group-chevron{width:28px;height:28px;flex:0 0 28px;display:grid;place-items:center;border-radius:999px;font-size:14px;font-weight:800;color:#55709f;background:#eef3ff;border:1px solid #d8e2fb}.nav-subnav{margin-top:8px;-webkit-margin-start:18px;margin-inline-start:18px;-webkit-padding-start:14px;padding-inline-start:14px;-webkit-border-start:1px solid #d8e2fb;border-inline-start:1px solid #d8e2fb}.nav-link-nested{padding:9px 12px}.nav-link-nested .nav-key{width:30px;height:24px;flex-basis:30px;font-size:9px}.nav-group-toggle:hover,.nav-link:hover{background:#eef3ff;border-color:#d3e0ff;color:#1f3f83}.nav-group-toggle.active,.nav-link.active{background:linear-gradient(90deg,#e2ecff,#edf3ff);border-color:#bfd2ff;color:#173a83;box-shadow:0 8px 20px rgba(36,96,242,.12)}.nav-group-toggle.active .nav-group-chevron,.nav-group-toggle.active .nav-key,.nav-link.active .nav-key{color:#f4f8ff;background:linear-gradient(135deg,#2f66f4,#2357e4);border-color:#2454d8}.content{flex:1 1 auto;min-width:0;flex-direction:column}.content,.topbar{display:flex;gap:14px}.topbar{justify-content:space-between;align-items:flex-start;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--border);border-radius:18px;padding:14px 16px;box-shadow:var(--shadow-soft)}.topbar-primary{display:flex;align-items:flex-start;gap:12px;min-width:0;flex:1 1 auto}.topbar-heading h1{margin:0;color:var(--text);font-size:20px;font-weight:800;line-height:1.2}.topbar-heading p{margin:4px 0 0;color:var(--muted);font-size:13px}.topbar-actions{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.content-shell{width:min(100%,1560px);max-width:100%;display:flex;flex-direction:column;gap:16px}.page-title{margin:0;font-size:clamp(26px,4vw,34px);font-weight:800;line-height:1.1;color:var(--text)}.card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--border);border-radius:20px;padding:18px;box-shadow:var(--shadow-card);animation:card-enter .24s ease}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:32px;position:relative;overflow:hidden}.auth-controls{position:absolute;top:24px;inset-inline-end:24px;z-index:2;display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.auth-wrap:after,.auth-wrap:before{content:"";position:absolute;border-radius:999px;pointer-events:none;filter:blur(10px)}.auth-wrap:before{width:380px;height:380px;top:6%;inset-inline-start:-120px;background:rgba(86,131,255,.2)}.auth-wrap:after{width:420px;height:420px;bottom:-120px;inset-inline-end:-120px;background:rgba(83,210,181,.12)}.auth-shell{width:min(1120px,100%);display:grid;grid-template-columns:minmax(280px,1fr) minmax(340px,460px);grid-gap:20px;gap:20px;align-items:stretch;position:relative;z-index:1}.auth-hero{min-height:100%;padding:32px;border:1px solid var(--border);border-radius:26px;background:linear-gradient(180deg,hsla(0,0%,100%,.08),hsla(0,0%,100%,.02));box-shadow:var(--shadow-soft);display:flex;flex-direction:column;justify-content:space-between}.auth-hero .brand{margin-bottom:32px}.auth-hero-copy{max-width:520px}.auth-kicker{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);border:1px solid var(--border);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.auth-hero-copy h1{margin:18px 0 10px;font-size:clamp(32px,4vw,52px);line-height:1.02}.auth-hero-copy p{margin:0;color:var(--muted);font-size:15px;line-height:1.8}.auth-card{width:min(100%,460px);background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:0 24px 64px rgba(31,68,140,.15);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-card h1{margin:0 0 8px;font-size:28px}.auth-card p{margin:0 0 20px;color:var(--muted)}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.field label{color:var(--muted);font-size:14px}.field input{background:#f7faff;border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:12px}.field-compact{margin-bottom:0}.field-compact>span{color:var(--muted);font-size:13px}.field-help{color:#6d7ea3;font-size:12px;line-height:1.4}.btn{background:linear-gradient(135deg,var(--accent) 0,var(--accent-strong) 100%);color:#f8fbff;border:1px solid #1949c6;padding:10px 15px;border-radius:12px;min-height:42px;font-weight:700;cursor:pointer;box-shadow:0 10px 20px rgba(36,96,242,.24);transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 14px 24px rgba(36,96,242,.28)}.btn:disabled{opacity:.65;cursor:not-allowed;box-shadow:none}.btn-secondary{background:#fff;color:var(--text-soft);border:1px solid var(--border-strong);box-shadow:none}.btn-secondary:hover{transform:translateY(-1px);background:#edf3ff;color:#1b3f88}.btn-danger{background:linear-gradient(135deg,#d9536f,#c13f5a);border-color:#a9334a;box-shadow:0 10px 20px rgba(201,63,90,.22)}.btn-danger:hover{box-shadow:0 14px 24px rgba(201,63,90,.28)}.logout-link,.theme-toggle{font-size:13px;padding:8px 12px}.theme-toggle{display:inline-flex;align-items:center;gap:6px}.theme-toggle-icon{width:20px;height:20px;border-radius:999px;display:grid;place-items:center;font-size:12px;background:var(--accent-soft);color:var(--accent-strong)}.lang-switch{display:inline-flex;gap:8px;align-items:center}.lang-switch button{background:#fff;border:1px solid var(--border);color:var(--muted);padding:6px 10px;border-radius:10px;min-height:40px;cursor:pointer;transition:all .18s ease}.lang-switch button.active{color:#20479a;border-color:#b7ccff;background:var(--accent-soft)}.alert{margin-top:12px;color:var(--danger);font-size:14px;background:var(--danger-soft);border:1px solid #f0bfcb;border-radius:12px;padding:10px 12px}.alert-success{color:var(--success);background:var(--success-soft);border-color:#b9e8d5}.muted{color:var(--muted)}.stack{display:flex;flex-direction:column;gap:16px}.page-head{justify-content:space-between;align-items:center;gap:12px}.page-head,.toolbar{display:flex;flex-wrap:wrap;margin-bottom:8px}.toolbar{align-items:flex-start;gap:10px}.toolbar .field{margin-bottom:0}.toolbar-field{min-width:170px;flex:1 1 220px}.toolbar-field input,.toolbar-field select{width:100%}.toolbar-actions{display:inline-flex;align-items:flex-end;align-self:flex-end;gap:8px;flex-wrap:wrap}.stack input,.stack select,.stack textarea,.toolbar input,.toolbar select{background:#f7faff;border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:12px;text-align:start;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.stack input:focus,.stack select:focus,.stack textarea:focus,.toolbar input:focus,.toolbar select:focus{outline:none;border-color:#9ab5ff;background:#fff;box-shadow:0 0 0 3px rgba(151,178,255,.24)}.stack input:disabled,.stack select:disabled,.stack textarea:disabled{opacity:.75;cursor:not-allowed}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.actions{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.actions a:not(.btn),.actions button:not(.btn){background:#fff;border:1px solid var(--border-strong);color:var(--text-soft);border-radius:10px;padding:6px 10px;min-height:40px;cursor:pointer;transition:all .18s ease}.actions a:not(.btn):hover,.actions button:not(.btn):hover{background:#edf3ff;border-color:#bfd1ff;color:#1b3f88}.table-wrap{overflow:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:14px;background:#fff}.table{width:100%;border-collapse:collapse;min-width:760px}.table td,.table th{padding:11px 12px;border-bottom:1px solid var(--border);text-align:start;vertical-align:top}.table th{color:var(--muted);font-weight:700;font-size:12px;letter-spacing:.02em;text-transform:uppercase;background:#f4f8ff;position:-webkit-sticky;position:sticky;top:0;z-index:1}.badge,.table tbody tr:hover{background:#f8fbff}.badge{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;padding:3px 10px;font-size:12px;font-weight:700}.badge.success{border-color:#93dac2;color:var(--success);background:var(--success-soft)}.badge.danger{border-color:#f3b6c5;color:var(--danger);background:var(--danger-soft)}.badge.warning{border-color:#f0d38b;color:#8a5a00;background:#fff5d9}.badge.info{border-color:#b7ccff;color:#20479a;background:#edf3ff}.badge.muted{border-color:#d5dce8;color:#5f6f90;background:#f3f6fb}.table-sort{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:inherit;font:inherit;font-weight:inherit;padding:0;cursor:pointer}.table-sort:hover{color:var(--accent-strong)}.pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px}.check{display:inline-flex;align-items:center;gap:8px}.permission-check{justify-content:center}.permission-matrix .table td,.permission-matrix .table th{text-align:center;vertical-align:middle;min-width:88px}.permission-matrix .table td:first-child,.permission-matrix .table th:first-child{text-align:start;min-width:220px}.secret-field{display:flex;gap:8px;align-items:center}.secret-field input{flex:1 1}.input-suffix-field{display:flex;align-items:center;gap:8px}.input-suffix-field input{flex:1 1}.input-suffix{min-width:42px;min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border-radius:12px;background:#eef4ff;color:var(--text-soft);font-weight:700}.input-suffix,.provider-guide{border:1px solid var(--border)}.provider-guide{border-radius:12px;padding:12px;background:linear-gradient(180deg,#f6f9ff,#eef4ff)}.provider-guide strong{display:block;margin-bottom:6px;color:var(--text)}.provider-guide p{margin:0}.form-grid-help .field,.provider-settings-grid .field{background:#f8fbff;border:1px solid var(--border);border-radius:12px;padding:10px}.provider-active{min-height:42px;display:flex;align-items:center}.provider-code-cell{max-width:220px}.provider-code{display:inline-block;max-width:100%;direction:ltr;unicode-bidi:plaintext;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:top;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.log-json-button{all:unset;cursor:pointer;color:var(--accent-strong);text-decoration:underline;word-break:break-word}.modal-backdrop{position:fixed;inset:0;background:rgba(17,39,84,.34);display:grid;place-items:center;z-index:2000;padding:20px}.modal-panel{width:min(980px,100%);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 24px 70px rgba(24,56,120,.22)}.modal-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:8px 14px;gap:8px 14px;margin-bottom:12px;color:var(--muted);font-size:13px}.mono-block{margin:0;background:#f7faff;border:1px solid var(--border);border-radius:12px;padding:12px;overflow:auto;max-height:56vh;white-space:pre;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;line-height:1.45}@keyframes card-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1080px){.layout{display:block;padding:12px}.sidebar-overlay{position:fixed;inset:0;z-index:2040;border:0;padding:0;background:rgba(11,24,50,.44);opacity:0;pointer-events:none;transition:opacity .22s ease}.sidebar-overlay.visible{display:block;opacity:1;pointer-events:auto}.sidebar-drawer{position:fixed;inset-block:0;inset-inline-start:0;width:min(86vw,320px);min-width:0;max-height:none;border-radius:0 24px 24px 0;z-index:2050;transform:translateX(var(--sidebar-hidden-shift));transition:transform .24s ease;overflow:auto}html[dir=rtl] .sidebar-drawer{border-radius:24px 0 0 24px}.sidebar-drawer.open{transform:translateX(0)}.sidebar-mobile-head{display:flex}.mobile-menu-button{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;flex:0 0 44px;border-radius:12px;border:1px solid var(--border-strong);background:#fff;color:var(--text-soft);cursor:pointer}.hamburger-lines{display:inline-flex;flex-direction:column;gap:4px}.hamburger-lines span{display:block;width:18px;height:2px;border-radius:999px;background:currentColor}.topbar{position:-webkit-sticky;position:sticky;top:12px;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand-copy strong{font-size:18px}.auth-shell,.form-grid{grid-template-columns:1fr}.auth-hero{padding:24px}.auth-controls{top:16px;inset-inline-end:16px}}@media (max-width:780px){.topbar{flex-direction:column;align-items:stretch}.topbar-primary{width:100%;align-items:center}.topbar-heading h1{font-size:18px}.topbar-actions{justify-content:stretch;width:100%}.topbar-actions>*{flex:1 1 140px}.modal-meta{grid-template-columns:1fr}.toolbar{gap:12px}.toolbar-actions,.toolbar-field{width:100%;min-width:0}.toolbar-actions{align-self:stretch}.toolbar-actions .btn,.toolbar-actions a{flex:1 1 160px;text-align:center}.card{padding:14px;border-radius:16px}.table{min-width:640px}.table td,.table th{padding:10px}.page-head .actions,.page-head>.btn,.page-head>a.btn{width:100%}.page-head .actions>*,.page-head>.btn,.page-head>a.btn{flex:1 1 140px;text-align:center}.actions{width:100%}.modal-backdrop{padding:10px}.modal-panel{max-height:92vh;padding:12px;border-radius:14px}.mono-block{white-space:pre-wrap;word-break:break-word}}@media (max-width:560px){.layout{padding:10px}.topbar{padding:12px;border-radius:16px}.topbar-heading p{font-size:12px;line-height:1.6}.sidebar-drawer{width:min(92vw,320px);padding:16px 12px 24px}.auth-controls{position:static;justify-content:center;margin-bottom:12px}.brand{gap:10px}.brand-copy small{font-size:11px}.actions a:not(.btn),.actions button:not(.btn),.btn,.btn-secondary{min-height:44px}.table{min-width:580px}}html[data-theme=dark]{color-scheme:dark;--bg:#0d1529;--bg-soft:#121e38;--surface:#122040;--panel:#122040;--muted:#95a8cf;--text:#e7eefc;--text-soft:#cfd9f2;--accent:#5f8cff;--accent-strong:#4b79f0;--accent-soft:#1d2d56;--success:#41d29b;--success-soft:#16372c;--danger:#f07b97;--danger-soft:#3d1f2b;--border:#2a3f69;--border-strong:#355080;--ring:#6f97ff;--shadow-soft:0 12px 30px rgba(4,10,26,.4);--shadow-card:0 18px 42px rgba(4,10,26,.44)}html[data-theme=dark] body{background:radial-gradient(circle at 8% -8%,rgba(79,121,240,.22) 0,rgba(79,121,240,0) 35%),radial-gradient(circle at 95% 0,rgba(126,98,255,.2) 0,rgba(126,98,255,0) 38%),linear-gradient(180deg,#0e1a34,#0a1224);color:var(--text)}html[data-theme=dark] .sidebar{background:linear-gradient(180deg,rgba(20,32,61,.96),rgba(16,26,50,.96))}html[data-theme=dark] .mobile-menu-button,html[data-theme=dark] .sidebar-close{background:#15284f;color:#d5e1ff}html[data-theme=dark] .nav-group-chevron,html[data-theme=dark] .nav-key{color:#aac1ee;background:#1b2c54;border-color:#2f4a7b}html[data-theme=dark] .nav-section+.nav-section{border-top-color:rgba(53,80,128,.85)}html[data-theme=dark] .nav-subnav{border-inline-start-color:#2f4a7b}html[data-theme=dark] .nav-group-toggle:hover,html[data-theme=dark] .nav-link:hover{background:#182a52;border-color:#29477b;color:#dbe6ff}html[data-theme=dark] .nav-group-toggle.active,html[data-theme=dark] .nav-link.active{background:linear-gradient(90deg,#203767,#1c325f);border-color:#3a5d98;color:#e7eeff}html[data-theme=dark] .auth-card,html[data-theme=dark] .card,html[data-theme=dark] .topbar{background:linear-gradient(180deg,rgba(22,36,69,.98),rgba(17,29,57,.98))}html[data-theme=dark] .auth-hero{background:linear-gradient(180deg,rgba(22,36,69,.94),rgba(17,29,57,.9))}html[data-theme=dark] .actions a:not(.btn),html[data-theme=dark] .actions button:not(.btn),html[data-theme=dark] .btn-secondary,html[data-theme=dark] .lang-switch button{background:#15284f;color:#d5e1ff}html[data-theme=dark] .lang-switch button.active{color:#dbe7ff;border-color:#4a72b9;background:#203a70}html[data-theme=dark] .field input,html[data-theme=dark] .stack input,html[data-theme=dark] .stack select,html[data-theme=dark] .stack textarea,html[data-theme=dark] .toolbar input,html[data-theme=dark] .toolbar select{background:#102141;color:#e5edff}html[data-theme=dark] .stack input:focus,html[data-theme=dark] .stack select:focus,html[data-theme=dark] .stack textarea:focus,html[data-theme=dark] .toolbar input:focus,html[data-theme=dark] .toolbar select:focus{background:#13274d;border-color:#5f89df;box-shadow:0 0 0 3px rgba(95,140,255,.24)}html[data-theme=dark] .modal-panel,html[data-theme=dark] .table-wrap{background:#122142}html[data-theme=dark] .table th{background:#162a50}html[data-theme=dark] .table tbody tr:hover{background:#15264b}html[data-theme=dark] .badge{background:#152847}html[data-theme=dark] .provider-guide{background:linear-gradient(180deg,#182d58,#13264a)}html[data-theme=dark] .form-grid-help .field,html[data-theme=dark] .mono-block,html[data-theme=dark] .provider-settings-grid .field{background:#122346}html[data-theme=dark] .input-suffix{background:#15284f}html[data-theme=dark] .modal-backdrop{background:rgba(5,10,24,.66)}html[data-theme=dark] .theme-toggle-icon{background:#27427b;color:#f2f6ff}.dash{display:flex;flex-direction:column;gap:18px;width:100%;max-width:1500px;margin-inline:auto}.dash-alert{background:var(--danger-soft);color:var(--danger);border:1px solid var(--border);border-radius:14px;padding:10px 14px;font-size:.9rem;font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:16px;gap:16px}.kpi-card{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:18px;box-shadow:var(--shadow-soft);transition:transform .22s ease,box-shadow .22s ease}.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}.kpi-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;flex-shrink:0;background:var(--accent-soft);color:var(--accent)}.kpi-violet .kpi-icon{background:rgba(102,84,240,.12);color:#6654f0}.kpi-success .kpi-icon{background:var(--success-soft);color:var(--success)}.kpi-teal .kpi-icon{background:rgba(11,181,201,.12);color:#0b96a8}.kpi-amber .kpi-icon{background:rgba(224,145,58,.14);color:#c9792a}.kpi-body{min-width:0}.kpi-label{margin:0 0 4px;font-size:.82rem;font-weight:600;color:var(--muted)}.kpi-value{margin:0;font-size:1.55rem;font-weight:800;color:var(--text);line-height:1.1}.attn-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.attn-tile{position:relative;display:flex;flex-direction:column;gap:4px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:16px 18px;box-shadow:var(--shadow-soft);transition:transform .2s ease,border-color .2s ease}.attn-tile:hover{transform:translateY(-2px);border-color:var(--border-strong)}.attn-dot{width:10px;height:10px;border-radius:50%}.attn-warning .attn-dot{background:#e0913a}.attn-danger .attn-dot{background:var(--danger)}.attn-value{font-size:1.5rem;font-weight:800;color:var(--text)}.attn-label{font-size:.82rem;font-weight:600;color:var(--muted)}.dash-row{display:grid;grid-gap:16px;gap:16px}.dash-row-2{grid-template-columns:1fr 1fr}.dash-row-32{grid-template-columns:2fr 1fr}.panel{background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:20px;box-shadow:var(--shadow-soft)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-head h3{margin:0;font-size:1.02rem;font-weight:800;color:var(--text)}.panel-link{font-size:.85rem;font-weight:700;color:var(--accent)}.panel-link:hover{color:var(--accent-strong)}.panel-tag{font-size:.66rem;font-weight:800;letter-spacing:.05em;color:var(--muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:8px;padding:2px 7px}.panel-loading{display:flex;flex-direction:column;gap:10px;align-items:center;padding:8px 0}.dash-empty{text-align:center;color:var(--muted);font-size:.9rem;padding:24px 0}.trend-placeholder{display:flex;flex-direction:column;gap:10px}.trend-placeholder svg{width:100%;height:120px}.trend-base{stroke:var(--border-strong);stroke-width:1.5;stroke-dasharray:4 5}.trend-ghost{fill:none;stroke:var(--border-strong);stroke-width:2.5;stroke-dasharray:5 6;opacity:.65}.trend-note{margin:0;text-align:center;color:var(--muted);font-size:.82rem}.donut-wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.donut{width:150px;height:150px;flex-shrink:0}.donut-track{fill:none;stroke:var(--border);stroke-width:22}.donut-center-top{text-anchor:middle;font-size:16px;font-weight:800;fill:var(--text)}.donut-center-sub{text-anchor:middle;font-size:9px;font-weight:600;fill:var(--muted)}.donut-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;flex:1 1;min-width:160px}.donut-legend li{display:flex;align-items:center;gap:8px;font-size:.86rem}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-label{color:var(--text-soft);flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-value{color:var(--muted);font-weight:700}.table-scroll{overflow-x:auto}.dash-table{width:100%;border-collapse:collapse;font-size:.88rem}.dash-table th{text-align:start;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);padding:0 10px 10px}.dash-table td,.dash-table th{border-bottom:1px solid var(--border);white-space:nowrap}.dash-table td{padding:11px 10px;color:var(--text-soft)}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr:hover td{background:var(--bg-soft)}.dash-table .ta-end{text-align:end}.st-badge{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:800;letter-spacing:.02em}.st-ok{background:var(--success-soft);color:var(--success)}.st-warn{background:rgba(224,145,58,.14);color:#c9792a}.st-bad{background:var(--danger-soft);color:var(--danger)}.bar-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.bar-row{display:grid;grid-template-columns:1fr;grid-gap:6px;gap:6px}.bar-label{font-size:.86rem;font-weight:700;color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{height:9px;border-radius:50px;background:var(--bg-soft);overflow:hidden}.bar-fill{display:block;height:100%;border-radius:50px;min-width:6px;transition:width .4s ease}.bar-value{font-size:.8rem;font-weight:700;color:var(--muted)}.skeleton{display:block;border-radius:8px;background:linear-gradient(90deg,var(--bg-soft) 25%,var(--border) 50%,var(--bg-soft) 75%);background-size:200% 100%;animation:dash-shimmer 1.3s ease-in-out infinite}.skeleton-value{width:70%;height:22px}.skeleton-sm{width:48px;height:22px}.skeleton-row{width:100%;height:16px;margin:4px 0}.skeleton-donut{width:130px;height:130px;border-radius:50%}@keyframes dash-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}html[data-theme=dark] .attn-tile,html[data-theme=dark] .kpi-card,html[data-theme=dark] .panel{background:linear-gradient(180deg,rgba(22,36,69,.98),rgba(17,29,57,.98))}@media (max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:980px){.dash-row-2,.dash-row-32{grid-template-columns:1fr}.attn-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:420px){.attn-grid,.kpi-grid{grid-template-columns:1fr}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--text-soft);transition:background .2s ease,border-color .2s ease,color .2s ease}.icon-btn:hover{color:var(--accent);border-color:var(--border-strong)}.user-menu{position:relative}.avatar-btn{display:inline-flex;align-items:center;gap:9px;padding:5px 12px 5px 6px;border-radius:50px;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.avatar-btn:hover{border-color:var(--border-strong);box-shadow:var(--shadow-soft)}.avatar-circle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0,#6654f0 100%);color:#fff;font-size:.8rem;font-weight:800;flex-shrink:0}.avatar-name{font-size:.86rem;font-weight:700;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-chevron{color:var(--muted);font-size:.7rem}.user-menu-backdrop{position:fixed;inset:0;z-index:60;background:transparent;border:0;cursor:default}.user-menu-pop{position:absolute;inset-block-start:calc(100% + 8px);inset-inline-end:0;z-index:70;min-width:200px;display:flex;flex-direction:column;padding:8px;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-card)}.user-menu-item{display:block;padding:10px 12px;border-radius:10px;font-size:.88rem;font-weight:600;color:var(--text-soft);transition:background .18s ease,color .18s ease}.user-menu-item:hover{background:var(--bg-soft);color:var(--accent)}.user-menu-sep{height:1px;background:var(--border);margin:6px 4px}.user-menu-danger{color:var(--danger)}.user-menu-danger:hover{background:var(--danger-soft);color:var(--danger)}@media (max-width:560px){.avatar-name{display:none}}html[data-theme=dark] .avatar-btn,html[data-theme=dark] .icon-btn{background:#15284f;color:#d5e1ff}