:root,[data-theme=night]{--bg-main:#071c45;--sidebar:#0b2658;--blue-primary:#06c;--blue-secondary:#2896ff;--gold-primary:#d4a63a;--gold-light:#f0c75e;--text-main:#f5f7fa;--gray-light:#d9dee7;--success:#2dbf7f;--danger:#ff8a8a;--on-accent:#021b4d;--card-bg:#1060b81f;--glass-bg:#ffffff14;--glass-border:#ffffff1f;--shadow:0 10px 40px #00000059;--shadow-blue:0 10px 30px #0066cc26;--shadow-gold:0 0 18px #f0c75e2e;--shell-accent-a:#1c8dff1f;--shell-accent-b:#d4a63a14;--header-bg:#071c45f5;--header-border:var(--blue-primary);--sidebar-border:#0066cc73;--menu-hover-bg:#1c8dff2e;--menu-active-bg:var(--blue-primary);--surface-soft:#ffffff08;--surface-muted:#ffffff06;--surface-border:#0066cc47;--surface-border-strong:#0066cc73;--icon-btn-bg:#ffffff0a;--icon-btn-hover-bg:#f0c75e14;--field-bg:#ffffff0d;--field-bg-focus:#ffffff14;--field-border:#d9dee71f;--field-placeholder:#d9dee7bf;--field-focus-ring:0 0 0 4px #1c8dff1f;--overlay-bg:#071c45d1;--toast-bg:#071c45f5;--table-head-bg:var(--blue-primary);--table-row-even:#ffffff05;--table-row-hover:#1c8dff14;--footer-border:#ffffff14;--transition:.3s ease;font-size:14px}[data-theme=day]{--bg-main:#f2f5f9;--sidebar:#edf3fb;--blue-primary:#2664aa;--blue-secondary:#2d6fb7;--gold-primary:#b78624;--gold-light:#c8973a;--text-main:#1f2a36;--gray-light:#5f6b78;--success:#2a8f62;--danger:#c25656;--on-accent:#1f2a36;--card-bg:#ffffffeb;--glass-bg:#ffffffe6;--glass-border:#2664aa24;--shadow:0 12px 30px #15263d1f;--shadow-blue:0 10px 24px #2664aa1f;--shadow-gold:0 0 18px #b8862433;--shell-accent-a:#2664aa14;--shell-accent-b:#b8862414;--header-bg:#f6f9fdf2;--header-border:#2664aa38;--sidebar-border:#2664aa2e;--menu-hover-bg:#2664aa1f;--menu-active-bg:#2664aa2e;--surface-soft:#ffffffbf;--surface-muted:#f7faffe6;--surface-border:#2664aa33;--surface-border-strong:#2664aa47;--icon-btn-bg:#2664aa14;--icon-btn-hover-bg:#b8862429;--field-bg:#fffffff5;--field-bg-focus:#fff;--field-border:#2664aa40;--field-placeholder:#5f6b78cc;--field-focus-ring:0 0 0 4px #2664aa24;--overlay-bg:#2b3c527a;--toast-bg:#fffffffa;--table-head-bg:#2664aa2e;--table-row-even:#2664aa0d;--table-row-hover:#2664aa1f;--footer-border:#2664aa29}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--text-main);background:var(--bg-main);font-family:Inter,sans-serif;font-size:.875rem;line-height:1.45;overflow-x:hidden}button,input,select,textarea{font:inherit}button{border:0}a{color:inherit;text-decoration:none}#app{min-height:100vh}.auth-page{background:radial-gradient(circle at top left, var(--shell-accent-a) 0%, var(--bg-main) 45%);min-height:100vh;color:var(--text-main);position:relative;overflow-x:hidden}.auth-page:before,.auth-page:after{content:"";filter:blur(90px);opacity:.25;z-index:0;border-radius:50%;position:absolute}.auth-page:before{background:var(--blue-secondary);width:300px;height:300px;top:-120px;left:-100px}.auth-page:after{background:var(--gold-primary);width:260px;height:260px;bottom:-120px;right:-80px}.container{z-index:2;flex-direction:column;min-height:100vh;padding:28px 54px;display:flex;position:relative}.header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.logo{align-items:center;gap:14px;display:flex}.gem{background:linear-gradient(135deg, var(--blue-primary), var(--blue-secondary));border-radius:4px;width:20px;height:20px;transform:rotate(45deg);box-shadow:0 0 12px #1c8dff80}.logo h1{color:var(--gold-primary);letter-spacing:0;text-shadow:0 2px 8px #d4a63a40;font-size:1.45rem;font-weight:700}.main{flex:1;justify-content:space-between;align-items:center;gap:48px;display:flex}.left-content{max-width:540px}.tag{background:var(--surface-soft);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:999px;align-items:center;gap:10px;margin-bottom:20px;padding:8px 13px;display:inline-flex}.tag-dot{background:var(--gold-light);border-radius:50%;width:10px;height:10px;box-shadow:0 0 10px #f0c75e99}.tag span{color:var(--gray-light);font-size:.82rem}.left-content h2{margin-bottom:20px;font-size:2.7rem;font-weight:700;line-height:1.1}.left-content h2 span{color:var(--gold-light)}.left-content p{color:var(--gray-light);max-width:480px;font-size:.95rem;line-height:1.65}.diamond-art{width:96px;height:96px;margin-top:34px;position:relative}.diamond-art:before,.diamond-art:after{content:"";border-radius:18px;position:absolute;inset:0;transform:rotate(45deg)}.diamond-art:before{background:linear-gradient(135deg,#f0c75e26,#d4a63a59);border:1px solid #f0c75e4d}.diamond-art:after{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;inset:20px}.login-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:380px;box-shadow:var(--shadow);border-radius:18px;padding:30px}.login-card h3{margin-bottom:22px;font-size:1.35rem;font-weight:600}.form-group{margin-bottom:16px}.form-group label{color:var(--gray-light);margin-bottom:7px;font-size:.82rem;display:block}.form-control{background:var(--field-bg);border:1px solid var(--field-border);width:100%;color:var(--text-main);border-radius:10px;outline:none;padding:11px 13px;font-size:.9rem;transition:all .3s}.form-control::placeholder{color:var(--field-placeholder)}.form-control:focus{border-color:var(--blue-secondary);box-shadow:var(--field-focus-ring);background:var(--field-bg-focus)}.forgot{color:var(--blue-secondary);margin-top:8px;font-size:.82rem;transition:all .25s;display:inline-block}.forgot:hover{opacity:.8}.form-error{color:var(--gold-light);margin-top:-4px;font-size:.82rem;line-height:1.5}.btn-login{cursor:pointer;background:var(--gold-primary);width:100%;color:var(--on-accent);border-radius:10px;margin-top:20px;padding:12px;font-size:.9rem;font-weight:600;transition:all .3s;box-shadow:0 8px 20px #d4a63a47}.btn-login:hover:not(:disabled){background:var(--gold-light);transform:translateY(-2px);box-shadow:0 12px 24px #f0c75e59}.btn-login:disabled{cursor:not-allowed;opacity:.65}@media (width<=980px){.main{text-align:center;flex-direction:column;justify-content:center}.left-content{flex-direction:column;align-items:center;display:flex}.left-content h2{font-size:2.25rem}.login-card{width:100%;max-width:380px}}@media (width<=640px){.container{padding:20px}.header{margin-bottom:24px}.left-content h2{font-size:1.75rem}.login-card{padding:24px 20px}}.dashboard-shell{background:radial-gradient(circle at top left, var(--shell-accent-a), transparent 25%), radial-gradient(circle at bottom right, var(--shell-accent-b), transparent 20%), var(--bg-main);min-height:100vh;color:var(--text-main)}.dashboard-shell header{background:var(--header-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid var(--header-border);z-index:999;justify-content:space-between;align-items:center;width:100%;height:62px;padding:0 20px;display:flex;position:fixed;top:0;left:0}.logo-area{align-items:center;gap:12px;display:flex}.menu-toggle{cursor:pointer;width:24px;min-width:24px;color:var(--gray-light);transition:var(--transition);background:0 0;font-size:1rem}.menu-toggle:hover{color:var(--gold-light)}.logo-gem{background:linear-gradient(135deg, var(--blue-primary), var(--blue-secondary));border-radius:4px;width:16px;height:16px;transform:rotate(45deg);box-shadow:0 0 12px #1c8dff80}.logo-text{color:var(--gold-primary);text-shadow:0 0 12px #d4a63a40;font-size:1.2rem;font-weight:700}.top-actions{align-items:center;gap:12px;display:flex}.user-box{color:var(--text-main);cursor:pointer;background:0 0;align-items:center;gap:10px;margin-right:4px;display:flex}.session-countdown{border:1px solid var(--surface-border);background:var(--surface-soft);color:var(--gray-light);white-space:nowrap;transition:var(--transition);border-radius:999px;padding:5px 9px;font-size:.78rem;font-weight:600}.session-countdown.warning{color:var(--gold-light);background:#d4a63a26;border-color:#d4a63a8c}.session-countdown.expired{color:var(--gold-light);box-shadow:var(--shadow-gold);background:#f0c75e33;border-color:#f0c75ea6}.avatar{background:linear-gradient(135deg, var(--gold-primary), var(--gold-light));width:34px;height:34px;color:var(--on-accent);box-shadow:var(--shadow-gold);object-fit:cover;border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.avatar-image{background:0 0}.icon-btn{background:var(--icon-btn-bg);cursor:pointer;width:34px;height:34px;transition:var(--transition);color:var(--gray-light);border-radius:10px;justify-content:center;align-items:center;display:flex}.icon-btn:hover{color:var(--gold-light);background:var(--icon-btn-hover-bg);box-shadow:var(--shadow-gold)}.theme-toggle{gap:7px;width:auto;padding:0 10px}.theme-toggle span{font-size:.78rem;font-weight:600}.logout{color:var(--gold-primary)}.layout{min-height:100vh;padding-top:62px;display:flex}.dashboard-shell aside{background:var(--sidebar);border-right:1px solid var(--sidebar-border);width:230px;transition:var(--transition);z-index:100;height:calc(100vh - 62px);position:fixed;top:62px;left:0;overflow:hidden}.dashboard-shell aside.collapsed{width:62px}.menu{padding:16px 10px}.menu-item{color:var(--text-main);transition:var(--transition);border-radius:10px;align-items:center;gap:12px;margin-bottom:7px;padding:11px 12px;display:flex;position:relative;overflow:hidden}.menu-item i{min-width:18px;color:var(--gray-light);font-size:.92rem}.menu-item span{white-space:nowrap;transition:var(--transition);font-size:.88rem}.dashboard-shell aside.collapsed .menu-item span{opacity:0;visibility:hidden}.menu-item:hover{background:var(--menu-hover-bg)}.menu-item.active{background:var(--menu-active-bg);box-shadow:var(--shadow-blue)}.menu-item.active:before{content:"";background:var(--gold-primary);width:3px;height:100%;position:absolute;top:0;left:0}.menu-item.disabled{cursor:default}.dashboard-shell main{width:100%;transition:var(--transition);margin-left:230px;padding:22px}.dashboard-shell main.expanded{margin-left:62px}.page-header{margin-bottom:18px}.page-header h1{margin-bottom:5px;font-size:1.25rem}.page-header p{color:var(--gray-light);font-size:.88rem}.profile-page-header{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.refresh-action,.ghost-action{cursor:pointer;transition:var(--transition);border-radius:10px;justify-content:center;align-items:center;gap:6px;font-weight:600;display:inline-flex}.refresh-action{background:var(--gold-primary);min-height:34px;color:var(--on-accent);padding:0 12px;box-shadow:0 8px 20px #d4a63a2e}.refresh-action:hover:not(:disabled){background:var(--gold-light);box-shadow:var(--shadow-gold)}.refresh-action:disabled{opacity:.65;cursor:not-allowed}.profile-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;display:grid}.profile-card{background:var(--card-bg);border:1px solid var(--surface-border-strong);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-blue);border-radius:14px;flex-direction:column;grid-column:span 4;align-self:stretch;padding:16px;display:flex}.profile-card-full{grid-column:1/-1}.profile-card-full .info-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.users-list{grid-template-columns:1fr;gap:12px;display:grid}.users-list-item{display:block}.users-list-item .profile-card{width:100%;min-height:unset;grid-column:auto}.users-list-item .profile-card-header{margin-bottom:8px}.users-list-item .profile-card h2{margin-top:4px;font-size:1rem}.users-list-item .trend{margin-bottom:10px}.user-card-actions,.profile-card-footer{flex-wrap:wrap;justify-content:flex-end;gap:9px;margin-top:auto;display:flex}.profile-card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.ghost-action{background:var(--icon-btn-bg);min-height:30px;color:var(--blue-secondary);padding:0 10px;font-size:.82rem}.ghost-action:hover{color:var(--gold-light);background:var(--icon-btn-hover-bg);box-shadow:var(--shadow-gold)}.ghost-action:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.ghost-action.danger{color:var(--gold-primary)}.cancel-action{justify-content:center;min-width:92px}.modal-actions{align-items:center}.modal-actions .modal-action-btn,.modal-actions .reauth-submit.modal-action-btn{justify-content:center;align-items:center;width:92px;min-width:92px;height:42px;min-height:42px;margin-top:0;padding:0 12px;display:inline-flex}.field-hint{color:var(--gray-light);margin-top:6px;font-size:.76rem;line-height:1.4}.field-hint.error{color:var(--gold-light)}.info-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;display:grid}.info-field{border:1px solid var(--surface-border);background:var(--surface-soft);border-radius:10px;min-width:0;padding:9px 10px}.info-field span,.process-item span{color:var(--gray-light);margin-bottom:4px;font-size:.76rem;display:block}.info-field strong,.process-item strong{overflow-wrap:anywhere;color:var(--text-main);font-size:.9rem;font-weight:600;display:block}.stack-list,.process-list,.access-section{gap:10px;display:grid}.stack-item,.process-item{border:1px solid var(--surface-border);background:var(--surface-soft);border-radius:11px;gap:8px;padding:10px;display:grid}.stack-item{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.compact-summary{gap:5px;min-width:0;display:grid}.compact-summary strong{color:var(--text-main);text-transform:capitalize;font-size:1rem;font-weight:700}.compact-summary span{color:var(--gray-light);overflow-wrap:anywhere}.process-item{grid-template-columns:minmax(0,1fr) auto;align-items:center}.process-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:9px;display:flex}.profile-card .card-title{font-size:.9rem;font-weight:600}.profile-card .card-icon{border-radius:10px;width:34px;height:34px;font-size:.95rem}.access-section h4{margin-bottom:8px;font-size:.9rem}.badge-list{flex-wrap:wrap;gap:7px;display:flex}.empty-state{border:1px solid var(--surface-border);background:var(--surface-muted);min-height:52px;color:var(--gray-light);border-radius:11px;align-items:center;gap:10px;padding:12px;display:flex}.empty-state i{color:var(--gold-primary)}.json-debug{background:var(--surface-soft);border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;margin-top:14px;overflow:hidden}.json-debug summary{cursor:pointer;color:var(--blue-secondary);padding:12px 16px;font-weight:600}.json-debug pre{color:var(--gray-light);white-space:pre-wrap;margin:0;padding:0 16px 16px;font-size:.78rem;line-height:1.5;overflow-x:auto}.reauth-backdrop{z-index:2000;background:var(--overlay-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.reauth-modal{background:var(--glass-bg);border:1px solid var(--glass-border);width:min(460px,100%);box-shadow:var(--shadow);border-radius:16px;padding:22px}.reauth-header{justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px;display:flex}.reauth-kicker{color:var(--gold-light);margin-bottom:5px;font-size:.78rem;font-weight:600;display:block}.reauth-header h2{font-size:1.15rem}.reauth-icon{flex:none}.reauth-copy{color:var(--gray-light);font-size:.88rem;line-height:1.55}.reauth-timer{border:1px solid var(--surface-border);background:var(--surface-soft);border-radius:11px;justify-content:space-between;align-items:center;margin:14px 0 18px;padding:10px 12px;display:flex}.reauth-timer span{color:var(--gray-light)}.reauth-timer strong{color:var(--text-main);font-size:1rem}.reauth-timer.warning,.reauth-timer.expired{background:#d4a63a1f;border-color:#d4a63a8c}.reauth-form .btn-login{margin-top:0}.reauth-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.reauth-submit{width:auto;min-width:142px}.cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:22px;display:grid}.card{background:var(--card-bg);border:1px solid var(--surface-border-strong);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:var(--transition);box-shadow:var(--shadow-blue);border-radius:14px;padding:16px}.card:hover{border-color:var(--gold-primary);transform:translateY(-4px)}.card-top{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--gray-light);font-size:.84rem}.card-icon{background:var(--surface-soft);width:38px;height:38px;color:var(--blue-secondary);border-radius:11px;justify-content:center;align-items:center;font-size:1rem;display:flex}.card h2{margin-bottom:8px;font-size:1.35rem}.trend{color:var(--gold-primary);margin-bottom:12px;font-weight:600}.progress{background:#ffffff14;border-radius:999px;width:100%;height:10px;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--blue-secondary), var(--blue-primary));border-radius:999px;width:72%;height:100%}.card button{cursor:pointer;background:var(--gold-primary);color:var(--on-accent);transition:var(--transition);border-radius:10px;margin-top:14px;padding:9px 12px;font-weight:600}.card button:hover{background:var(--gold-light);box-shadow:var(--shadow-gold)}.table-container{background:var(--surface-soft);border:1px solid var(--surface-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;overflow:hidden}.table-header{justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.table-header h3{font-size:1rem}.table-header button{color:var(--blue-secondary);cursor:pointer;transition:var(--transition);background:0 0;font-weight:600}.table-header button:hover{color:var(--gold-light)}.dashboard-shell table{border-collapse:collapse;width:100%}.dashboard-shell thead{background:var(--table-head-bg)}.dashboard-shell thead th{text-align:left;padding:11px 14px;font-weight:600}.dashboard-shell tbody tr{transition:var(--transition)}.dashboard-shell tbody tr:nth-child(2n){background:var(--table-row-even)}.dashboard-shell tbody tr:hover{background:var(--table-row-hover)}.dashboard-shell tbody td{color:var(--gray-light);padding:11px 14px}.status{border-radius:999px;padding:5px 9px;font-size:.76rem;font-weight:600;display:inline-block}.status.success{color:var(--success);background:#2dbf7f26}.status.pending{color:var(--gold-primary);background:#d4a63a26}.status.danger{color:var(--danger);background:#e64a4a24}.user-status-icon.active{color:var(--success);background:#2dbf7f26}.user-status-icon.inactive{color:var(--danger);background:#e64a4a24}.app-toast-stack{z-index:10000;pointer-events:none;flex-direction:column;gap:10px;width:min(420px,100vw - 32px);display:flex;position:fixed;top:18px;right:18px}.app-toast{border:1px solid var(--glass-border);background:var(--toast-bg);box-shadow:var(--shadow);color:var(--text-main);pointer-events:auto;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:12px 14px;display:grid}.app-toast p{color:var(--gray-light);margin:0}.app-toast button{background:var(--icon-btn-bg);width:28px;height:28px;color:var(--gray-light);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.app-toast-success{border-color:#2dbf7f73}.app-toast-success>i{color:var(--success)}.app-toast-error{border-color:#e64a4a73}.app-toast-error>i{color:var(--danger)}.pagination-bar{color:var(--gray-light);justify-content:space-between;align-items:center;gap:12px;margin-top:14px;display:flex}.pagination-actions,.assignment-item{align-items:center;gap:10px;display:flex}.assignment-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.assignment-grid .profile-card{grid-column:auto}.assignment-item{border:1px solid var(--surface-border);background:var(--surface-soft);border-radius:11px;justify-content:space-between;padding:10px}.assignment-item strong,.assignment-item span{display:block}.assignment-item span{color:var(--gray-light);margin-top:4px;font-size:.78rem}.table-actions{gap:9px;display:flex}.table-actions i{cursor:pointer;transition:var(--transition)}.table-actions i:hover{color:var(--gold-light)}.user-details pre{color:var(--gray-light);white-space:pre-wrap;margin:0;padding:0 16px 16px;line-height:1.6;overflow-x:auto}.dashboard-shell footer{color:var(--gray-light);border-top:1px solid var(--footer-border);justify-content:space-between;align-items:center;margin-top:28px;padding:16px 8px;font-size:.82rem;display:flex}.footer-links{gap:20px;display:flex}.footer-links a{transition:var(--transition)}.footer-links a:hover{color:var(--gold-light)}@media (width<=980px){.dashboard-shell aside{width:62px}.dashboard-shell aside .menu-item span{display:none}.dashboard-shell main{margin-left:62px}.top-actions .user-box span{display:none}.top-actions .user-box .session-countdown{display:inline-flex}}@media (width<=768px){.dashboard-shell header{padding:0 16px}.logo-text{font-size:1.05rem}.top-actions{gap:10px}.theme-toggle span{display:none}.session-countdown{display:none!important}.reauth-modal{padding:20px}.reauth-actions{flex-direction:column-reverse}.reauth-submit,.reauth-actions .ghost-action{width:100%}.cards{grid-template-columns:1fr}.profile-page-header,.profile-card-header{flex-direction:column;align-items:flex-start}.profile-grid,.assignment-grid,.info-grid,.stack-item,.users-list-item{grid-template-columns:1fr}.profile-card,.profile-card-full{grid-column:1/-1}.table-container{overflow-x:auto}.dashboard-shell footer{text-align:center;flex-direction:column;gap:14px}}
