:root{--bg: #f6f7f9;--surface: #ffffff;--surface-2: #f1f3f5;--border: #e3e6ea;--border-strong: #d2d7dd;--fg: #14181f;--fg-muted: #5b6470;--fg-subtle: #8c95a1;--primary: #0b6bcb;--primary-fg: #ffffff;--primary-soft: #e7f1fb;--success: #1f9d57;--success-soft: #e4f6ec;--warning: #c77700;--warning-soft: #fdf2dd;--danger: #d4351c;--danger-soft: #fbe7e4;--info: #5b6470;--info-soft: #eef0f2;--radius: 10px;--radius-sm: 7px;--shadow-sm: 0 1px 2px rgba(16,24,40,.05);--shadow: 0 1px 3px rgba(16,24,40,.08), 0 1px 2px rgba(16,24,40,.04);--shadow-lg: 0 12px 32px -8px rgba(16,24,40,.18);--sidebar-w: 248px;--font: "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif}:root[data-theme=dark]{--bg: #0e1116;--surface: #161b22;--surface-2: #1d2430;--border: #272e3a;--border-strong: #3a4350;--fg: #e7ebf0;--fg-muted: #9aa4b2;--fg-subtle: #6b7582;--primary: #4a93e8;--primary-fg: #ffffff;--primary-soft: #15314f;--success: #45c277;--success-soft: #133526;--warning: #e0a13b;--warning-soft: #3a2c12;--danger: #f0705a;--danger-soft: #3a1d1a;--info: #9aa4b2;--info-soft: #232b36;--callout-warn-bd: #5a4316;--callout-warn-fg: #f0c674;--callout-info-bd: #2a4d72;--callout-info-fg: #9fc7f3;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow: 0 1px 3px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.4);--shadow-lg: 0 16px 40px -10px rgba(0,0,0,.65);color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 16px;border-bottom:1px solid var(--border)}.brand .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--primary),#0a4f99);display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;box-shadow:var(--shadow-sm)}.brand .name{font-weight:700;font-size:15px;letter-spacing:.02em}.brand .sub{font-size:11px;color:var(--fg-subtle)}.nav{padding:10px;overflow-y:auto;flex:1}.nav .group-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--fg-subtle);font-weight:600;padding:14px 10px 6px}.nav a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--fg-muted);font-weight:500;margin-bottom:1px}.nav a:hover{background:var(--surface-2);color:var(--fg)}.nav a.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.nav a .ic{width:18px;height:18px;flex:0 0 18px;opacity:.9}.nav a .badge{margin-left:auto}.sidebar .user{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border)}.avatar{width:34px;height:34px;border-radius:50%;background:var(--surface-2);color:var(--fg-muted);display:grid;place-items:center;font-weight:600;font-size:13px;border:1px solid var(--border)}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:60px;flex:0 0 60px;background:var(--surface);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 26px;position:sticky;top:0;z-index:5}.topbar .crumbs{color:var(--fg-subtle);font-size:13px}.topbar .crumbs b{color:var(--fg);font-weight:600}.topbar .spacer{flex:1}.search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:7px 12px;width:280px;color:var(--fg-subtle);font-size:13px}.search input{border:0;background:transparent;outline:none;flex:1;font:inherit;color:var(--fg)}.content{padding:26px;max-width:1180px;width:100%;margin:0 auto}.page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:22px}.page-head .titles h1{font-size:21px}.page-head .titles p{margin:3px 0 0;color:var(--fg-muted);font-size:13.5px}.page-head .actions{margin-left:auto;display:flex;gap:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:18px 20px}.card-head{display:flex;align-items:center;gap:10px;padding:15px 20px;border-bottom:1px solid var(--border)}.card-head h3{font-size:14.5px}.card-head .sub{color:var(--fg-subtle);font-size:12.5px}.card-head .actions{margin-left:auto;display:flex;gap:8px}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 960px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}.stat{padding:16px 18px}.stat .label{color:var(--fg-muted);font-size:12.5px;font-weight:500;display:flex;align-items:center;gap:7px}.stat .value{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-top:6px}.stat .delta{font-size:12px;margin-top:4px;color:var(--fg-subtle)}.stat .delta.up{color:var(--success)}.stat .delta.down{color:var(--danger)}.stat .ic-box{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;float:right}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;line-height:1;padding:4px 9px;border-radius:999px;background:var(--info-soft);color:var(--info);border:1px solid transparent}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.green{background:var(--success-soft);color:var(--success)}.badge.amber{background:var(--warning-soft);color:var(--warning)}.badge.red{background:var(--danger-soft);color:var(--danger)}.badge.blue{background:var(--primary-soft);color:var(--primary)}.badge.outline{background:transparent;border-color:var(--border-strong);color:var(--fg-muted)}.role-tag{display:inline-flex;align-items:center;font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 7px;border-radius:6px;background:var(--surface-2);color:var(--fg-muted);border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;gap:7px;font:inherit;font-weight:600;font-size:13px;padding:8px 14px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--fg);cursor:pointer;box-shadow:var(--shadow-sm);white-space:nowrap;transition:background .12s,border-color .12s}.btn:hover{background:var(--surface-2)}.btn .ic{width:16px;height:16px}.btn.primary{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}.btn.primary:hover{background:#0a5cb0}.btn.ghost{border-color:transparent;box-shadow:none;background:transparent;color:var(--fg-muted)}.btn.ghost:hover{background:var(--surface-2);color:var(--fg)}.btn.danger{color:var(--danger);border-color:var(--danger-soft)}.btn.danger:hover{background:var(--danger-soft)}.btn.sm{padding:6px 10px;font-size:12.5px}.btn.icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}table.tbl th{text-align:left;font-weight:600;color:var(--fg-muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:11px 16px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface)}table.tbl td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}table.tbl tbody tr:hover{background:var(--surface-2)}table.tbl tbody tr:last-child td{border-bottom:0}.cell-main{font-weight:600}.cell-sub{color:var(--fg-subtle);font-size:12px}.id-mono{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:12.5px;color:var(--fg-muted)}.person{display:flex;align-items:center;gap:11px}.table-toolbar{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border)}.table-foot{display:flex;align-items:center;gap:10px;padding:12px 16px;color:var(--fg-muted);font-size:12.5px}.table-foot .spacer{flex:1}.field{margin-bottom:15px}.field label{display:block;font-weight:600;font-size:12.5px;margin-bottom:6px;color:var(--fg)}.field .hint{color:var(--fg-subtle);font-size:12px;margin-top:5px}.input,.select{width:100%;font:inherit;font-size:14px;padding:9px 12px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--fg);outline:none}.input:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.input::placeholder{color:var(--fg-subtle)}.divider{height:1px;background:var(--border);margin:16px 0}.kv{display:grid;grid-template-columns:150px 1fr;gap:10px 14px;font-size:13.5px}.kv dt{color:var(--fg-muted)}.kv dd{margin:0;font-weight:500}.muted{color:var(--fg-muted)}.subtle{color:var(--fg-subtle)}.right{text-align:right}.flex{display:flex;align-items:center;gap:10px}.flex.wrap{flex-wrap:wrap}.gap-sm{gap:6px}.mt{margin-top:16px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);padding:0 4px}.tabs a{padding:11px 14px;font-weight:600;font-size:13.5px;color:var(--fg-muted);border-bottom:2px solid transparent;margin-bottom:-1px}.tabs a:hover{color:var(--fg)}.tabs a.active{color:var(--primary);border-bottom-color:var(--primary)}.progress{height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden}.progress>span{display:block;height:100%;background:var(--primary);border-radius:999px}.timeline{position:relative;padding-left:26px}.timeline:before{content:"";position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--border)}.timeline .ev{position:relative;padding-bottom:18px}.timeline .ev:before{content:"";position:absolute;left:-22px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--border-strong)}.timeline .ev.done:before{background:var(--success);border-color:var(--success)}.timeline .ev.active:before{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.timeline .ev .t{font-weight:600;font-size:13.5px}.timeline .ev .d{color:var(--fg-subtle);font-size:12px}.callout{display:flex;gap:11px;padding:13px 15px;border-radius:var(--radius-sm);background:var(--warning-soft);border:1px solid var(--callout-warn-bd, #f3dca8);color:var(--callout-warn-fg, #7a4d00);font-size:13px}.callout.info{background:var(--primary-soft);border-color:var(--callout-info-bd, #c5dcf5);color:var(--callout-info-fg, #0a4f99)}.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}@media (max-width: 880px){.auth-wrap{grid-template-columns:1fr}.auth-aside{display:none}}.auth-aside{background:radial-gradient(120% 120% at 80% 0%,#0b6bcb,#0a3f7a 55%,#07203f);color:#fff;padding:56px 52px;display:flex;flex-direction:column}.auth-aside .logo-lg{width:52px;height:52px;border-radius:13px;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;font-weight:700;font-size:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-aside h2{font-size:30px;margin-top:auto;line-height:1.2;letter-spacing:-.02em}.auth-aside p{color:#ffffffc7;font-size:15px;max-width:420px}.auth-aside .feats{margin-top:26px;display:grid;gap:12px}.auth-aside .feat{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;color:#ffffffe6}.auth-aside .feat .ck{width:20px;height:20px;border-radius:50%;background:#ffffff29;display:grid;place-items:center;flex:0 0 20px}.auth-main{display:grid;place-items:center;padding:30px}.auth-card{width:100%;max-width:372px}.auth-card .h{text-align:center;margin-bottom:26px}.auth-card .h h1{font-size:22px}.auth-card .h p{color:var(--fg-muted);margin-top:6px;font-size:13.5px}.otp{display:flex;gap:9px;justify-content:center}.otp input{width:46px;height:54px;text-align:center;font-size:22px;font-weight:700;border:1px solid var(--border-strong);border-radius:10px;background:var(--surface);outline:none;color:var(--fg)}.otp input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.otp input.filled{border-color:var(--primary)}.qr{width:168px;height:168px;border-radius:12px;border:1px solid var(--border);display:block;margin:0 auto;background:#fff;padding:10px}.gallery{max-width:1080px;margin:0 auto;padding:48px 26px}.gallery h1{font-size:26px}.gallery .lead{color:var(--fg-muted);margin:8px 0 30px;font-size:15px}.thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media (max-width: 880px){.thumbs{grid-template-columns:1fr 1fr}}.thumb{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s;display:block}.thumb:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.thumb .frame{height:158px;background:var(--surface-2);border-bottom:1px solid var(--border);position:relative;overflow:hidden}.thumb .frame .mini{position:absolute;top:0;right:0;bottom:0;left:0;padding:14px}.thumb .cap{padding:13px 15px}.thumb .cap h3{font-size:14.5px}.thumb .cap p{color:var(--fg-muted);font-size:12.5px;margin:4px 0 0}.theme-switch{position:relative}.theme-switch>button.trigger{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:38px;height:38px;padding:0;border-radius:8px;font-size:16px;border:1px solid var(--border-strong);background:var(--surface);color:var(--fg);cursor:pointer;box-shadow:var(--shadow-sm)}.theme-switch>button.trigger:hover{background:var(--surface-2)}.theme-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);padding:5px;min-width:168px;display:none}.theme-menu.open{display:block}.theme-menu .mlabel{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle);font-weight:600;padding:7px 10px 4px}.theme-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:7px;border:0;background:transparent;color:var(--fg);font:inherit;font-size:13.5px;font-weight:500;cursor:pointer;text-align:left}.theme-menu button:hover{background:var(--surface-2)}.theme-menu button .ck{margin-left:auto;color:var(--primary);opacity:0;font-weight:700}.theme-menu button[aria-checked=true] .ck{opacity:1}.theme-menu button[aria-checked=true]{color:var(--primary)}.theme-switch.floating{position:fixed;top:18px;right:18px;z-index:50}
