:root{--bg: #f6f8fb;--card: #ffffff;--ink: #0f172a;--muted: #64748b;--brand: #4f46e5;--brand-2: #6366f1;--brand-dark: #0b1220;--line: #e7ebf1;--ok: #16a34a;--warn: #d97706;--bad: #dc2626}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif;background:radial-gradient(1200px 480px at 80% -10%,rgba(99,102,241,.07),transparent 60%),radial-gradient(900px 420px at -10% 0%,rgba(8,145,178,.05),transparent 55%),var(--bg);background-attachment:fixed;color:var(--ink);-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}.shell{display:flex;min-height:100vh}.sidebar{width:250px;flex:0 0 250px;background:linear-gradient(180deg,#111a2e,#0b1220);color:#cbd5e1;display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;padding:4px 8px 22px}.brand-mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%);box-shadow:0 6px 16px #4f46e573}.brand-text{display:flex;flex-direction:column;line-height:1.25}.brand-name{color:#fff;font-weight:700;font-size:15px}.brand-sub{color:#6b7a92;font-size:11px}.nav-label{color:#56657f;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;margin-top:4px}.sidebar nav{display:flex;flex-direction:column;gap:3px}.sidebar nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:#aeb9cc;font-size:14px;font-weight:500;position:relative;transition:background .15s,color .15s}.sidebar nav a svg{color:#7c8aa3;transition:color .15s}.sidebar nav a:hover{background:#ffffff0d;color:#fff}.sidebar nav a:hover svg{color:#cbd5e1}.sidebar nav a.active{background:linear-gradient(135deg,#4f46e5f2,#6366f1e6);color:#fff;box-shadow:0 6px 16px #4f46e559}.sidebar nav a.active svg{color:#fff}.sidebar .spacer{flex:1}.user-card{display:flex;align-items:center;gap:10px;padding:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:12px}.avatar{width:36px;height:36px;flex:0 0 36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:13px;font-weight:700;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%)}.user-meta{display:flex;flex-direction:column;line-height:1.3;min-width:0;flex:1}.user-name{color:#fff;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:#6b7a92;font-size:11px;text-transform:capitalize}.signout{background:#ffffff0f;color:#aeb9cc;border:0;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;cursor:pointer;padding:0;flex:0 0 auto}.signout:hover{background:#dc2626d9;color:#fff}.main{flex:1;padding:26px 30px;overflow:auto;min-width:0}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.card{background:var(--card);border-radius:16px;border:1px solid var(--line);box-shadow:0 1px 2px #0f172a0a,0 10px 30px #0f172a09;padding:20px}.stat .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.stat .value{font-size:28px;font-weight:700;margin-top:4px}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px}.page-header h2{margin:0;font-size:24px;font-weight:700;letter-spacing:-.02em}.page-header .crumb{color:var(--muted);font-size:13px;margin-top:3px}.hero{position:relative;overflow:hidden;border-radius:20px;padding:26px 28px;color:#fff;background:linear-gradient(120deg,#312e81,#4f46e5,#6366f1);box-shadow:0 16px 40px #4f46e547;display:flex;align-items:center;justify-content:space-between;gap:16px}.hero-eyebrow{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#ffffffb3}.hero h2{margin:6px 0;font-size:26px;font-weight:800;letter-spacing:-.02em}.hero p{margin:0;color:#ffffffe0;font-size:14px}.hero-refresh{position:relative;z-index:2;background:#ffffff29;color:#fff;box-shadow:none;border:1px solid rgba(255,255,255,.25);display:inline-flex;align-items:center;gap:7px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hero-refresh:hover{background:#ffffff42;filter:none}.hero-glow{position:absolute;width:360px;height:360px;border-radius:50%;right:-80px;top:-160px;background:radial-gradient(circle,rgba(255,255,255,.28),transparent 65%)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{position:relative;overflow:hidden;background:var(--card);border-radius:16px;padding:20px;box-shadow:0 1px 2px #0f172a0a,0 10px 30px #0f172a0a;border:1px solid var(--line);display:flex;flex-direction:column;gap:14px;transition:box-shadow .18s,transform .18s}.stat-card:after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:color-mix(in srgb,var(--accent, var(--brand)) 8%,transparent)}.stat-sub{font-size:11.5px;color:var(--muted);margin-top:3px}.stat-card:hover{box-shadow:0 8px 24px #0f172a14;transform:translateY(-2px)}.stat-card .icon{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:var(--accent, var(--brand));background:color-mix(in srgb,var(--accent, var(--brand)) 12%,white)}.stat-card .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-card .value{font-size:32px;font-weight:800;margin-top:2px;line-height:1;letter-spacing:-.02em}.stat-card.blue{--accent: #2563eb}.stat-card.green{--accent: #16a34a}.stat-card.amber{--accent: #d97706}.stat-card.violet{--accent: #7c3aed}.stat-card.red{--accent: #dc2626}.composition .total{font-size:13px;color:var(--muted);margin-bottom:12px}.composition .total strong{color:var(--ink);font-size:15px}.composition .bar{display:flex;height:14px;border-radius:999px;overflow:hidden;background:#eef2f7}.composition .bar span{height:100%}.composition .legend{display:flex;flex-wrap:wrap;gap:12px 18px;margin-top:16px}.composition .legend .row2{display:flex;align-items:center;gap:8px;font-size:13px}.composition .legend .dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}.composition .legend .lname{color:var(--muted)}.composition .legend .lval{font-weight:700;color:var(--ink)}.card-title{display:flex;align-items:center;gap:10px;margin:0 0 18px;padding-bottom:14px;font-size:15px;font-weight:700;border-bottom:1px solid var(--line)}.card-title svg{color:var(--brand)}.list-scroll{max-height:320px;overflow-y:auto;margin:-4px -6px;padding:0 6px}.list-scroll::-webkit-scrollbar{width:8px}.list-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:999px}.list-row{display:flex;align-items:center;gap:12px;padding:10px 6px;border-bottom:1px solid var(--line)}.list-row:last-child{border-bottom:0}.list-row:hover{background:#f8fafc}.list-row .nm{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row .sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend{display:flex;flex-direction:column;gap:4px}.legend .row2{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:9px;font-size:13px}.legend .row2:hover{background:#f8fafc}.legend .dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}.legend .lname{color:var(--ink);flex:1}.legend .lval{font-weight:700;color:var(--ink)}.legend .lpct{color:var(--muted);font-size:12px;width:36px;text-align:right}input[type=date]{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234f46e5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") no-repeat left 12px center,#fff;padding-left:38px;font-weight:600;color:var(--ink)}input[type=date]::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:100%;left:0;position:absolute}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search{position:relative;flex:1;max-width:340px}.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}.search input{padding-left:38px;background:var(--card)}.count-pill{font-size:12px;font-weight:600;color:var(--muted);background:#eef1f6;padding:5px 11px;border-radius:999px}.cell-user{display:flex;align-items:center;gap:11px}.avatar-sm{width:36px;height:36px;flex:0 0 36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700}.cell-user .nm{font-weight:600}.cell-user .sub{font-size:12px;color:var(--muted)}.icon-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:6px 11px;font-size:13px;font-weight:500;cursor:pointer}.icon-btn:hover{border-color:var(--brand);color:var(--brand);background:#f5f5ff}.icon-btn svg{color:inherit}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.pill.active{background:#dcfce7;color:#15803d}.pill.inactive{background:#f1f5f9;color:#64748b}.empty{text-align:center;color:var(--muted);padding:36px 16px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 16px;color:var(--muted)}.empty-state .empty-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:#eef2ff;color:var(--brand)}.empty-state span{font-size:14px}.req-list{display:flex;flex-direction:column;gap:10px}.req-card{display:flex;align-items:center;gap:13px;padding:13px 14px;border:1px solid var(--line);border-radius:14px;background:#fff;transition:box-shadow .15s,border-color .15s}.req-card:hover{border-color:#d7dce6;box-shadow:0 6px 18px #0f172a0d}.req-main{flex:1;min-width:0}.req-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.req-name{font-weight:700;font-size:14px}.req-sub{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.req-sub svg{color:var(--muted);flex:0 0 auto}.req-actions{display:flex;gap:8px;flex:0 0 auto}.req-actions button{padding:7px 14px;font-size:13px}.chip{font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;background:#eef2ff;color:var(--brand)}.chip-green{background:#dcfce7;color:#15803d}.chip-gray{background:#f1f5f9;color:var(--muted)}.chip-mono{background:#f1f5f9;color:#334155;font-family:ui-monospace,monospace}.pill-dot{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:700}.pill-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.run-list{display:flex;flex-direction:column;gap:8px}.run-item{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:12px 13px;border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:none;cursor:pointer}.run-item:hover{filter:none;border-color:#cbd5e1;background:#f8fafc}.run-item.on{border-color:var(--brand);background:#f5f5ff;box-shadow:0 0 0 2px color-mix(in srgb,var(--brand) 18%,transparent)}.run-period{font-weight:700;color:var(--ink)}.run-meta{font-size:12px;color:var(--muted);margin-top:2px}input[type=checkbox],input[type=radio]{width:18px;height:18px;min-width:18px;-moz-appearance:auto;appearance:auto;-webkit-appearance:auto;accent-color:var(--brand);cursor:pointer;padding:0;box-shadow:none}.bulk-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(135deg,#eef2ff,#f5f3ff);border:1px solid #dfe3ff;border-radius:12px;padding:10px 14px;margin-bottom:14px}.bulk-count{font-weight:700;color:var(--brand)}.bulk-actions{display:flex;align-items:center;gap:10px}.bulk-actions select{width:auto;min-width:180px;height:38px}.bulk-actions button{padding:8px 16px}.emp-check{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.emp-card.sel{border-color:var(--brand);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand) 20%,transparent)}tbody tr.row-sel td{background:#f5f5ff}.view-toggle{display:inline-flex;background:#eef1f6;border-radius:10px;padding:3px;gap:2px}.view-toggle button{background:none;box-shadow:none;color:var(--muted);padding:6px 9px;border-radius:8px}.view-toggle button:hover{filter:none;color:var(--ink)}.view-toggle button.on{background:#fff;color:var(--brand);box-shadow:0 1px 3px #0f172a1a}.avatar-lg{width:56px;height:56px;flex:0 0 56px;border-radius:16px;display:grid;place-items:center;color:#fff;font-size:18px;font-weight:700}.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}.emp-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 1px 2px #0f172a0a,0 10px 30px #0f172a09;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column}.emp-card:hover{box-shadow:0 14px 40px #0f172a1a;transform:translateY(-3px)}.emp-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.emp-card-name{font-size:17px;font-weight:700;letter-spacing:-.01em}.emp-card-role{font-size:13px;color:var(--muted);margin-top:2px;display:flex;justify-content:space-between;gap:8px}.emp-card-role .emp-code{color:#94a3b8;font-weight:600}.emp-card-meta{margin:14px 0;padding-top:14px;border-top:1px solid var(--line);display:grid;gap:9px}.emp-card-meta>div{display:flex;align-items:center;gap:9px;font-size:13px;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-card-meta svg{color:var(--brand);flex:0 0 auto}.emp-card-edit{width:100%;justify-content:center;margin-top:auto}.leaflet-container{z-index:0!important}.leaflet-tooltip.ping-num{background:transparent;border:0;box-shadow:none;color:#fff;font-weight:700;font-size:10px;padding:0}.leaflet-tooltip.ping-num:before{display:none}.dp{position:relative}.dp-trigger{display:inline-flex;align-items:center;gap:9px;width:100%;height:42px;padding:0 13px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--ink);font-size:14px;font-weight:600;cursor:pointer;box-shadow:none;transition:border-color .15s,box-shadow .15s}.dp-trigger:hover{filter:none;border-color:#cbd5e1}.dp-trigger.open{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%,transparent)}.dp-trigger svg{color:var(--brand)}.dp-trigger .ph{color:#aab4c4;font-weight:400}.dp-pop{position:absolute;z-index:1200;top:calc(100% + 8px);left:0;width:300px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px 18px;box-shadow:0 24px 60px #0f172a33;animation:dp-in .14s ease}@keyframes dp-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.dp-title{font-weight:700;font-size:16px}.dp-nav{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;cursor:pointer;background:none;color:#334155;border:0;font-size:22px;line-height:1;box-shadow:none;padding:0}.dp-nav:hover{background:#f1f5f9;color:var(--brand);filter:none}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.dp-wd{margin-bottom:6px}.dp-wdc{text-align:center;font-size:13px;font-weight:500;color:var(--muted);padding:2px 0}.dp-day{aspect-ratio:1;display:grid;place-items:center;border:0;background:none;cursor:pointer;border-radius:12px;font-size:15px;font-weight:500;color:var(--ink);box-shadow:none;padding:0}.dp-day:hover{background:#eef2ff;filter:none}.dp-day.today{color:var(--brand);font-weight:800}.dp-day.sel{background:var(--brand);color:#fff;font-weight:700;box-shadow:0 6px 16px #4f46e573}.dp-day.sel.today{color:#fff}.dp-day:disabled{color:#cbd5e1;cursor:not-allowed}.dp-day:disabled:hover{background:none}.dp-foot{display:flex;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.dp-link{background:none;box-shadow:none;color:var(--brand);font-weight:600;font-size:15px;padding:4px 6px}.dp-link:hover{background:#f5f5ff;filter:none}.dp-link:disabled{color:#cbd5e1}.mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.mp-month{padding:12px 0;border-radius:12px;border:0;background:#f8fafc;color:var(--ink);font-size:14px;font-weight:600;cursor:pointer;box-shadow:none}.mp-month:hover{background:#eef2ff;filter:none}.mp-month.sel{background:var(--brand);color:#fff;box-shadow:0 6px 16px #4f46e573}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:20px}.modal{background:var(--card);border-radius:14px;width:640px;max-width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #00000040}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card)}.modal-head h3{margin:0}.modal-body{padding:20px}.modal .close{background:none;color:var(--muted);font-size:22px;padding:0 6px;line-height:1}.subhead{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:18px 0 10px;border-top:1px solid var(--line);padding-top:14px}.link-btn{background:none;color:var(--brand);padding:4px 6px;font-size:13px}.ok-note{color:var(--ok);font-size:13px;margin:8px 0}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:11px 12px;border-bottom:1px solid var(--line)}td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}tbody tr:last-child td{border-bottom:0}tbody tr{transition:background .12s}tbody tr:hover td{background:#f8fafc}h2{margin:0 0 16px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}.badge.green{background:#dcfce7;color:var(--ok)}.badge.amber{background:#fef3c7;color:var(--warn)}.badge.red{background:#fee2e2;color:var(--bad)}.badge.gray{background:#e2e8f0;color:var(--muted)}button{background:var(--brand);color:#fff;border:0;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #4f46e540;transition:filter .15s,box-shadow .15s,background .15s}button:hover{filter:brightness(1.06)}button.ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none;font-weight:500}button.ghost:hover{background:#f8fafc;filter:none}button.ok{background:var(--ok);box-shadow:0 4px 12px #16a34a40}button.bad{background:var(--bad);box-shadow:0 4px 12px #dc262638}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.icon-btn,.link-btn,.close,.signout{box-shadow:none;font-weight:500}.icon-btn:hover,.link-btn:hover,.close:hover,.signout:hover{filter:none}input,select,textarea{width:100%;height:42px;padding:0 13px;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:10px;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:border-color .15s,box-shadow .15s,background .15s}textarea{height:auto;padding:10px 13px}input::placeholder{color:#aab4c4}input:hover,select:hover,textarea:hover{border-color:#cbd5e1}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%,transparent)}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px;cursor:pointer}select:invalid,select option[value=""]{color:#aab4c4}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=date]::-webkit-calendar-picker-indicator{opacity:.55;cursor:pointer}label{font-size:12.5px;font-weight:500;color:var(--muted);display:block;margin-bottom:6px}.field{margin-bottom:16px}.row{display:flex;gap:16px;flex-wrap:wrap}.row>*{flex:1;min-width:140px}.err{color:var(--bad);font-size:13px;margin:8px 0}.auth{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}@media (max-width: 860px){.auth{grid-template-columns:1fr}.auth-brand{display:none}}.auth-brand{position:relative;overflow:hidden;color:#fff;background:linear-gradient(135deg,#1e1b4b,#4f46e5 55%,#6366f1);display:flex;align-items:center;padding:56px}.auth-brand-inner{position:relative;z-index:2;max-width:420px}.auth-logo{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:#ffffff26;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);margin-bottom:26px}.auth-brand h1{font-size:38px;font-weight:800;margin:0 0 14px;letter-spacing:-.02em}.auth-tag{font-size:17px;line-height:1.5;color:#ffffffd9;margin:0 0 30px}.auth-points{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.auth-points li{display:flex;align-items:center;gap:12px;font-size:15px;color:#ffffffeb}.auth-points svg{padding:7px;background:#ffffff24;border-radius:9px;box-sizing:content-box}.auth-orb{position:absolute;border-radius:50%;filter:blur(8px);opacity:.35}.auth-orb-1{width:340px;height:340px;background:#818cf8;right:-90px;top:-90px}.auth-orb-2{width:260px;height:260px;background:#c7d2fe;left:-80px;bottom:-80px;opacity:.25}.auth-form-side{display:grid;place-items:center;padding:40px;background:var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:0 20px 60px #0f172a14}.auth-card h2{margin:0 0 4px;font-size:24px;font-weight:800;letter-spacing:-.02em}.auth-sub{color:var(--muted);font-size:14px;margin-bottom:24px}.btn-block{width:100%;margin-top:6px;padding:12px}.auth-foot{text-align:center;color:var(--muted);font-size:12px;margin-top:18px}.input-wrap{position:relative}.input-affix{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;box-shadow:none;color:var(--brand);font-weight:600;font-size:13px;padding:6px 8px}.input-affix:hover{filter:none;background:#f5f5ff}
