:root{font-family:Inter,Roboto,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background-color:#f0f2f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}.login-container{min-height:100vh;display:flex}.login-branding{flex:1.2;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px;position:relative;overflow:hidden}.login-branding-bg{position:absolute;inset:0;background:url(/bg-sso.jpg) center / cover no-repeat;z-index:0}.login-branding-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0a1628b8,#1b3a5c8c,#0a1628bf)}.login-branding-content{position:relative;z-index:1;text-align:center;max-width:580px;padding:48px 40px;background:#0a162873;border-radius:20px;border:1px solid rgba(212,168,67,.15);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-logo-title{font-size:42px;font-weight:800;color:#d4a843;letter-spacing:6px;text-transform:uppercase;margin-bottom:16px;text-shadow:0 2px 24px rgba(212,168,67,.5),0 0 60px rgba(212,168,67,.15);position:relative;display:inline-block}.login-logo-title:before,.login-logo-title:after{content:"";position:absolute;top:50%;width:60px;height:2px}.login-logo-title:before{right:calc(100% + 20px);background:linear-gradient(90deg,transparent,#D4A843)}.login-logo-title:after{left:calc(100% + 20px);background:linear-gradient(90deg,#D4A843,transparent)}.login-branding h1{color:#fff;font-size:22px;font-weight:600;letter-spacing:3px;margin-bottom:6px;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.4)}.login-branding h2{color:#ffffffa6;font-size:15px;font-weight:400;margin-bottom:36px;line-height:1.6}.login-features{display:flex;flex-direction:column;gap:18px;text-align:left}.login-feature-item{display:flex;align-items:center;gap:14px;color:#fffc;font-size:15px}.login-feature-icon{width:42px;height:42px;border-radius:10px;background:#d4a84326;border:1px solid rgba(212,168,67,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#d4a843;font-size:18px}.login-form-side{flex:.8;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 48px;background:#fff}.login-form-wrapper{width:100%;max-width:400px}.login-form-header{margin-bottom:36px}.login-form-header h3{font-size:24px;font-weight:700;color:#1b3a5c;margin-bottom:8px}.login-form-header p{color:#666;font-size:14px}.login-form .ant-input-affix-wrapper{padding:10px 14px;border-radius:8px}.login-form .ant-btn-primary{height:44px;border-radius:8px;font-size:15px;font-weight:600}.login-footer{margin-top:48px;text-align:center;color:#999;font-size:12px}@media(max-width:900px){.login-branding{display:none}.login-form-side{flex:1}}.sidebar-logo{height:64px;display:flex;align-items:center;padding:0 16px;gap:12px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-logo-badge{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#d4a843,#f0d890);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #d4a8434d}.sidebar-logo-badge span{font-size:14px;font-weight:800;color:#0a1628}.sidebar-logo-text h4{color:#fff;font-size:14px;font-weight:700;margin:0;line-height:1.3}.sidebar-logo-text p{color:#ffffff59;font-size:11px;margin:0}.sidebar-user{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:#0003;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.sidebar-user-name{color:#fff;font-size:13px;font-weight:500;line-height:1.3}.sidebar-user-role{color:#ffffff73;font-size:11px}.stat-card{border-radius:14px;padding:20px;position:relative;overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;min-height:120px}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #1b3a5c2e}.stat-card .stat-bg-icon{position:absolute;top:-8px;right:-8px;font-size:64px;opacity:.1;color:#fff;transition:all .5s cubic-bezier(.4,0,.2,1)}.stat-card:hover .stat-bg-icon{transform:rotate(15deg) scale(1.15)}.stat-card .stat-icon-badge{width:32px;height:32px;border-radius:8px;background:#fff3;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;margin-bottom:12px}.stat-card .stat-value{font-size:26px;font-weight:700;color:#fff;line-height:1.2}.stat-card .stat-value .stat-unit{font-size:13px;opacity:.7;margin-left:4px;font-weight:400}.stat-card .stat-label{font-size:12px;color:#fffc;margin-top:4px}.section-card{border-radius:14px;box-shadow:0 2px 12px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1)}.section-card:hover{box-shadow:0 8px 24px #1b3a5c1a}.section-card .card-title-icon{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;font-size:16px}.sider-menu .ant-menu-item-selected:before{content:"";position:absolute;left:0;top:25%;height:50%;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#d4a843,#f0d890)}.sider-menu .ant-menu-submenu-arrow{display:none}.permission-matrix .ant-table-thead>tr>th{text-align:center;font-size:12px;padding:8px 6px}.permission-matrix .ant-table-tbody>tr>td{text-align:center;padding:6px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1b3a5c26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#1b3a5c4d}.ant-layout-sider ::-webkit-scrollbar-thumb{background:#ffffff1a}@keyframes pulse{0%{box-shadow:0 0 #ff4d4f66}70%{box-shadow:0 0 0 8px #ff4d4f00}to{box-shadow:0 0 #ff4d4f00}}.pulse-danger{animation:pulse 2s infinite}
