:root{--c-primary:#0f6e56;--c-primary-dark:#085041;--c-primary-darker:#0a1f17;--c-primary-light:#5dcaa5;--c-primary-soft:#e8f5ef;--c-primary-softer:#f4faf7;--c-bg:#f7f8f7;--c-surface:#fff;--c-surface-2:#f2f4f2;--c-surface-3:#e9ebe9;--c-text:#04342c;--c-text-2:#5f5e5a;--c-text-3:#8e8d88;--c-text-inv:#fff;--c-border:#0f6e5614;--c-border-2:#0f6e5626;--c-border-3:#0f6e5640;--c-success:#2d7a3a;--c-success-bg:#ecfdf3;--c-warning:#9a6400;--c-warning-bg:#fff8e1;--c-danger:#a32d2d;--c-danger-bg:#fef2f2;--c-info:#1565a5;--c-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-full:9999px;--shadow-sm:0 1px 2px #04342c0a;--shadow:0 1px 3px #04342c0a, 0 4px 12px #04342c0a;--shadow-lg:0 8px 30px #04342c14;--shadow-xl:0 16px 48px #04342c1f;--sidebar-w:256px;--topbar-h:56px;--ease:cubic-bezier(.4, 0, .2, 1);--dur:.15s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:14px}body{background:var(--c-bg);color:var(--c-text);min-height:100vh;font-family:IBM Plex Sans Arabic,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}img,svg{max-width:100%;display:block}button{font-family:inherit}.t-h1{letter-spacing:-.02em;font-size:24px;font-weight:600;line-height:1.3}.t-h2{letter-spacing:-.01em;font-size:20px;font-weight:600;line-height:1.3}.t-h3{font-size:17px;font-weight:600;line-height:1.4}.t-h4{font-size:15px;font-weight:600;line-height:1.4}.t-body{font-size:14px;line-height:1.6}.t-small{font-size:13px;line-height:1.5}.t-xs{font-size:12px;line-height:1.5}.t-caption{letter-spacing:.3px;font-size:11px;line-height:1.4}.t-muted{color:var(--c-text-2)}.t-faint{color:var(--c-text-3)}.t-mono{direction:ltr;font-family:IBM Plex Mono,monospace}.t-tabular{font-variant-numeric:tabular-nums}.t-truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.app-shell{min-height:100vh;display:none}.app-shell.ready{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar""sidebar main";display:grid}.sidebar{background:var(--c-surface);border-left:1px solid var(--c-border);z-index:20;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:var(--c-text-3) transparent;flex-direction:column;grid-area:sidebar;height:100vh;display:flex;position:relative;top:0;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:var(--c-border-2);background-clip:padding-box;border:2px solid #0000;border-radius:4px;min-height:36px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--c-text-3);background-clip:padding-box;border:2px solid #0000}.sidebar:after{content:"";background:linear-gradient(to top, var(--c-surface) 0%, transparent 100%);pointer-events:none;z-index:1;height:32px;margin-top:-32px;display:block;position:sticky;bottom:0}.sidebar-header{border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:12px;padding:16px 18px;display:flex}.sidebar-logo{background:var(--c-primary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.sidebar-logo svg{width:19px;height:19px}.sidebar-brand{letter-spacing:-.01em;font-size:17px;font-weight:600}.sidebar-portal{color:var(--c-text-3);margin-top:1px;font-size:11px;font-weight:400;display:block}.sidebar-nav{flex:1;padding:12px 10px}.nav-group{margin-bottom:20px}.nav-group-label{color:var(--c-text-3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;padding:0 12px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--r-sm);color:var(--c-text-2);cursor:pointer;transition:all var(--dur) var(--ease);align-items:center;gap:10px;margin-bottom:1px;padding:8px 12px;font-size:13.5px;display:flex;position:relative}.nav-item:hover{background:var(--c-surface-2);color:var(--c-text)}.nav-item.active{background:var(--c-primary-soft);color:var(--c-primary);font-weight:500}.nav-item.active:after{content:"";background:var(--c-primary);border-radius:2px;width:3px;position:absolute;top:6px;bottom:6px;right:-10px}.nav-item svg{stroke-width:1.75px;fill:none;stroke:currentColor;flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid var(--c-border);flex-shrink:0;padding:12px 14px}.user-card{transition:background var(--dur) var(--ease);border-radius:8px;align-items:center;gap:10px;padding:8px;display:flex}.user-card:hover{background:var(--c-surface-2)}.user-avatar{background:var(--c-primary);width:32px;height:32px;color:var(--c-text-inv);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.user-role{color:var(--c-text-3);font-size:11px}.logout-btn{width:28px;height:28px;color:var(--c-text-3);border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur) var(--ease);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.logout-btn:hover{background:var(--c-danger-bg);color:var(--c-danger)}.logout-btn svg{stroke-width:1.75px;fill:none;stroke:currentColor;width:15px;height:15px}.sidebar-overlay{z-index:19;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000040;display:none;position:fixed;inset:0}.sidebar-overlay.show{display:block}.topbar{background:var(--c-surface);border-bottom:1px solid var(--c-border);padding:0 var(--sp-6);align-items:center;gap:var(--sp-3);grid-area:topbar;display:flex}.topbar-toggle{width:34px;height:34px;color:var(--c-text);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:none}.topbar-toggle svg{stroke-width:2px;fill:none;stroke:currentColor;width:20px;height:20px}.topbar-title{flex:1;font-size:15px;font-weight:500}.topbar-date{color:var(--c-text-3);font-variant-numeric:tabular-nums;font-size:13px}.main{padding:var(--sp-6) var(--sp-8);grid-area:main;max-width:1400px;overflow-y:auto}.page-header{margin-bottom:var(--sp-6)}.page-title{letter-spacing:-.02em;margin-bottom:2px;font-size:24px;font-weight:600}.page-desc{color:var(--c-text-2);font-size:14px}.page-actions{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-5);display:flex}.btn{border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-family:inherit;font-size:13.5px;font-weight:500;line-height:1;display:inline-flex}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{stroke-width:2px;fill:none;stroke:currentColor;width:16px;height:16px}.btn-primary{background:var(--c-primary);color:var(--c-text-inv)}.btn-primary:hover:not(:disabled){background:var(--c-primary-dark)}.btn-ghost{color:var(--c-text-2);border:1px solid var(--c-border-2);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--c-surface-2);color:var(--c-text)}.btn-danger{background:var(--c-danger);color:var(--c-text-inv)}.btn-danger:hover:not(:disabled){background:#8b2626}.btn-soft{background:var(--c-primary-soft);color:var(--c-primary)}.btn-soft:hover:not(:disabled){background:var(--c-primary-soft);filter:brightness(.96)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:12px 22px;font-size:15px}.btn-icon{padding:8px}.btn-icon.btn-sm{padding:6px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);padding:var(--sp-5)}.card-header{margin-bottom:var(--sp-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:15px;font-weight:600}.kpi-grid{gap:var(--sp-3);grid-template-columns:repeat(auto-fit,minmax(195px,1fr));display:grid}.kpi{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);transition:all .18s var(--ease);color:inherit;flex-direction:column;gap:12px;padding:16px 18px;display:flex}.kpi:hover{border-color:var(--c-border-2);box-shadow:var(--shadow);transform:translateY(-1px)}.kpi-icon{background:var(--c-primary-softer);width:36px;height:36px;color:var(--c-primary);border-radius:9px;justify-content:center;align-items:center;display:flex}.kpi-icon svg{stroke-width:1.75px;fill:none;stroke:currentColor;width:18px;height:18px}.kpi-value{font-variant-numeric:tabular-nums;font-size:28px;font-weight:600;line-height:1}.kpi-label{color:var(--c-text-2);font-size:13px;font-weight:500}.kpi-badge{color:var(--c-text-3);align-items:center;gap:5px;font-size:11px;display:flex}.kpi-dot{background:var(--c-text-3);border-radius:50%;width:6px;height:6px}.kpi-badge.ok .kpi-dot{background:var(--c-success)}.kpi-badge.warn .kpi-dot{background:var(--c-warning)}.kpi-badge.bad .kpi-dot{background:var(--c-danger)}.field{margin-bottom:var(--sp-4)}.field-label{color:var(--c-text);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.field-label .required{color:var(--c-danger);margin-right:2px}.field-hint{color:var(--c-text-3);margin-top:4px;font-size:12px}.input{border:1.5px solid var(--c-border-2);border-radius:var(--r-sm);background:var(--c-surface);width:100%;color:var(--c-text);transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);padding:10px 14px;font-family:inherit;font-size:14px}.input::placeholder{color:var(--c-text-3)}.input:focus{border-color:var(--c-primary);outline:none;box-shadow:0 0 0 3px #0f6e5614}.input:disabled{opacity:.5;cursor:not-allowed;background:var(--c-surface-2)}.input.error{border-color:var(--c-danger)}.input.error:focus{box-shadow:0 0 0 3px #a32d2d14}.input-login{padding:13px 16px;font-size:16px}textarea.input{resize:vertical;min-height:80px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238E8D88' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;padding-left:32px}.checkbox-group,.radio-group{gap:var(--sp-2);flex-direction:column;display:flex}.table-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);overflow:hidden}.table-toolbar{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;gap:var(--sp-2);display:flex}table{border-collapse:collapse;width:100%}th{text-align:right;color:var(--c-text-3);letter-spacing:.5px;text-transform:uppercase;background:var(--c-surface-2);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--c-border);vertical-align:middle;padding:10px 16px;font-size:13.5px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--c-primary-softer)}.badge{border-radius:var(--r-full);align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:500;line-height:1;display:inline-flex}.badge-success{background:var(--c-success-bg);color:var(--c-success)}.badge-warning{background:var(--c-warning-bg);color:var(--c-warning)}.badge-danger{background:var(--c-danger-bg);color:var(--c-danger)}.badge-info{background:var(--c-info-bg);color:var(--c-info)}.badge-neutral{background:var(--c-surface-2);color:var(--c-text-2)}.tag{border-radius:var(--r-sm);background:var(--c-surface-2);color:var(--c-text-2);border:1px solid var(--c-border);align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:inline-flex}.alert{border-radius:var(--r-sm);border-right:3px solid;align-items:flex-start;gap:10px;padding:12px 16px;font-size:13px;line-height:1.6;display:flex}.alert svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.alert-success{background:var(--c-success-bg);border-color:var(--c-success);color:#1a5c2a}.alert-warning{background:var(--c-warning-bg);border-color:var(--c-warning);color:#7a5000}.alert-danger{background:var(--c-danger-bg);border-color:var(--c-danger);color:#8b2626}.alert-info{background:var(--c-info-bg);border-color:var(--c-info);color:#104580}.banner{border-radius:var(--r-sm);padding:10px 14px;font-size:13px;line-height:1.6;display:none}.banner.show{justify-content:space-between;align-items:center;gap:12px;display:flex}.banner-info{color:var(--c-primary-dark);background:#0f6e560d;border:1px solid #0f6e562e}.banner-error{background:var(--c-danger-bg);color:var(--c-danger);border:1px solid #fecaca}.empty-state{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:var(--sp-12) var(--sp-8);text-align:center}.empty-icon{width:52px;height:52px;margin:0 auto var(--sp-4);background:var(--c-primary-softer);color:var(--c-primary);border-radius:12px;justify-content:center;align-items:center;display:flex}.empty-icon svg{stroke-width:1.5px;fill:none;stroke:currentColor;width:26px;height:26px}.empty-title{margin-bottom:6px;font-size:17px;font-weight:600}.empty-desc{color:var(--c-text-2);margin-bottom:var(--sp-5);max-width:400px;margin-left:auto;margin-right:auto;font-size:14px;line-height:1.7}.skeleton{background:linear-gradient(90deg, var(--c-surface-2) 25%, var(--c-bg) 50%, var(--c-surface-2) 75%);background-size:200% 100%;border-radius:4px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{border:2px solid var(--c-border-2);border-top-color:var(--c-primary);border-radius:50%;width:18px;height:18px;animation:.65s linear infinite spin}.spinner-white{border-color:#fff #ffffff4d #ffffff4d}.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;padding:var(--sp-6);opacity:0;pointer-events:none;transition:opacity .2s var(--ease);background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;transition:transform .2s var(--ease);overflow-y:auto;transform:translateY(10px)}.modal-backdrop.open .modal{transform:translateY(0)}.modal-header{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:17px;font-weight:600}.modal-close{width:28px;height:28px;color:var(--c-text-3);border-radius:var(--r-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--c-surface-2)}.modal-body{padding:var(--sp-5) var(--sp-6)}.modal-footer{justify-content:flex-start;gap:var(--sp-2);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--c-border);display:flex}.tabs{border-bottom:2px solid var(--c-border);margin-bottom:var(--sp-5);gap:0;display:flex}.tab{color:var(--c-text-3);cursor:pointer;transition:color var(--dur) var(--ease);background:0 0;border:none;padding:10px 18px;font-size:13.5px;font-weight:500;position:relative}.tab:hover{color:var(--c-text)}.tab.active{color:var(--c-primary)}.tab.active:after{content:"";background:var(--c-primary);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-2px;left:0;right:0}.pagination{justify-content:center;align-items:center;gap:var(--sp-1);padding:var(--sp-4) 0;display:flex}.pagination-btn{border:1px solid var(--c-border);background:var(--c-surface);border-radius:var(--r-sm);cursor:pointer;width:32px;height:32px;color:var(--c-text-2);transition:all var(--dur) var(--ease);justify-content:center;align-items:center;font-family:inherit;font-size:13px;display:flex}.pagination-btn:hover{background:var(--c-surface-2)}.pagination-btn.active{background:var(--c-primary);color:var(--c-text-inv);border-color:var(--c-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-5{gap:var(--sp-5)}.gap-6{gap:var(--sp-6)}.grid{display:grid}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.mb-5{margin-bottom:var(--sp-5)}.mb-6{margin-bottom:var(--sp-6)}.mb-8{margin-bottom:var(--sp-8)}.mt-2{margin-top:var(--sp-2)}.mt-4{margin-top:var(--sp-4)}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}.app-loading-screen{background:var(--c-bg);z-index:9999;transition:opacity .3s var(--ease);flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:fixed;inset:0}.app-loading-screen.hidden{opacity:0;pointer-events:none}.auth-error-screen{background:var(--c-bg);z-index:9998;padding:var(--sp-6);justify-content:center;align-items:center;display:none;position:fixed;inset:0}.auth-error-screen.show{display:flex}.auth-error-card{background:var(--c-surface);border:1px solid var(--c-border-2);border-radius:var(--r-lg);padding:var(--sp-10);text-align:center;max-width:420px;box-shadow:var(--shadow)}.auth-error-card .error-icon{background:var(--c-danger-bg);width:52px;height:52px;color:var(--c-danger);margin:0 auto var(--sp-4);border-radius:12px;justify-content:center;align-items:center;display:flex}.auth-error-card .error-icon svg{width:26px;height:26px}.auth-error-card .error-detail{background:var(--c-surface-2);border-radius:var(--r-sm);color:var(--c-text-3);margin-bottom:var(--sp-5);word-break:break-all;direction:ltr;padding:8px 12px;font-family:monospace;font-size:12px;display:none}.auth-error-card .error-detail.show{display:block}.login-layout{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-brand{background:linear-gradient(155deg, var(--c-primary-darker) 0%, var(--c-primary) 55%, var(--c-primary-dark) 100%);color:var(--c-text-inv);flex-direction:column;padding:64px 72px;display:flex;position:relative;overflow:hidden}.login-brand:before{content:"";pointer-events:none;background:radial-gradient(600px 400px at 75% 15%,#5dcaa51f 0%,#0000 100%),radial-gradient(500px 500px at 15% 85%,#5dcaa50f 0%,#0000 100%);position:absolute;inset:0}.login-brand>*{z-index:1;position:relative}.login-brand-logo{align-items:center;gap:12px;display:flex}.login-brand-hero{flex-direction:column;flex:1;justify-content:center;max-width:480px;display:flex}.login-brand h1{letter-spacing:-.02em;white-space:nowrap;margin-bottom:20px;font-size:36px;font-weight:600;line-height:1.3}.login-brand .tagline{opacity:.7;max-width:440px;font-size:15px;font-weight:300;line-height:1.8}.login-brand .footer{opacity:.4;letter-spacing:.02em;font-size:12px}.login-form-side{background:var(--c-surface);flex-direction:column;justify-content:center;padding:64px 48px;display:flex}.login-form-box{width:100%;max-width:400px;margin:0 auto}.login-form-box h2{letter-spacing:-.01em;margin-bottom:8px;font-size:26px;font-weight:600}.login-form-box .subtitle{color:var(--c-text-2);margin-bottom:var(--sp-8);font-size:14px;line-height:1.6}.login-submit{width:100%;margin-top:var(--sp-4);background:var(--c-primary);color:var(--c-text-inv);border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur) var(--ease);border:none;justify-content:center;align-items:center;gap:10px;padding:14px;font-family:inherit;font-size:15px;font-weight:600;display:flex}.login-submit:hover:not(:disabled){background:var(--c-primary-dark)}.login-submit:active:not(:disabled){transform:scale(.99)}.login-submit:disabled{cursor:not-allowed;background:#9bb8b0}.login-submit.loading .btn-text{display:none}.login-submit.loading .spinner{display:block}.login-submit .spinner{display:none}.login-note{margin-top:var(--sp-6);text-align:center;color:var(--c-text-3);font-size:12.5px;line-height:1.6}@media (max-width:1280px){.login-brand{padding:56px}.login-brand h1{font-size:32px}.login-form-side{padding:56px 40px}}@media (max-width:1024px){.app-shell.ready{grid-template-columns:1fr;grid-template-areas:"topbar""main"}.sidebar{width:280px;transition:transform .22s var(--ease);box-shadow:var(--shadow-lg);z-index:21;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.sidebar.open{transform:translate(0)}.topbar-toggle{display:flex}.main{padding:var(--sp-5)}.login-brand{padding:48px 44px}.login-brand h1{white-space:normal;font-size:28px}.login-brand .tagline{font-size:14.5px}.login-form-side{padding:48px 32px}.login-form-box h2{font-size:24px}}@media (max-width:900px){.login-layout{grid-template-columns:1fr;min-height:100vh}.login-brand{gap:24px;min-height:auto;padding:36px 32px}.login-brand-hero{justify-content:flex-start;max-width:100%}.login-brand h1{white-space:normal;margin-bottom:12px;font-size:26px;line-height:1.35}.login-brand .tagline{max-width:100%;font-size:14px;line-height:1.7}.login-brand .footer{display:none}.login-form-side{padding:40px 28px 60px}.login-form-box{max-width:100%}.login-form-box h2{font-size:22px}}@media (max-width:640px){.topbar{padding:0 var(--sp-4)}.topbar-date{display:none}.page-title{font-size:20px}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.grid-2,.grid-3{grid-template-columns:1fr}.modal{margin:var(--sp-4)}.login-brand{gap:20px;padding:32px 24px}.login-brand-logo span{font-size:19px!important}.login-brand h1{margin-bottom:10px;font-size:24px}.login-brand .tagline{font-size:13.5px}.login-form-side{padding:32px 20px 48px}.login-form-box h2{font-size:21px}.login-form-box .subtitle{margin-bottom:var(--sp-6);font-size:13.5px}}@media (max-width:400px){.kpi-grid{grid-template-columns:1fr}.login-brand{padding:28px 20px}.login-brand h1{font-size:22px}.login-form-side{padding:28px 16px 40px}}@media (max-height:500px) and (max-width:900px){.login-brand{min-height:auto;padding:20px 24px}.login-brand h1{margin-bottom:6px;font-size:20px}.login-brand .tagline{font-size:12.5px;line-height:1.5}.login-form-side{padding:24px 24px 32px}}.auth-forgot-link{color:var(--c-primary);transition:color var(--dur) var(--ease);margin-top:8px;font-size:12.5px;font-weight:500;text-decoration:none;display:inline-block}.auth-forgot-link:hover{color:var(--c-primary-dark);text-decoration:underline}.auth-forgot-link:focus-visible{outline:2px solid var(--c-primary);outline-offset:3px;border-radius:2px}.field-with-forgot{position:relative}.field-with-forgot .auth-forgot-link{text-align:left;margin-top:6px;margin-bottom:0;display:block}.auth-back-link{color:var(--c-text-2);margin-bottom:var(--sp-5);border-radius:var(--r-sm);transition:all var(--dur) var(--ease);align-items:center;gap:4px;margin-right:-10px;padding:6px 10px 6px 12px;font-size:13px;text-decoration:none;display:inline-flex}.auth-back-link:hover{background:var(--c-surface-2);color:var(--c-text)}.auth-back-link svg{transform:scaleX(-1)}.password-input-wrap{position:relative}.password-input-wrap .input{padding-left:48px}.password-toggle{cursor:pointer;color:var(--c-text-3);border-radius:var(--r-sm);transition:all var(--dur) var(--ease);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.password-toggle:hover{color:var(--c-text);background:var(--c-surface-2)}.password-toggle:focus{outline:2px solid var(--c-primary);outline-offset:2px}.password-strength{flex-direction:column;gap:6px;margin-top:12px;display:flex}.strength-bars{grid-template-columns:repeat(5,1fr);gap:4px;display:grid}.strength-bar{background:var(--c-surface-3);height:4px;transition:background var(--dur) var(--ease);border-radius:2px}.strength-bar.weak{background:#dc2626}.strength-bar.fair{background:#f59e0b}.strength-bar.good{background:#3b82f6}.strength-bar.excellent{background:var(--c-success)}.strength-label{color:var(--c-text-3);transition:color var(--dur) var(--ease);font-size:12px;font-weight:500}.strength-label.weak{color:#dc2626}.strength-label.fair{color:#b45309}.strength-label.good{color:#1e40af}.strength-label.excellent{color:var(--c-success)}.password-requirements{background:var(--c-surface-2);border-radius:var(--r-sm);flex-direction:column;gap:6px;margin:14px 0 0;padding:12px 14px;list-style:none;display:flex}.req-item{color:var(--c-text-3);transition:color .2s var(--ease);align-items:center;gap:8px;font-size:12.5px;display:flex}.req-item.passed{color:var(--c-success)}.req-check{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.req-check .check-empty{color:var(--c-text-3);opacity:.5}.req-check .check-filled{color:var(--c-success)}#match-hint{align-items:center;gap:6px;margin-top:6px;font-size:12px;font-weight:500;display:flex}#match-hint.match-ok{color:var(--c-success)}#match-hint.match-error{color:var(--c-danger)}.auth-help-note{margin-top:var(--sp-5);background:var(--c-info-bg);border-radius:var(--r-sm);color:var(--c-info);align-items:flex-start;gap:10px;padding:12px 14px;font-size:12.5px;line-height:1.6;display:flex}.auth-help-note svg{flex-shrink:0;margin-top:2px}.auth-success-icon,.auth-error-icon{width:64px;height:64px;margin-bottom:var(--sp-5);border-radius:16px;justify-content:center;align-items:center;display:flex}.auth-success-icon{background:var(--c-success-bg);color:var(--c-success)}.auth-error-icon{background:var(--c-danger-bg);color:var(--c-danger)}.auth-info-box{background:var(--c-primary-softer);border:1px solid var(--c-primary-soft);border-radius:var(--r-sm);margin:var(--sp-5) 0;padding:14px 16px}.auth-info-box ol,.auth-info-box ul{color:var(--c-text-2);margin:0;padding-right:18px;font-size:12.5px;line-height:1.8}.auth-info-box li strong{color:var(--c-text);word-break:break-all;font-weight:500}.auth-warn-box{background:var(--c-warning-bg);border-radius:var(--r-sm);margin:var(--sp-4) 0;color:var(--c-warning);align-items:flex-start;gap:10px;padding:12px 14px;font-size:12.5px;line-height:1.6;display:flex}.auth-warn-box svg{flex-shrink:0;margin-top:2px}.auth-warn-box strong{margin-bottom:2px;display:block}.auth-actions{margin-top:var(--sp-5);flex-direction:column;gap:0;display:flex}.auth-redirect-note{margin-top:var(--sp-4);text-align:center;color:var(--c-text-3);font-size:12px}.auth-redirect-note span{color:var(--c-primary);min-width:14px;font-weight:600;display:inline-block}.auth-loading{padding:var(--sp-12) var(--sp-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.auth-loading .spinner{border-width:3px;border-color:var(--c-primary-soft);border-top-color:var(--c-primary);width:40px;height:40px;margin-bottom:var(--sp-4)}.auth-loading p{color:var(--c-text-2);font-size:14px}.banner-success{background:var(--c-success-bg);color:var(--c-success);border:1px solid #bae5cb}.banner-success.show{justify-content:flex-start;gap:8px}.banner-success svg{color:var(--c-success)}@media (max-width:640px){.password-requirements{padding:10px 12px}.req-item,.auth-info-box ol,.auth-info-box ul{font-size:12px}}.captcha-field{margin-top:var(--sp-5);margin-bottom:var(--sp-5)}.captcha-container{justify-content:center;align-items:center;min-height:65px;display:flex}.captcha-container>div{max-width:100%}.captcha-loading{background:var(--c-surface-2);border-radius:var(--r-sm);color:var(--c-text-3);justify-content:center;align-items:center;gap:10px;width:100%;max-width:300px;min-height:65px;padding:18px 20px;font-size:13px;display:flex}.captcha-loading .spinner{border-width:2px;width:16px;height:16px}.captcha-error{background:var(--c-danger-bg);border-radius:var(--r-sm);color:var(--c-danger);text-align:center;border:1px solid #fecaca;padding:14px 16px;font-size:13px;line-height:1.6}@media (max-width:480px){.captcha-container{min-height:70px}}.input-with-toggle{position:relative}.input-with-toggle .input{padding-left:44px}.password-toggle{cursor:pointer;width:32px;height:32px;color:var(--c-text-3);transition:all var(--dur) var(--ease);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.password-toggle:hover{background:var(--c-surface-2);color:var(--c-text)}.password-toggle:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.password-toggle:active{transform:translateY(-50%)scale(.95)}.password-toggle svg{display:block}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:8px;max-width:calc(100vw - 48px);display:flex;position:fixed;bottom:24px;left:24px}.toast{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);pointer-events:auto;border-right:3px solid;align-items:flex-start;gap:10px;min-width:280px;max-width:420px;padding:12px 16px;font-size:13.5px;animation:.28s cubic-bezier(.32,.72,0,1) tk-toast-in;display:flex}.toast.toast-success{border-right-color:var(--c-success)}.toast.toast-error{border-right-color:var(--c-danger)}.toast.toast-warning{border-right-color:var(--c-warning)}.toast.toast-info{border-right-color:var(--c-info)}.toast.removing{animation:.2s forwards tk-toast-out}@keyframes tk-toast-in{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes tk-toast-out{to{opacity:0;transform:translate(-30px)}}.toast-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px;display:inline-flex}.toast-icon svg{width:18px;height:18px}.toast-success .toast-icon{color:var(--c-success)}.toast-error .toast-icon{color:var(--c-danger)}.toast-warning .toast-icon{color:var(--c-warning)}.toast-info .toast-icon{color:var(--c-info)}.toast-content{color:var(--c-text);flex:1;min-width:0;line-height:1.5}.toast-title{margin-bottom:2px;font-weight:600}.toast-message{color:var(--c-text-2);word-wrap:break-word;font-size:12.5px}.toast-close{cursor:pointer;width:22px;height:22px;color:var(--c-text-3);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:18px;line-height:1;display:inline-flex}.toast-close:hover{background:var(--c-surface-2);color:var(--c-text)}.toast-close:focus-visible{outline:2px solid var(--c-primary);outline-offset:1px}@media (max-width:480px){.toast-container{max-width:none;bottom:12px;left:12px;right:12px}.toast{width:100%;min-width:0;max-width:none}}.confirm-modal .modal{max-width:440px}.confirm-modal .modal-body{text-align:center;padding:24px 24px 8px}.confirm-modal .modal-footer{border-top:none;justify-content:center;gap:10px;padding:16px 24px 20px}.confirm-icon{border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 16px;display:flex}.confirm-icon.danger{background:var(--c-danger-bg);color:var(--c-danger)}.confirm-icon.warning{background:var(--c-warning-bg);color:var(--c-warning)}.confirm-icon svg{width:26px;height:26px}.confirm-title{color:var(--c-text);margin-bottom:8px;font-size:17px;font-weight:600}.confirm-message{color:var(--c-text-2);margin-bottom:0;font-size:14px;line-height:1.6}.confirm-detail{color:var(--c-text-3);background:var(--c-surface-2);border-radius:var(--r-sm);text-align:start;word-break:break-all;direction:ltr;margin-top:12px;padding:10px 14px;font-size:12.5px;line-height:1.5}.search-row{gap:var(--sp-3);margin-bottom:var(--sp-4);align-items:center;display:flex}.search-input-wrap{flex:1;max-width:520px;position:relative}.search-input-wrap .input{padding-left:60px;padding-right:38px}.search-icon{color:var(--c-text-3);pointer-events:none;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.search-icon svg{fill:none;stroke:currentColor;stroke-width:2px;width:16px;height:16px}.search-kbd{background:var(--c-surface-2);border:1px solid var(--c-border-2);color:var(--c-text-3);pointer-events:none;border-radius:4px;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:10.5px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.filter-tabs{border-bottom:2px solid var(--c-border);margin-bottom:var(--sp-5);gap:0;display:flex;overflow-x:auto}.filter-tab{color:var(--c-text-3);cursor:pointer;white-space:nowrap;transition:color var(--dur) var(--ease);background:0 0;border:none;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex;position:relative}.filter-tab:hover{color:var(--c-text)}.filter-tab.active{color:var(--c-primary)}.filter-tab.active:after{content:"";background:var(--c-primary);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-2px;left:0;right:0}.filter-tab .count{background:var(--c-surface-2);border-radius:var(--r-full);color:var(--c-text-2);font-variant-numeric:tabular-nums;padding:1px 7px;font-size:10.5px;font-weight:600}.filter-tab.active .count{background:var(--c-primary-soft);color:var(--c-primary)}.wizard-progress{padding:0 var(--sp-6);margin-bottom:var(--sp-4);gap:6px;display:flex}.wizard-step-bar{background:var(--c-border);height:3px;transition:background var(--dur) var(--ease);border-radius:2px;flex:1}.wizard-step-bar.active,.wizard-step-bar.done{background:var(--c-primary)}.wizard-step-label{color:var(--c-text-3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px;font-size:11px}.wizard-step-title{color:var(--c-text);margin-bottom:6px;font-size:18px;font-weight:600}.wizard-step-desc{color:var(--c-text-2);margin-bottom:var(--sp-5);font-size:13px}.wizard-pane{display:none}.wizard-pane.active{display:block}.info-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-sm);margin-bottom:12px;padding:12px 14px}.info-card-title{color:var(--c-text-3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.info-row{grid-template-columns:100px 1fr;gap:10px;padding:4px 0;font-size:13px;display:grid}.info-row-label{color:var(--c-text-3)}.info-row-value{color:var(--c-text);font-weight:500}.info-row-value.mono{direction:ltr;font-family:IBM Plex Mono,monospace;font-size:12px}.info-row-value.email{text-align:right;direction:ltr}.audit-log{margin:0;padding:0;list-style:none}.audit-item{border-bottom:1px solid var(--c-border);gap:10px;padding:10px 0;display:flex}.audit-item:last-child{border-bottom:none}.audit-dot{background:var(--c-primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.audit-dot.success{background:var(--c-success)}.audit-dot.warning{background:var(--c-warning)}.audit-dot.danger{background:var(--c-danger)}.audit-dot.neutral{background:var(--c-text-3)}.audit-content{flex:1;min-width:0}.audit-title{color:var(--c-text);font-size:13px}.audit-meta{color:var(--c-text-3);margin-top:2px;font-size:11px}.mini-stats{margin-bottom:var(--sp-4);grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.mini-stat{background:var(--c-surface-2);border-radius:var(--r-sm);text-align:center;padding:12px}.mini-stat-value{color:var(--c-text);font-variant-numeric:tabular-nums;font-size:20px;font-weight:600;line-height:1.2}.mini-stat-label{color:var(--c-text-3);margin-top:4px;font-size:11px}.review-card{background:var(--c-surface-2);border-radius:var(--r-sm);margin-bottom:12px;padding:12px 14px}.review-card-title{color:var(--c-text-3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.review-row{grid-template-columns:130px 1fr;gap:10px;padding:4px 0;font-size:13px;display:grid}.review-row-label{color:var(--c-text-3)}.review-row-value{color:var(--c-text);font-weight:500}.review-row-value.muted{color:var(--c-text-3);font-style:italic;font-weight:400}.kpi.kpi-clickable{cursor:pointer}.kpi.kpi-active{background:var(--c-primary-soft);border-color:var(--c-primary)}.kpi-small{color:var(--c-text-3);margin-top:2px;font-size:11px}.field-row{gap:var(--sp-3);grid-template-columns:1fr 1fr;display:grid}.modal-wide{max-width:720px}.modal-narrow{max-width:400px}.empty-state.compact{padding:var(--sp-8)}.detail-header{gap:var(--sp-4);padding-bottom:var(--sp-4);margin-bottom:var(--sp-4);border-bottom:1px solid var(--c-border);align-items:flex-start;display:flex}.detail-header-info{flex:1;min-width:0}.detail-header-name{color:var(--c-text);margin-bottom:2px;font-size:18px;font-weight:600}.detail-header-name-en{color:var(--c-text-3);text-align:right;direction:ltr;margin-bottom:8px;font-size:12.5px}.detail-panel{display:none}.detail-panel.active{display:block}@media (max-width:640px){.field-row{grid-template-columns:1fr}.mini-stats{grid-template-columns:1fr 1fr}.info-row,.review-row{grid-template-columns:1fr;gap:2px}.search-input-wrap{max-width:100%}.toast{bottom:var(--sp-4);padding:10px 14px;font-size:13px}}.drill-filter-banner{border:1px solid #f0e0b8;color:var(--c-text-2);background:#fffbf0;border-inline-start:3px solid #b8902d;border-radius:0 8px 8px 0;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:13.5px;line-height:1.6;animation:.2s ease-out slideDown;display:flex}.drill-filter-banner-icon{color:#8a6b1f;background:#fdf4e2;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.drill-filter-banner-icon svg{stroke-width:1.75px;width:16px;height:16px}.drill-filter-banner-text{flex:1;min-width:0}.drill-filter-banner-text strong{color:var(--c-text);margin-inline-end:6px;font-weight:600}.drill-filter-banner-text small{color:var(--c-text-3);margin-inline-start:6px;font-size:11.5px}.drill-filter-banner-close{cursor:pointer;color:#8a6b1f;width:28px;height:28px;transition:all .12s var(--ease);background:0 0;border:1px solid #e5d9b8;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.drill-filter-banner-close:hover{color:var(--c-text);background:#fdf4e2;border-color:#b8902d}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.readonly-info-banner{border:1px solid #dbe5f0;color:var(--c-text-2);background:#f4f7fa;border-inline-start:3px solid #1565a5;border-radius:0 8px 8px 0;align-items:flex-start;gap:14px;margin-bottom:20px;padding:14px 18px;font-size:13px;line-height:1.75;display:flex}.readonly-info-banner-icon{color:#1565a5;background:#e7f0fa;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.readonly-info-banner-icon svg{stroke-width:1.75px;width:18px;height:18px}.readonly-info-banner-text{flex:1;min-width:0}.readonly-info-banner-text strong{color:var(--c-text);margin-bottom:4px;font-size:14px;font-weight:600;display:block}.readonly-info-banner-text p{margin:0}.readonly-info-banner-text p+p{margin-top:6px}.tk-kpi-tooltip{z-index:100;background:var(--c-surface,#fff);border:1px solid var(--c-border,#e5e7eb);opacity:0;pointer-events:none;direction:rtl;border-radius:10px;width:320px;max-width:calc(100vw - 32px);padding:0;font-size:13px;transition:opacity .15s,transform .15s;position:absolute;transform:translateY(-4px);box-shadow:0 12px 36px #0a192924}.tk-kpi-tooltip.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.tk-kpi-tooltip-head{border-bottom:1px solid var(--c-border,#e5e7eb);color:var(--c-text-3,#6b7280);text-transform:uppercase;letter-spacing:.4px;padding:10px 14px;font-size:11.5px;font-weight:600}.tk-kpi-tooltip-body{max-height:240px;padding:6px 0;overflow-y:auto}.tk-kpi-tooltip-row{color:var(--c-text-2,#2c3e50);align-items:center;gap:10px;padding:7px 14px;font-size:12.5px;text-decoration:none;transition:background .1s;display:flex}.tk-kpi-tooltip-row:hover{background:var(--c-primary-softer,#ecfdf3);color:var(--c-text,#111827)}.tk-kpi-tooltip-row-label{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.tk-kpi-tooltip-row-sub{color:var(--c-text-3,#6b7280);flex-shrink:0;font-family:IBM Plex Mono,monospace;font-size:11px}.tk-kpi-tooltip-empty,.tk-kpi-tooltip-loading{text-align:center;color:var(--c-text-3,#6b7280);padding:16px;font-size:12px}.tk-kpi-tooltip-foot{border-top:1px solid var(--c-border,#e5e7eb);background:var(--c-surface-2,#f9fafb);text-align:center;border-radius:0 0 10px 10px;padding:8px 14px}.tk-kpi-tooltip-foot a{color:var(--c-primary,#0f6e56);font-size:11.5px;font-weight:500;text-decoration:none}.tk-kpi-tooltip-foot a:hover{text-decoration:underline}.tk-page-hint{color:#5a4413;background:#fdf4e2;border-inline-start:3px solid #b8902d;border-radius:0 6px 6px 0;margin-bottom:16px;padding:12px 16px;font-size:12.5px;line-height:1.7}.tk-page-hint strong{color:#8b2626}.tk-page-hint code{background:#f0ecdf;border-radius:3px;padding:1px 6px;font-family:IBM Plex Mono,monospace;font-size:11px}.tk-readonly-hint{color:#1a3a52;background:#f4f7fa;border-inline-start:3px solid #1565a5;border-radius:0 6px 6px 0;margin-bottom:16px;padding:12px 16px;font-size:12.5px;line-height:1.7}.tk-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px;display:flex}.tk-header .page-title{align-items:center;gap:10px;display:flex}.tk-count{color:var(--c-text-3);background:var(--c-surface-2);font-variant-numeric:tabular-nums;border-radius:999px;padding:3px 10px;font-size:13px;font-weight:500}.tk-kpis{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px;display:grid}.tk-kpi{background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;padding:14px 16px}.tk-kpi-label{color:var(--c-text-3);margin-bottom:6px;font-size:11px}.tk-kpi-val{font-variant-numeric:tabular-nums;color:var(--c-text);font-size:24px;font-weight:600;line-height:1.1}.tk-kpi[data-tone=ok] .tk-kpi-val{color:#1a5c2a}.tk-kpi[data-tone=warn] .tk-kpi-val{color:#8a6b1f}.tk-kpi[data-tone=danger] .tk-kpi-val{color:#8b2626}.tk-kpi[data-tone=info] .tk-kpi-val{color:#1565a5}.tk-table-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;overflow:hidden}.tk-table{border-collapse:collapse;width:100%}.tk-table thead{background:var(--c-surface-2)}.tk-table th{text-align:right;color:var(--c-text-3);letter-spacing:.4px;border-bottom:1px solid var(--c-border);text-transform:uppercase;padding:11px 14px;font-size:11px;font-weight:600}.tk-table td{border-bottom:1px solid var(--c-border);vertical-align:top;color:var(--c-text);padding:13px 14px;font-size:13px}.tk-table tbody tr:last-child td{border-bottom:none}.tk-table tbody tr.clickable{cursor:pointer;transition:background .1s}.tk-table tbody tr.clickable:hover{background:var(--c-primary-softer)}.tk-table .num{font-variant-numeric:tabular-nums;font-family:IBM Plex Mono,monospace}.tk-table .ltr{direction:ltr;font-family:IBM Plex Mono,monospace}.tk-table .actions{text-align:left}.tk-chip{border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-flex}.tk-chip:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.tk-chip[data-tone=active],.tk-chip[data-tone=success]{color:#1a5c2a;background:#ecfdf3}.tk-chip[data-tone=warn],.tk-chip[data-tone=expired]{color:#8a6b1f;background:#fdf4e2}.tk-chip[data-tone=danger],.tk-chip[data-tone=revoked]{color:#8b2626;background:#fee2e2}.tk-chip[data-tone=muted],.tk-chip[data-tone=draft]{background:var(--c-surface-2);color:var(--c-text-3)}.tk-chip[data-tone=info],.tk-chip[data-tone=upcoming]{color:#1565a5;background:#e0e7ff}.tk-empty{text-align:center;color:var(--c-text-3);padding:56px 20px}.tk-empty-title{color:var(--c-text-2);margin-bottom:6px;font-size:15px;font-weight:500}.tk-empty-desc{font-size:12.5px}.tk-toolbar{background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;flex-direction:column;gap:12px;margin-bottom:16px;padding:12px;display:flex}.tk-search{background:var(--c-surface-2);width:100%;color:var(--c-text);border:1px solid #0000;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.tk-search:focus{background:var(--c-surface);border-color:var(--c-primary);box-shadow:0 0 0 3px #0f6e561a}.tk-pills{flex-wrap:wrap;gap:6px;display:flex}.tk-pill{border:1px solid var(--c-border-2);color:var(--c-text-2);cursor:pointer;background:0 0;border-radius:999px;padding:6px 14px;font-family:inherit;font-size:12.5px;font-weight:500;transition:all .15s}.tk-pill:hover{color:var(--c-text);border-color:var(--c-border-3,#ccc)}.tk-pill.active{background:var(--c-primary);border-color:var(--c-primary);color:#fff}.tk-grid-cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;display:grid}.tk-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;padding:16px 18px}.tk-field{flex-direction:column;gap:5px;margin-bottom:14px;display:flex}.tk-field.span-2{grid-column:1/-1}.tk-label{color:var(--c-text-2);font-size:12px;font-weight:500}.tk-label .req{color:#b8390e;margin-inline-end:2px}.tk-input,.tk-select,.tk-textarea{background:var(--c-surface);border:1px solid var(--c-border-2);width:100%;color:var(--c-text);border-radius:6px;outline:none;padding:9px 12px;font-family:inherit;font-size:14px;transition:all .13s}.tk-input:focus,.tk-select:focus,.tk-textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0f6e561a}.tk-input.ltr{text-align:right;direction:ltr;font-family:IBM Plex Mono,IBM Plex Sans Arabic,monospace;font-size:13px}.tk-textarea{resize:vertical;min-height:60px}.tk-hint{color:var(--c-text-3);font-size:11.5px}.tk-form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.tk-modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;background:#04342c80;justify-content:center;align-items:flex-start;padding:40px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.tk-modal{background:var(--c-surface);border-radius:12px;width:100%;overflow:hidden;box-shadow:0 20px 60px #0a192940}.tk-modal-head{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);align-items:center;gap:12px;padding:16px 22px;display:flex}.tk-modal-title{color:var(--c-text);flex:1;font-size:16px;font-weight:600}.tk-modal-close{width:30px;height:30px;color:var(--c-text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;font-size:24px;line-height:1}.tk-modal-close:hover{background:var(--c-surface);color:var(--c-text)}.tk-modal-body{padding:20px 22px}.tk-modal-foot{border-top:1px solid var(--c-border);background:var(--c-surface-2);justify-content:flex-start;gap:8px;padding:14px 22px;display:flex}.tk-skel{background:linear-gradient(90deg, var(--c-surface-2) 0%, var(--c-surface-3,#e9e9e9) 50%, var(--c-surface-2) 100%);background-size:200% 100%;border-radius:4px;height:14px;animation:1.4s ease-in-out infinite tk-skel}@keyframes tk-skel{0%{background-position:200% 0}to{background-position:-200% 0}}.tk-checklist-action:hover{background:#fbf7ec!important;border-color:#b8902d!important}.tk-checklist-action:focus-visible{outline-offset:1px;outline:2px solid #b8902d}.auth-center{background:linear-gradient(#fafaf7 0%,#f5f1e8 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.verify-card{text-align:center;background:#fff;border:1px solid #e8e0d0;border-radius:12px;width:100%;max-width:420px;padding:36px 32px 28px;box-shadow:0 4px 20px #0a19290f}.auth-icon{color:#fff;background:linear-gradient(135deg,#0f6e56 0%,#1b9d77 100%);border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 18px;display:flex}.auth-icon svg{stroke-width:1.75px;width:28px;height:28px}.auth-card-title{color:#0a1929;letter-spacing:-.3px;margin-bottom:6px;font-size:19px;font-weight:700}.auth-card-subtitle{color:#6b7280;margin-bottom:22px;font-size:13.5px;line-height:1.7}.auth-user-mono{color:#2c3e50;direction:ltr;margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:12.5px}.totp-input{color:#0a1929;text-align:center;letter-spacing:.6em;direction:ltr;background:#fafaf7;border:1.5px solid #e8e0d0;border-radius:10px;outline:none;width:100%;padding:16px;font-family:IBM Plex Mono,monospace;font-size:28px;font-weight:600;transition:all .15s}.totp-input:focus{background:#fff;border-color:#0f6e56;box-shadow:0 0 0 3px #0f6e561a}.totp-input::placeholder{color:#c5bda8;letter-spacing:.4em;font-weight:400}.totp-input.is-error{background:#fef2f2;border-color:#b8390e;animation:.4s ease-in-out auth-shake}.totp-input.sm{letter-spacing:.5em;border-radius:8px;padding:14px 16px;font-size:22px}@keyframes auth-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.hint-row{color:#8a6b1f;justify-content:center;align-items:center;gap:6px;margin-top:10px;font-size:11.5px;display:flex}.hint-row .dot{background:#b8902d;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite auth-pulse}@keyframes auth-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.countdown{background:#f0ecdf;border-radius:3px;height:3px;margin-top:14px;position:relative;overflow:hidden}.countdown-bar{transform-origin:100%;background:linear-gradient(90deg,#0f6e56,#1b9d77);transition:transform 1s linear;position:absolute;inset:0}.auth-err{color:#8b2626;text-align:start;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;margin:12px 0 0;padding:10px 14px;font-size:13px;line-height:1.6}.auth-success{color:#1a5c2a;text-align:start;background:#ecfdf3;border:1px solid #86efac;border-radius:6px;margin:10px 0 0;padding:10px 14px;font-size:13px;line-height:1.6}.auth-actions{gap:8px;margin-top:22px;display:flex}.auth-meta{color:#6b7280;border-top:1px dashed #e8e0d0;margin-top:22px;padding-top:16px;font-size:11px;line-height:1.7}.auth-meta strong{color:#2c3e50}.mfa-card{background:#fff;border:1px solid #e8e0d0;border-radius:12px;width:100%;max-width:480px;padding:32px;box-shadow:0 4px 20px #0a19290f}.mfa-header{text-align:center;border-bottom:1px solid #f0ecdf;margin-bottom:24px;padding-bottom:20px}.step{margin-bottom:22px}.step-title{color:#0a1929;align-items:center;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.step-num{color:#fff;background:#0f6e56;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-inline-end:8px;font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:600;display:inline-flex}.step-desc{color:#2c3e50;margin-bottom:10px;margin-inline-start:30px;font-size:13px;line-height:1.7}.qr-wrap{text-align:center;background:#f5f1e8;border:1px solid #e8e0d0;border-radius:10px;margin:12px 0;padding:20px}.qr-img{background:#fff;border-radius:8px;padding:12px;line-height:0;display:inline-block}.qr-img img,.qr-img svg{width:192px;height:192px;display:block}.secret-row{direction:ltr;background:#fff;border:1px solid #e8e0d0;border-radius:6px;align-items:center;gap:10px;margin-top:12px;padding:10px 14px;display:flex}.secret-label{color:#6b7280;letter-spacing:.5px;font-size:11px;font-weight:500}.secret-value{color:#0a1929;word-break:break-all;-webkit-user-select:all;user-select:all;flex:1;font-family:IBM Plex Mono,monospace;font-size:13px}.secret-copy{color:#2c3e50;cursor:pointer;background:0 0;border:1px solid #e8e0d0;border-radius:4px;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .12s}.secret-copy:hover{color:#fff;background:#0f6e56;border-color:#0f6e56}.recovery-note{color:#5a4413;background:#fdf4e2;border-inline-start:3px solid #b8902d;border-radius:0 6px 6px 0;margin-top:14px;padding:10px 14px;font-size:12px;line-height:1.7}.otp-info-text{color:#5f5e5a;margin:0 0 20px;font-size:14px;line-height:1.7}.otp-info-text strong{color:#04342c;word-break:break-all;font-weight:600}.otp-input-group{direction:ltr;justify-content:center;gap:10px;margin:24px 0 16px;display:flex}.otp-digit{text-align:center;color:#04342c;background:#fff;border:2px solid #d6dcd9;border-radius:10px;outline:none;width:48px;height:56px;padding:0;font-family:IBM Plex Mono,monospace;font-size:26px;font-weight:600;line-height:1;transition:border-color .15s,background-color .15s,box-shadow .15s}.otp-digit:focus{border-color:#0f6e56;box-shadow:0 0 0 3px #0f6e5626}.otp-digit.filled{background:#f4faf7;border-color:#0f6e56}.otp-digit.error{background:#fef2f2;border-color:#dc2626;animation:.4s auth-shake-lg}.otp-digit:disabled{cursor:not-allowed;background:#f4f6f5}@keyframes auth-shake-lg{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.otp-actions{flex-direction:column;align-items:center;gap:4px;margin-top:16px;display:flex}.otp-link-btn{color:#5f5e5a;cursor:pointer;background:0 0;border:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:color .15s}.otp-link-btn:hover:not(:disabled){color:#0f6e56}.otp-link-btn:disabled{cursor:not-allowed;color:#8e8d88}.otp-link-btn.ready{color:#0f6e56;font-weight:500}.otp-tips{background:#f4faf7;border:1px solid #d8ede3;border-radius:8px;margin:20px 0;padding:14px 16px}.otp-tips h4{color:#04342c;align-items:center;gap:6px;margin:0 0 8px;font-size:13px;font-weight:600;display:flex}.otp-tips ul{color:#5f5e5a;margin:0;padding:0;font-size:13px;line-height:1.7;list-style:none}.otp-tips li{padding-inline-start:18px;position:relative}.otp-tips li:before{content:"•";color:#0f6e56;font-weight:700;position:absolute;inset-inline-start:6px}.otp-tips strong{color:#04342c;font-weight:600}.otp-warn{color:#9a6400;background:#fff8e1;border-radius:8px;align-items:flex-start;gap:8px;margin:16px 0;padding:12px 14px;font-size:13px;display:flex}.otp-warn svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.otp-warn strong{color:#9a6400}.password-field-wrap{position:relative}.pwd-toggle-btn{top:50%;cursor:pointer;color:#5f5e5a;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,color .15s;position:absolute;inset-inline-start:10px;transform:translateY(-50%)}.pwd-toggle-btn:hover{color:#0f6e56;background:#f4faf7}.input.has-toggle{padding-inline-start:60px}.strength-wrap{margin:8px 0 16px}.strength-bar{background:#e9ebe9;border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden}.strength-fill{background:#dc2626;border-radius:3px;width:0%;height:100%;transition:width .25s,background-color .25s}.strength-fill.s-1{background:#dc2626;width:20%}.strength-fill.s-2{background:#ea580c;width:40%}.strength-fill.s-3{background:#f59e0b;width:60%}.strength-fill.s-4{background:#84cc16;width:80%}.strength-fill.s-5{background:#0f6e56;width:100%}.strength-label{color:#5f5e5a;font-size:12px;font-weight:500}.strength-label .s-text{color:#04342c;font-weight:600}.reqs-list{grid-template-columns:1fr 1fr;gap:6px 16px;margin:12px 0 20px;padding:0;list-style:none;display:grid}.reqs-list li{color:#8e8d88;align-items:center;gap:6px;font-size:12px;transition:color .2s;display:flex}.reqs-list li.passed{color:#0f6e56}.reqs-list .req-icon{background:#e9ebe9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;transition:background .2s;display:flex}.reqs-list li.passed .req-icon{background:#0f6e56}.reqs-list .req-icon svg{color:#fff;opacity:0;width:8px;height:8px;transition:opacity .2s}.reqs-list li.passed .req-icon svg{opacity:1}.match-indicator{align-items:center;gap:6px;min-height:18px;margin-top:6px;font-size:13px;display:flex}.match-indicator.match-ok{color:#0f6e56}.match-indicator.match-fail{color:#dc2626}.match-indicator svg{flex-shrink:0;width:14px;height:14px}.auth-loading{text-align:center;color:#6b7280;padding:40px 0}.auth-loading p{margin-top:14px;font-size:13px}.auth-state-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.auth-state-icon.err{color:#b8390e;background:#fef2f2}.auth-state-icon.ok{color:#1a5c2a;background:#ecfdf3}.auth-info-box{background:#f4faf7;border:1px solid #d8ede3;border-radius:8px;margin-top:18px;padding:14px 16px}.auth-info-box h4{color:#04342c;margin:0 0 8px;font-size:13px;font-weight:600}.auth-info-box ol{color:#5f5e5a;margin:0;padding-inline-start:18px;font-size:12.5px;line-height:1.8}.auth-redirect-note{text-align:center;color:#6b7280;margin-top:16px;font-size:13px}@media (max-width:600px){.reqs-list{grid-template-columns:1fr}}@media (max-width:480px){.otp-digit{width:42px;height:50px;font-size:22px}.otp-input-group{gap:6px}.totp-input{font-size:24px}}
