@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";.tt-filters{display:flex;gap:12px;margin-bottom:20px}.tt-filters select,.tt-filters button{padding:6px 10px}.break{background:#f3f4f6;text-align:center;font-weight:600;color:#6b7280}.muted{font-size:12px;color:#6b7280}.tt-student-summary ul{margin:8px 0 0;padding-left:18px}:root{--bg-0: #f0f4f9;--bg-1: #e8ecf2;--bg-2: #dfe5ed;--surface: rgba(255, 255, 255, .72);--surface-strong: rgba(255, 255, 255, .88);--surface-muted: rgba(219, 234, 254, .45);--text: #0f172a;--text-soft: #1e293b;--muted: #475569;--border: rgba(219, 234, 254, .6);--border-strong: rgba(147, 197, 253, .5);--primary: #2563eb;--primary-strong: #1d4ed8;--danger: #f43f5e;--ok: #10b981;--focus: #3b82f6;--shadow-1: 0 15px 35px rgba(30, 44, 76, .15);--shadow-2: 0 25px 50px rgba(15, 23, 42, .2);--glass-shadow: inset 0 1px 0 rgba(255, 255, 255, .5);--main-aurora-a: rgba(66, 130, 246, .16);--main-aurora-b: rgba(72, 177, 216, .12);--main-aurora-c: rgba(255, 255, 255, .22);--main-vignette-edge: rgba(84, 107, 146, .14);--main-noise-line-a: rgba(27, 65, 129, .045);--main-noise-line-b: rgba(27, 65, 129, .03);--radius-lg: 20px;--radius-md: 14px;--radius-sm: 10px}html.dark{--bg-0: #0f172a;--bg-1: #1a233e;--bg-2: #2d3a52;--surface: rgba(30, 41, 59, .7);--surface-strong: rgba(41, 57, 86, .85);--surface-muted: rgba(59, 130, 246, .1);--text: #f1f5f9;--text-soft: #e2e8f0;--muted: #cbd5e1;--border: rgba(100, 165, 255, .2);--border-strong: rgba(147, 197, 253, .35);--primary: #60a5fa;--primary-strong: #3b82f6;--danger: #f472b6;--ok: #34d399;--focus: #93c5fd;--shadow-1: 0 15px 40px rgba(0, 0, 0, .4);--shadow-2: 0 25px 60px rgba(0, 0, 0, .6);--glass-shadow: inset 0 1px 0 rgba(255, 255, 255, .1);--main-aurora-a: rgba(79, 130, 230, .12);--main-aurora-b: rgba(48, 133, 191, .1);--main-aurora-c: rgba(165, 204, 255, .06);--main-vignette-edge: rgba(3, 8, 23, .5);--main-noise-line-a: rgba(128, 174, 255, .05);--main-noise-line-b: rgba(128, 174, 255, .03)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:Manrope,Segoe UI,sans-serif;font-size:16px;line-height:1.5;color:var(--text);background:radial-gradient(1200px 900px at -10% -8%,rgba(118,170,255,.35),transparent 40%),radial-gradient(900px 600px at 110% -8%,rgba(116,120,255,.25),transparent 35%),radial-gradient(700px 500px at 50% 110%,rgba(93,164,255,.18),transparent 45%),linear-gradient(155deg,var(--bg-0),var(--bg-1) 52%,var(--bg-2))}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,h6,p{margin:0}input,select,button,textarea{font:inherit}.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:3px solid var(--primary);outline-offset:2px}input,select,textarea{width:100%;min-height:44px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface-strong);color:var(--text);transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease,transform .15s ease}input::placeholder,textarea::placeholder{color:color-mix(in srgb,var(--muted) 76%,transparent)}input:hover,select:hover,textarea:hover{border-color:var(--primary);background:color-mix(in srgb,var(--surface-strong) 96%,var(--primary) 4%)}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 20%,transparent);transform:translateY(-1px)}input[type=checkbox]{width:16px;height:16px;min-height:16px;padding:0;border-radius:3px;border:1px solid var(--border-strong);background:var(--surface-strong);transform:none;appearance:auto;accent-color:var(--primary);box-shadow:none;cursor:pointer}input[type=checkbox]:hover,input[type=checkbox]:focus{transform:none;box-shadow:none}input[type=file]{padding:10px 12px;cursor:pointer}input[type=file]::file-selector-button{margin-right:12px;border:1px solid color-mix(in srgb,var(--primary) 42%,white 58%);background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 14%,#fff 86%),color-mix(in srgb,var(--primary) 22%,#fff 78%));color:var(--primary-strong);border-radius:10px;padding:9px 14px;font:inherit;font-weight:800;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease}input[type=file]::file-selector-button:hover{transform:translateY(-1px);box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 18%,transparent);filter:brightness(1.02)}select{appearance:none;padding-right:40px;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 20px) calc(50% - 2px),calc(100% - 14px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.custom-select{position:relative;min-width:180px;flex:1 1 180px}.custom-select-trigger{width:100%;min-height:56px;padding:12px 16px;border-radius:16px;border:1px solid var(--border-strong);background:color-mix(in srgb,var(--surface-strong) 95%,#fff 5%);color:var(--text);box-shadow:var(--shadow-1);display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease,background-color .2s ease}.custom-select-trigger:hover,.custom-select-trigger.open{border-color:color-mix(in srgb,var(--primary) 58%,white 42%);background:color-mix(in srgb,var(--surface-strong) 90%,var(--primary) 10%);box-shadow:var(--shadow-1),0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}.custom-select-trigger:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 68%,white 32%);outline-offset:2px}.custom-select-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.custom-select-icon{width:18px;height:18px;color:var(--muted);transition:transform .18s ease,color .18s ease;flex:0 0 18px}.custom-select-icon.open{transform:rotate(180deg);color:var(--primary)}.custom-select-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:50;box-sizing:border-box;padding:8px;border-radius:18px;border:1px solid color-mix(in srgb,var(--primary) 25%,var(--border) 75%);background:color-mix(in srgb,var(--surface-strong) 98%,#fff 2%);box-shadow:0 18px 36px #0f172a2e;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);display:grid;gap:6px}.custom-select-menu-floating{max-height:min(320px,calc(100vh - 24px));overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.custom-select-option{width:100%;box-sizing:border-box;min-height:44px;padding:10px 12px;border:1px solid transparent;border-radius:12px;background:transparent;color:var(--text);box-shadow:none;justify-content:flex-start;font-weight:700;text-align:left;white-space:normal;word-break:break-word;line-height:1.35}.custom-select-option:hover,.custom-select-option:focus-visible{background:color-mix(in srgb,var(--primary) 12%,var(--surface-strong) 88%);border-color:color-mix(in srgb,var(--primary) 24%,transparent);box-shadow:none;transform:none;scale:1}.custom-select-option.active{background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 16%,#fff 84%),color-mix(in srgb,var(--primary) 24%,#fff 76%));border-color:color-mix(in srgb,var(--primary) 42%,white 58%);color:var(--primary-strong)}.date-input-shell{position:relative;display:flex;align-items:center;width:100%}.date-input-field{min-height:56px;padding:12px 48px 12px 16px;border-radius:16px;border:1px solid var(--border-strong);background:color-mix(in srgb,var(--surface-strong) 95%,#fff 5%);box-shadow:var(--shadow-1);color:var(--text)}.date-input-field:hover,.date-input-field:focus{border-color:color-mix(in srgb,var(--primary) 58%,white 42%);background:color-mix(in srgb,var(--surface-strong) 90%,var(--primary) 10%);box-shadow:var(--shadow-1),0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}.date-input-field::-webkit-calendar-picker-indicator{position:absolute;right:14px;width:22px;height:22px;margin:0;opacity:0;cursor:pointer}.date-input-field::-webkit-datetime-edit,.date-input-field::-webkit-date-and-time-value{color:inherit}.date-input-icon{position:absolute;right:16px;width:18px;height:18px;color:var(--muted);pointer-events:none}button{min-height:44px;border-radius:12px;border:1px solid color-mix(in srgb,var(--primary) 50%,white 50%);padding:10px 16px;color:#fff;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;background:linear-gradient(120deg,var(--primary),var(--primary-strong));box-shadow:0 12px 28px color-mix(in srgb,var(--primary) 42%,transparent);transition:transform .15s ease,box-shadow .2s ease,filter .2s ease,scale .15s ease}button:hover{transform:translateY(-2px);scale:1.02;filter:brightness(1.05);box-shadow:0 16px 36px color-mix(in srgb,var(--primary) 48%,transparent)}button:active{transform:translateY(0);scale:1}button:disabled{opacity:.58;cursor:not-allowed;transform:none;box-shadow:none;scale:1}.btn-secondary{background:var(--surface-strong);color:var(--text);border:1px solid var(--border-strong);box-shadow:var(--shadow-1);transition:all .2s ease}.btn-secondary:hover{border-color:var(--primary);background:color-mix(in srgb,var(--surface-strong) 92%,var(--primary) 8%);box-shadow:var(--shadow-1),0 0 20px color-mix(in srgb,var(--primary) 25%,transparent)}.btn-danger{background:linear-gradient(120deg,var(--danger),color-mix(in srgb,var(--danger) 82%,black 18%));border-color:color-mix(in srgb,var(--danger) 70%,white 30%)}.link-button{min-height:24px;background:transparent;border:0;color:var(--primary);padding:0;box-shadow:none;text-decoration:underline;text-underline-offset:3px}.link-button:hover{transform:none;filter:none}.page{width:100%;max-width:1220px;margin:0 auto}.muted{color:var(--muted);font-size:14px}.glass-panel,.card{background:var(--surface);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border:1px solid var(--border);box-shadow:var(--shadow-1),var(--glass-shadow);border-radius:var(--radius-lg)}.card{padding:18px}.form-stack{display:grid;gap:12px;width:100%;max-width:1040px;margin:0 auto}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1;min-width:180px}.section-title{font-size:clamp(30px,3vw,46px);line-height:1.1;letter-spacing:-.02em;color:var(--text);font-weight:800}.gradient-text{background:linear-gradient(120deg,#2563eb,#3b82f6 40%,#60a5fa 80%);color:transparent;-webkit-background-clip:text;background-clip:text}.erp-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh}.mobile-nav-toggle,.mobile-nav-backdrop{display:none}.erp-sidebar{position:sticky;top:0;height:100vh;padding:18px;display:grid;grid-template-rows:auto 1fr auto;gap:14px;border-radius:0;border-right:1px solid var(--border);overflow-y:auto}.erp-brand-wrap{display:flex;align-items:center;gap:10px}.erp-logo-img{width:42px;height:42px;object-fit:contain}.erp-logo-full{width:min(100%,220px);height:auto;object-fit:contain;display:block}.erp-brand{font-size:30px;font-weight:800;letter-spacing:-.03em;color:var(--text-soft)}.erp-nav{display:grid;gap:8px;align-content:start}.erp-nav-link{min-height:48px;border-radius:13px;border:1px solid transparent;padding:10px 12px;display:flex;align-items:center;gap:10px;color:var(--text-soft);font-weight:700;transition:all .2s ease;cursor:pointer}.nav-icon{width:18px;height:18px;object-fit:contain;flex:0 0 18px;stroke-width:2.2}.nav-label{line-height:1.2}.erp-nav-link:hover{background:var(--surface-muted);border-color:var(--border-strong);transform:translate(4px)}.erp-nav-link.active{background:linear-gradient(120deg,color-mix(in srgb,var(--primary) 35%,transparent),color-mix(in srgb,var(--primary) 20%,transparent));border-color:var(--primary);color:var(--primary);box-shadow:0 8px 24px color-mix(in srgb,var(--primary) 28%,transparent),inset 0 1px #ffffff4d;font-weight:800}.erp-nav-link.active:before{content:"";width:7px;height:7px;border-radius:999px;background:var(--primary);flex:0 0 7px;box-shadow:0 0 12px var(--primary)}.erp-sidebar-footer{display:grid;grid-template-columns:68px 1fr;gap:10px}.mode-btn,.theme-icon-toggle{width:68px;min-width:68px}.theme-icon-toggle{border-radius:14px;border:1px solid var(--border-strong);background:var(--surface-strong);color:var(--text);box-shadow:var(--shadow-1);transition:all .2s ease;cursor:pointer}.theme-icon-toggle:hover{border-color:var(--primary);background:color-mix(in srgb,var(--surface-strong) 94%,var(--primary) 6%);box-shadow:var(--shadow-1),0 0 20px color-mix(in srgb,var(--primary) 30%,transparent)}.theme-icon-toggle .btn-icon{width:20px;height:20px}.logout-btn{border-color:color-mix(in srgb,var(--danger) 50%,white 50%);background:linear-gradient(120deg,var(--danger),color-mix(in srgb,var(--danger) 82%,black 18%))}.erp-body{min-width:0}.erp-main{position:relative;isolation:isolate;padding:20px;overflow-y:auto;min-height:100vh;background:radial-gradient(760px 480px at 92% 10%,var(--main-aurora-a),transparent 55%),radial-gradient(680px 500px at 8% 86%,var(--main-aurora-b),transparent 58%),radial-gradient(820px 420px at 50% 42%,var(--main-aurora-c),transparent 68%)}.erp-main>*{position:relative;z-index:1}.erp-main:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,var(--main-noise-line-a) 0 1px,transparent 1px 4px),repeating-linear-gradient(90deg,var(--main-noise-line-b) 0 1px,transparent 1px 5px);opacity:.06}.erp-main:after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;box-shadow:inset 0 0 120px var(--main-vignette-edge)}.table-shell{border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:auto;background:var(--surface-strong);box-shadow:var(--shadow-1);transition:all .2s ease}.table-shell:hover{box-shadow:var(--shadow-1),0 0 20px color-mix(in srgb,var(--primary) 15%,transparent)}table{width:100%;border-collapse:separate;border-spacing:0}th,td{padding:11px 12px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}th{position:sticky;top:0;background:color-mix(in srgb,var(--surface-strong) 88%,white 12%);color:var(--text);font-weight:800}tr:last-child td{border-bottom:0}.stat-card{min-height:120px;transition:all .3s ease;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-2),0 0 30px color-mix(in srgb,var(--primary) 25%,transparent)}.stat-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,color-mix(in srgb,var(--primary) 5%,transparent) 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.stat-card:hover:before{opacity:1}.stat-number{font-size:clamp(28px,3vw,42px);font-weight:800;line-height:1;margin-top:10px;background:linear-gradient(120deg,var(--primary),var(--text));color:transparent;-webkit-background-clip:text;background-clip:text}.stat-number-compact{font-size:clamp(22px,2.2vw,30px)}.loader-shell{display:grid;place-items:center;gap:10px;padding:22px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-1);transition:all .3s ease}.loader-shell:hover{box-shadow:var(--shadow-1),0 0 20px color-mix(in srgb,var(--primary) 20%,transparent)}.loader-spinner{width:48px;height:48px;border-radius:50%;border:4px solid color-mix(in srgb,var(--primary) 20%,transparent);border-top-color:var(--primary);animation:spin 1s linear infinite}.toast-stack{position:fixed;top:16px;right:16px;z-index:120;display:grid;gap:10px;width:min(360px,calc(100vw - 24px))}.toast-item{position:relative;padding:12px 40px 12px 12px;border-radius:12px;border:1px solid var(--border-strong);background:color-mix(in srgb,var(--surface-strong) 92%,white 8%);box-shadow:var(--shadow-1)}.toast-default{border-color:var(--border-strong)}.toast-success{border-color:color-mix(in srgb,var(--ok) 55%,white 45%)}.toast-error{border-color:color-mix(in srgb,var(--danger) 55%,white 45%)}.toast-title{font-size:13px;font-weight:800;color:var(--text)}.toast-desc{margin-top:2px;font-size:13px;color:var(--text-soft);line-height:1.35}.toast-close{position:absolute;top:8px;right:8px;min-height:24px;width:24px;border-radius:8px;border:0;padding:0;color:var(--muted);background:transparent;box-shadow:none}.toast-close:hover{background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary);transform:none;scale:1;box-shadow:none}.control-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.control-row input{flex:1 1 260px;min-width:240px}.filter-shell{margin-bottom:12px}.filter-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.modal-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:16px;background:#070c1873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:16px;position:relative;overflow:hidden}.auth-page-hero{position:fixed;inset:0;pointer-events:none;background:radial-gradient(900px 700px at 12% 12%,rgba(125,180,255,.3),transparent 40%),radial-gradient(700px 580px at 88% 16%,rgba(136,157,255,.24),transparent 40%),radial-gradient(1000px 700px at 52% 100%,rgba(86,135,235,.14),transparent 45%)}.auth-page-hero:before,.auth-page-hero:after{content:"";position:absolute;inset:0}.auth-page-hero:before{opacity:.25;background-image:repeating-linear-gradient(0deg,rgba(31,65,131,.045) 0 1px,transparent 1px 3px),repeating-linear-gradient(90deg,rgba(31,65,131,.035) 0 1px,transparent 1px 4px)}.auth-page-hero:after{inset:-25% -10% auto;height:280px;background:linear-gradient(180deg,rgba(171,205,255,.28),transparent 72%);filter:blur(26px)}.auth-theme-toggle{position:fixed;right:20px;top:20px;z-index:85}.auth-theme-toggle-polished .theme-icon-toggle{border:1px solid color-mix(in srgb,var(--primary) 26%,var(--border-strong));background:color-mix(in srgb,var(--surface-strong) 84%,#f1f6ff 16%);box-shadow:var(--shadow-1),0 0 0 1px #ffffff73 inset}.auth-shell-split{width:min(1240px,100%);min-height:min(740px,calc(100vh - 32px));max-height:calc(100vh - 32px);z-index:2;position:relative;border-radius:14px;overflow:hidden;display:grid;grid-template-columns:1fr 2fr;background:color-mix(in srgb,var(--surface) 96%,#f5f9ff 4%);border:1px solid var(--border);box-shadow:var(--shadow-2)}.auth-left-panel{position:relative;padding:38px 32px;display:grid;place-items:center;background:linear-gradient(150deg,#1d4ec6,#2d6dde 55%,#1f55ca);color:#eef6ff;overflow:hidden}.auth-left-panel:before{content:"";position:absolute;inset:-20% auto -20% -45%;width:60%;background:linear-gradient(100deg,transparent 20%,rgba(255,255,255,.28) 50%,transparent 80%);transform:rotate(8deg);animation:authSweep 6.5s linear infinite;opacity:.22}.auth-left-panel:after{content:"";position:absolute;inset:auto -80px -120px auto;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffffff38,#ffffff05 65%);filter:blur(6px)}.auth-left-brand{width:min(420px,100%);z-index:2;display:grid;justify-items:center;text-align:center}.auth-left-subtitle{margin-top:6px;font-size:20px;font-weight:600;text-align:center}.auth-left-points{margin:24px auto 0;padding-left:18px;width:fit-content;display:grid;gap:10px;font-weight:500;text-align:left}.auth-left-points li{line-height:1.3}.auth-left-orb{position:absolute;border-radius:50%;background:#ffffff1a;filter:blur(.2px)}.auth-left-orb-a{width:74px;height:74px;top:40px;left:42px}.auth-left-orb-b{width:62px;height:62px;right:34px;bottom:36px}.auth-logo-only{width:min(100%,280px);line-height:0}.auth-logo-full{width:100%;height:auto;object-fit:contain;display:block}.auth-right-panel{padding:40px 30px;display:grid;align-content:center}.auth-role-panel{width:min(920px,100%);margin:0 auto;display:grid;gap:16px;padding:24px}.auth-role-heading{text-align:center;font-size:clamp(34px,3vw,44px);font-weight:800;line-height:1.02;letter-spacing:-.03em;margin:0}.auth-role-subheading{margin:-4px 0 10px;text-align:center;color:color-mix(in srgb,var(--muted) 85%,var(--text) 15%);font-size:18px}.role-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:18px}.role-card{min-height:300px;border-radius:24px;border:1px solid var(--border-strong);background:var(--surface-strong);color:var(--text);box-shadow:var(--shadow-1);display:grid;align-content:center;justify-items:center;gap:10px;text-align:center;white-space:normal;cursor:pointer;position:relative;overflow:hidden;animation:cardReveal .65s ease both;animation-delay:calc(var(--stagger-order, 0) * 90ms);transition:transform .28s ease,box-shadow .3s ease,border-color .2s ease,background .2s ease}.role-card:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:5px;background:linear-gradient(90deg,var(--role-accent, var(--primary)),color-mix(in srgb,var(--role-accent, var(--primary)) 58%,white 42%))}.role-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-2),0 0 30px color-mix(in srgb,var(--role-accent, var(--primary)) 28%,transparent);border-color:color-mix(in srgb,var(--role-accent, var(--primary)) 58%,white 42%);background:color-mix(in srgb,var(--surface-strong) 92%,var(--role-accent, var(--primary)) 8%)}.role-card.selected{background:color-mix(in srgb,var(--role-accent, var(--primary)) 12%,var(--surface-strong) 88%);border-color:color-mix(in srgb,var(--role-accent, var(--primary)) 64%,white 36%);box-shadow:var(--shadow-2),0 0 34px color-mix(in srgb,var(--role-accent, var(--primary)) 34%,transparent)}.role-card strong{color:var(--role-accent, var(--primary));font-size:clamp(34px,2.3vw,42px);letter-spacing:-.03em;line-height:1;font-weight:800}.role-card span{color:color-mix(in srgb,var(--muted) 86%,var(--text) 14%);font-size:13px;width:min(220px,100%);line-height:1.45}.role-card-admin{--role-accent: #2d6de7}.role-card-student{--role-accent: #1f9ea8}.role-card-faculty{--role-accent: #7652d6}.role-image-wrap{width:80px;height:80px;border-radius:50%;border:2px solid var(--role-accent, var(--primary));display:grid;place-items:center;background:color-mix(in srgb,var(--role-accent, var(--primary)) 10%,transparent);box-shadow:0 0 0 8px color-mix(in srgb,var(--role-accent, var(--primary)) 14%,transparent);transition:all .28s ease}.role-card:hover .role-image-wrap{border-color:color-mix(in srgb,var(--role-accent, var(--primary)) 80%,white 20%);background:color-mix(in srgb,var(--role-accent, var(--primary)) 16%,transparent);box-shadow:0 0 0 10px color-mix(in srgb,var(--role-accent, var(--primary)) 18%,transparent),0 0 22px color-mix(in srgb,var(--role-accent, var(--primary)) 32%,transparent)}.role-image-wrap svg{width:38px;height:38px;color:var(--role-accent, var(--primary));stroke-width:2}.auth-form-card{width:min(820px,100%);margin:0 auto;background:color-mix(in srgb,var(--surface) 92%,#f4f8ff 8%);border:1px solid color-mix(in srgb,var(--border) 80%,var(--primary) 20%);box-shadow:var(--shadow-2),0 0 0 1px #ffffff6b inset}.auth-form-shell{width:min(640px,100%);margin:0 auto;display:grid;gap:12px}.auth-selected-role{padding:14px 16px;background:color-mix(in srgb,var(--surface-strong) 90%,#eff5ff 10%);border:1px solid color-mix(in srgb,var(--border-strong) 80%,var(--primary) 20%)}.auth-selected-role h3{font-size:clamp(30px,2.2vw,38px);text-align:center;letter-spacing:-.02em}.auth-selected-role .muted{text-align:center;font-size:16px}.auth-error{color:#b42318;font-weight:600}.auth-success{color:#0f7d3f;font-weight:600}.auth-form-title{font-size:36px;line-height:1.08;text-align:center;margin:0}.auth-form-subtitle{margin:-4px 0 2px;color:var(--muted);text-align:center;font-weight:500}.slide-in{animation:authPanelSlideIn .34s cubic-bezier(.22,.9,.24,1)}@keyframes authPanelSlideIn{0%{opacity:0;transform:translate(26px)}to{opacity:1;transform:translate(0)}}.slide-out{animation:authPanelSlideOut .24s ease}@keyframes authPanelSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(22px)}}.auth-form-shell>label{font-weight:700;color:var(--text);margin-bottom:-6px;font-size:18px}.auth-form-shell input{min-height:52px;border-radius:14px}.auth-form-shell input[type=checkbox]{width:16px;height:16px;min-height:16px;border-radius:3px}.auth-inline-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.checkbox-inline{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:500;font-size:13px;margin:0}.checkbox-inline input[type=checkbox]{width:18px;height:18px;min-height:18px;border-radius:6px;border:1px solid color-mix(in srgb,var(--primary) 45%,var(--border-strong) 55%);background:color-mix(in srgb,var(--surface-strong) 90%,#f8fbff 10%);box-shadow:0 1px 2px #0f172a24;appearance:none;display:inline-grid;place-content:center;cursor:pointer}.checkbox-inline input[type=checkbox]:before{content:"";width:10px;height:10px;transform:scale(0);transition:transform .16s ease-in-out;clip-path:polygon(14% 44%,0 63%,44% 100%,100% 16%,82% 0,43% 62%);transform-origin:center;background:#fff}.checkbox-inline input[type=checkbox]:checked{background:linear-gradient(120deg,var(--primary),var(--primary-strong));border-color:var(--primary)}.checkbox-inline input[type=checkbox]:checked:before{transform:scale(1)}.checkbox-inline input[type=checkbox]:hover,.checkbox-inline input[type=checkbox]:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}.small-link{font-size:14px;min-height:0;padding:0}.auth-form-shell .link-button{justify-self:center;width:auto;min-width:0;min-height:0;padding:0 2px;border:0;border-radius:0;background:transparent;box-shadow:none}.auth-form-shell .link-button:hover,.auth-form-shell .link-button:focus-visible,.auth-form-shell .link-button:active{background:transparent;box-shadow:none;filter:none;transform:none;scale:1}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:44px}.password-toggle-btn{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:0;background:transparent;width:28px;height:28px;min-height:28px;border-radius:50%;padding:0;display:grid;place-items:center;color:var(--muted);cursor:pointer}.password-toggle-btn:hover{background:color-mix(in srgb,var(--primary) 10%,transparent);color:var(--primary);transform:translateY(-50%)!important;scale:1!important;filter:none!important;box-shadow:none!important}.btn-style905{border-radius:14px;background:linear-gradient(120deg,#2a66ec,#1f4fd1);box-shadow:0 14px 30px #2a66ec59}.btn-style905:hover{background:linear-gradient(120deg,#2f6ef3,#245adf)}.password-toggle-btn:active{transform:translateY(-50%)!important}.password-toggle-btn svg{width:18px;height:18px}.auth-legal{margin-top:8px;text-align:center;color:var(--muted);font-size:12px;line-height:1.3}.auth-legal-links{display:inline-block;padding:4px 10px;border-radius:999px;background:color-mix(in srgb,var(--surface-strong) 82%,var(--primary) 18%)}.auth-legal p{margin:0}.auth-legal p+p{margin-top:4px}.auth-legal-roles,.auth-legal-form{margin-top:14px}.auth-transition{position:fixed;inset:0;z-index:90;display:grid;place-items:center;gap:10px;color:#fff;background:#070c1880}.tt-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.tt-editor-cell{display:grid;gap:6px}.tt-editor-cell .cell-actions{display:flex;gap:6px;flex-wrap:wrap}.tt-break{text-align:center;font-weight:700;color:var(--text-soft);background:color-mix(in srgb,var(--surface-muted) 92%,white 8%)}.tt-student-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.tt-student-summary{margin-top:14px}.timetable-editor-page{max-width:min(1480px,calc(100vw - 64px))}.tt-shell{overflow-x:hidden}.tt-admin-table{table-layout:fixed}.tt-admin-table th:first-child,.tt-admin-table td:first-child{width:82px;min-width:82px}.tt-admin-table th,.tt-admin-table td{padding:10px 8px;vertical-align:middle}.tt-admin-table .tt-editor-cell{gap:8px}.tt-admin-table .tt-editor-cell .custom-select,.tt-admin-table .tt-editor-cell input{min-width:0;width:100%}.tt-admin-table .tt-editor-cell .custom-select-trigger,.tt-admin-table .tt-editor-cell input{min-height:42px;padding:10px 12px;border-radius:12px}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.btn-icon{width:16px;height:16px;object-fit:contain}@keyframes spin{to{transform:rotate(360deg)}}@keyframes cardReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes authSweep{0%{transform:translate(-24%) rotate(8deg)}to{transform:translate(158%) rotate(8deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(max-width:1080px){.erp-shell{grid-template-columns:1fr}.erp-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--border);border-radius:0}.erp-main{min-height:auto}.erp-nav,.filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.role-grid,.grid-2{grid-template-columns:1fr}.auth-shell-split{grid-template-columns:1fr;width:min(700px,100%);max-height:unset}.auth-left-panel{min-height:230px;padding:24px 20px}.auth-left-panel:before,.auth-left-panel:after{display:none}.auth-left-subtitle{font-size:16px}.auth-left-points{display:none}.auth-right-panel{padding:24px 16px}.auth-role-panel{padding:18px}.role-card{min-height:210px;gap:8px}.role-card strong{font-size:32px}.auth-form-card,.auth-form-shell{width:100%}.auth-form-shell>label{font-size:16px}}@media(max-width:760px){.erp-shell{min-height:100vh}.mobile-nav-toggle{display:inline-flex;position:sticky;top:10px;left:auto;z-index:96;justify-self:start;margin:10px 0 0 10px;width:auto;min-width:84px;min-height:40px;padding:0 16px;border-radius:14px}.mobile-nav-backdrop{display:block;position:fixed;inset:0;z-index:94;border:0;border-radius:0;background:#070c1873}.erp-sidebar{position:fixed;top:0;left:0;width:min(82vw,312px);height:100vh;z-index:95;transform:translate(-108%);transition:transform .22s ease;border-right:1px solid var(--border);padding:72px 14px 18px}.erp-sidebar.mobile-open{transform:translate(0)}.erp-nav{grid-template-columns:1fr}.erp-nav-link{width:100%}.erp-main{padding:8px 12px 12px}.filter-grid{grid-template-columns:1fr}.control-row input,.control-row button{width:100%;min-width:0;flex:1 1 100%}.row>*{min-width:100%}table{min-width:720px}.section-title{font-size:clamp(26px,8vw,34px)}.card{padding:14px}.auth-wrap{padding:10px;align-items:start}.auth-theme-toggle{position:absolute;right:14px;top:14px;z-index:5}.auth-theme-toggle .theme-icon-toggle{min-width:54px;width:54px;min-height:44px;border-radius:14px}.auth-shell-split{width:100%;min-height:auto;max-height:none;border-radius:18px}.auth-left-panel{min-height:150px;padding:20px 16px 18px}.auth-logo-only{width:min(100%,220px)}.auth-left-subtitle{font-size:14px}.auth-right-panel{padding:14px 10px 18px}.auth-role-panel{gap:12px;padding:14px}.auth-role-heading{font-size:clamp(28px,8vw,34px)}.auth-role-subheading{font-size:15px;margin-bottom:2px}.role-grid{gap:12px}.role-card,.auth-role-panel .role-card{min-height:170px;padding:18px 14px;border-radius:20px}.role-image-wrap{width:74px;height:74px}.role-card strong{font-size:22px}.role-card span{font-size:14px}.auth-form-card{padding:14px;border-radius:18px}.auth-form-title{font-size:clamp(26px,8vw,34px)}.auth-form-subtitle{font-size:14px}.auth-selected-role h3{font-size:clamp(24px,8vw,30px)}.auth-legal{font-size:11px}.attendance-kpi-grid,.attendance-filters-inline{grid-template-columns:1fr}}.lf-picker-modal{width:min(640px,100%);display:grid;gap:14px}.lf-picker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.lf-option-card{min-height:120px;border-radius:14px;display:grid;place-items:center;align-content:center;gap:8px;background:var(--surface-strong);color:var(--text);border:1px solid var(--border-strong);box-shadow:var(--shadow-1);transition:all .2s ease;cursor:pointer}.lf-option-card:hover{transform:translateY(-4px) scale(1.02);border-color:var(--primary);box-shadow:var(--shadow-1),0 0 25px color-mix(in srgb,var(--primary) 30%,transparent);background:color-mix(in srgb,var(--surface-strong) 94%,var(--primary) 6%)}.lf-option-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:20px;background:color-mix(in srgb,var(--primary) 15%,transparent);color:var(--primary)}.lf-form-modal{width:min(760px,100%);display:grid;gap:14px}.lf-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.lf-span-full{grid-column:1 / -1}.lf-form-grid label{display:block;margin-bottom:6px}.lf-form-grid textarea{min-height:108px;resize:vertical}.lf-photo-preview{margin-top:8px;width:100%;max-height:220px;object-fit:cover;border-radius:12px;border:1px solid var(--border-strong)}@media(max-width:760px){.lf-picker-grid,.lf-form-grid{grid-template-columns:1fr}.lf-option-card{min-height:96px}}.logout-btn{border-color:color-mix(in srgb,var(--danger) 58%,white 42%);background:linear-gradient(120deg,#ff4c63,#e63755 45%,#b81f4a);box-shadow:0 12px 24px #c7274f57}.logout-btn:hover{filter:brightness(1.06);box-shadow:0 14px 28px #c7274f6b}.lf-photo-link{display:block;width:fit-content}.lf-item-photo{width:100%;max-width:320px;max-height:210px;object-fit:cover;border-radius:12px;border:1px solid var(--border-strong)}#lf-date::placeholder{letter-spacing:.02em}.tt-controls{display:grid;grid-template-columns:minmax(180px,220px) minmax(180px,220px) minmax(160px,1fr) minmax(140px,180px);align-items:center;gap:10px}.tt-controls .custom-select,.tt-controls select,.tt-controls button{width:100%;min-width:0;flex:1 1 auto}@media(max-width:980px){.timetable-editor-page{max-width:100%}.tt-controls{grid-template-columns:1fr 1fr}.tt-controls .custom-select,.tt-controls select,.tt-controls button{width:100%;flex:1 1 100%}}@media(max-width:760px){.tt-controls{grid-template-columns:1fr}}.dashboard-split{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}.announcement-card{position:sticky;top:20px;border:1px solid color-mix(in srgb,var(--danger) 40%,var(--border) 60%);box-shadow:var(--shadow-1),0 0 25px color-mix(in srgb,var(--danger) 20%,transparent);background:color-mix(in srgb,var(--surface-strong) 95%,var(--danger) 5%);transition:all .3s ease}.support-grid{align-items:start}.support-ticket-btn{width:100%;justify-content:space-between;text-align:left}.support-ticket-btn.active{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 40%,transparent)}.support-badge{display:inline-flex;align-items:center;justify-content:center;min-width:108px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid var(--border-strong);background:var(--surface-strong)}.support-badge.open{color:#1d4ed8}.support-badge.in_review{color:#b45309}.support-badge.resolved{color:#047857}.support-badge.rejected{color:#b42318}.support-badge.reopen_requested{color:#7c3aed}.support-thread{display:grid;gap:10px;margin-top:6px}.support-msg{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;background:var(--surface-strong)}.fees-table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--surface-strong) 96%,#000 4%)}.fees-table tbody tr:hover{background:color-mix(in srgb,var(--surface-strong) 91%,#000 9%)}.fees-row-overdue{background:color-mix(in srgb,#fee2e2 65%,var(--surface-strong) 35%)!important}.fees-overdue-date{color:#b42318;font-weight:700}.fees-overdue-tag{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:800;color:#fff;background:#b42318}.fees-check-label{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text-soft)}.fees-table thead .fees-check-label{font-size:14px;font-weight:800;color:var(--text)}.fees-check-label input[type=checkbox]{width:18px;height:18px;min-height:18px;border-radius:5px;border:1px solid color-mix(in srgb,var(--primary) 45%,var(--border-strong) 55%);background:color-mix(in srgb,var(--surface-strong) 90%,#f8fbff 10%);box-shadow:0 1px 2px #0f172a24;appearance:none;display:inline-grid;place-content:center;cursor:pointer}.fees-check-label input[type=checkbox]:before{content:"";width:10px;height:10px;transform:scale(0);transition:transform .16s ease-in-out;clip-path:polygon(14% 44%,0 63%,44% 100%,100% 16%,82% 0,43% 62%);transform-origin:center;background:#fff}.fees-check-label input[type=checkbox]:checked{background:linear-gradient(120deg,var(--primary),var(--primary-strong));border-color:var(--primary)}.fees-check-label input[type=checkbox]:checked:before{transform:scale(1)}.fees-check-label input[type=checkbox]:hover,.fees-check-label input[type=checkbox]:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}.fees-stat-card{position:relative}.fees-stat-hover-value{position:absolute;left:14px;right:14px;bottom:14px;opacity:0;transform:translateY(8px);font-size:14px;font-weight:700;color:var(--text-soft);transition:opacity .22s ease,transform .22s ease;pointer-events:none}.fees-stat-card:hover .fees-stat-hover-value{opacity:1;transform:translateY(0)}.announcement-label{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#b42318}.announcement-badge{display:inline-flex;align-items:center;width:fit-content;min-height:28px;padding:4px 10px;border-radius:999px;border:1px solid color-mix(in srgb,#ef4444 34%,white 66%);background:linear-gradient(120deg,color-mix(in srgb,#fee2e2 82%,white 18%),color-mix(in srgb,#fecaca 70%,white 30%));color:#b42318;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.faculty-weekly-table{width:100%;min-width:0;table-layout:fixed}.faculty-weekly-table th{white-space:normal}.faculty-tt-time-col{width:120px;white-space:normal;font-weight:800}.faculty-tt-cell{vertical-align:top;min-width:0}.faculty-tt-item{border:1px solid var(--border);border-radius:10px;padding:7px;background:color-mix(in srgb,var(--surface-strong) 95%,var(--primary) 5%);display:grid;gap:3px;width:100%;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.faculty-tt-item+.faculty-tt-item{margin-top:8px}.faculty-tt-subject{font-weight:800;color:var(--text);font-size:15px;line-height:1.2}.faculty-tt-meta{font-size:11px;color:var(--muted);line-height:1.25}.faculty-tt-lab-badge{justify-self:start;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:800;color:var(--primary-strong);border:1px solid var(--border-strong);background:color-mix(in srgb,var(--primary) 14%,var(--surface-strong) 86%)}.faculty-tt-empty{color:var(--muted);font-weight:600;text-align:center}.attendance-page{align-items:stretch}.attendance-header{display:grid;gap:6px}.attendance-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.attendance-filters{display:grid;gap:10px}.attendance-filters-inline{display:grid;grid-template-columns:minmax(200px,1.2fr) minmax(170px,.9fr) minmax(220px,1.4fr) auto;gap:10px;align-items:center}.attendance-load-row{display:grid;grid-template-columns:minmax(280px,1.6fr) minmax(180px,1fr) minmax(180px,.9fr);gap:12px;align-items:end}.attendance-load-field{display:grid;gap:6px}.attendance-load-action button{width:100%}.attendance-chart-card{display:grid;gap:12px}.attendance-subject-row{display:grid;gap:6px}.attendance-subject-head{display:flex;justify-content:space-between;gap:12px;font-size:13px;color:var(--text-soft);font-weight:700}.attendance-bar-track{width:100%;height:10px;border-radius:999px;background:color-mix(in srgb,var(--surface-strong) 88%,#000 12%);overflow:hidden}.attendance-bar-fill{height:100%;border-radius:999px;background:linear-gradient(120deg,var(--primary),var(--primary-strong))}.attendance-trend-svg{width:100%;height:160px;border-radius:10px;background:color-mix(in srgb,var(--surface-strong) 92%,#fff 8%);border:1px solid var(--border)}.attendance-trend-labels{display:flex;gap:6px;justify-content:space-between;flex-wrap:wrap;font-size:12px;color:var(--muted)}.attendance-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:78px;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;border:1px solid var(--border-strong)}.attendance-status-badge.present{color:#0f7d3f;background:color-mix(in srgb,#dcfce7 70%,var(--surface-strong) 30%)}.attendance-status-badge.absent{color:#b42318;background:color-mix(in srgb,#fee2e2 70%,var(--surface-strong) 30%)}.attendance-sort-btn{min-height:0;padding:0;border:0;border-radius:0;background:transparent;color:inherit;box-shadow:none;font-weight:800}.attendance-sort-btn:hover,.attendance-sort-btn:focus-visible,.attendance-sort-btn:active{transform:none;scale:1;filter:none;box-shadow:none;color:var(--primary);background:transparent}.attendance-reset-btn{min-height:44px;border-radius:12px;border:1px solid color-mix(in srgb,var(--danger) 50%,white 50%);background:linear-gradient(120deg,var(--danger),color-mix(in srgb,var(--danger) 82%,black 18%));box-shadow:0 10px 22px color-mix(in srgb,var(--danger) 38%,transparent)}.marks-filter-row{display:grid;grid-template-columns:minmax(320px,1fr) minmax(220px,.6fr) auto;gap:10px;align-items:center}.marks-filter-row>*{min-width:0}.marks-filter-row>button{width:auto;min-width:120px}.file-badge{display:inline-flex;align-items:center;justify-content:center;min-width:56px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:800;color:var(--primary-strong);border:1px solid var(--border-strong);background:color-mix(in srgb,var(--primary) 14%,var(--surface-strong) 86%)}.resource-skeleton-grid{display:grid;gap:10px}.resource-skeleton-row{height:52px;border-radius:12px;border:1px solid var(--border);background:linear-gradient(90deg,color-mix(in srgb,var(--surface-strong) 88%,#000 12%),color-mix(in srgb,var(--surface-strong) 96%,#fff 4%),color-mix(in srgb,var(--surface-strong) 88%,#000 12%));background-size:200% 100%;animation:resourcePulse 1.2s ease-in-out infinite}.resource-modal{border:1px solid color-mix(in srgb,var(--primary) 28%,var(--border) 72%);box-shadow:var(--shadow-2),0 0 26px color-mix(in srgb,var(--primary) 22%,transparent)}.resource-modal-centered{text-align:center}.resource-modal-centered .row{justify-content:center}.resource-actions-cell{width:260px;min-width:260px}.resource-table-actions{display:grid;grid-template-columns:minmax(92px,.7fr) minmax(132px,1.3fr);align-items:center;gap:10px;justify-content:stretch}.resource-action-link{display:block;width:100%}.resource-action-link button,.resource-table-actions>button{width:100%;min-width:0}.resource-action-btn{min-height:48px;border-radius:14px;font-weight:800;letter-spacing:.01em;border:1px solid transparent}.resource-action-btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 58%,#fff 42%);outline-offset:2px}.resource-action-btn-material{background:linear-gradient(120deg,#1d4ed8,#2563eb);border-color:color-mix(in srgb,#2563eb 65%,white 35%)}.resource-action-btn-paper{background:linear-gradient(120deg,#0f766e,#0891b2);border-color:color-mix(in srgb,#0891b2 65%,white 35%)}.materials-filter-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr .9fr .7fr;gap:12px;align-items:center}.materials-filter-row>*{min-width:0}@media(max-width:1080px){.materials-filter-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.custom-select{min-width:100%;flex-basis:100%}.resource-actions-cell{width:auto;min-width:0}.resource-table-actions,.materials-filter-row,.marks-filter-row{grid-template-columns:1fr}.marks-filter-row>button{width:100%}}@keyframes resourcePulse{0%{background-position:0% 0}to{background-position:-200% 0}}@media(max-width:1080px){.dashboard-split{grid-template-columns:1fr}.announcement-card{position:static}.attendance-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-subject-head{flex-direction:column;gap:2px}.attendance-filters-inline{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-load-row{grid-template-columns:1fr}}:root{--space-1: 6px;--space-2: 10px;--space-3: 14px;--space-4: 18px;--space-5: 24px;--radius-pill: 999px;--elev-soft: 0 10px 28px rgba(15, 23, 42, .11);--elev-hard: 0 18px 38px rgba(15, 23, 42, .2)}.erp-shell{animation:shellEnter .45s ease}.erp-shell[data-role=student]{--primary: #2f7df6;--primary-strong: #1f5fdd;--main-aurora-a: rgba(83, 163, 255, .2);--main-aurora-b: rgba(96, 165, 250, .14);--main-aurora-c: rgba(147, 197, 253, .12)}.erp-shell[data-role=faculty]{--primary: #1d6fe8;--primary-strong: #1e4fc4;--main-aurora-a: rgba(37, 99, 235, .2);--main-aurora-b: rgba(30, 144, 255, .16);--main-aurora-c: rgba(125, 211, 252, .1)}.erp-shell[data-role=admin]{--primary: #2155d6;--primary-strong: #183ea5;--main-aurora-a: rgba(59, 130, 246, .18);--main-aurora-b: rgba(37, 99, 235, .14);--main-aurora-c: rgba(96, 165, 250, .12)}.erp-sidebar{gap:16px}.role-brand-wrap{position:relative}.erp-nav-scroll{overflow-y:auto;display:grid;gap:14px;padding-right:4px;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--primary) 42%,transparent) color-mix(in srgb,var(--surface-strong) 84%,transparent)}.erp-nav-scroll::-webkit-scrollbar{width:10px}.erp-nav-scroll::-webkit-scrollbar-track{border-radius:999px;background:color-mix(in srgb,var(--surface-strong) 82%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--border) 70%,transparent)}.erp-nav-scroll::-webkit-scrollbar-thumb{border-radius:999px;border:2px solid transparent;background:linear-gradient(180deg,color-mix(in srgb,var(--primary) 72%,#ffffff 28%),color-mix(in srgb,var(--primary-strong) 82%,#ffffff 18%));background-clip:padding-box}.erp-nav-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,color-mix(in srgb,var(--primary) 82%,#ffffff 18%),color-mix(in srgb,var(--primary-strong) 90%,#ffffff 10%));background-clip:padding-box}.erp-nav-group{display:grid;gap:7px}.erp-nav-group-title{margin:0;padding:0 6px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in srgb,var(--muted) 84%,var(--text) 16%)}.profile-footer-card{grid-template-columns:1fr;gap:12px;padding:12px;border-radius:22px;border:1px solid color-mix(in srgb,var(--primary) 34%,#dbeafe 66%);background:linear-gradient(170deg,#f7fbff,#eef5ff);box-shadow:0 10px 24px #142c5c24}.profile-card-head{display:grid;grid-template-columns:60px 1fr;gap:12px;align-items:center;padding:4px;border-radius:16px;background:#ffffff94}.profile-avatar-wrap{width:60px;height:60px;border-radius:16px;border:0;background:linear-gradient(145deg,color-mix(in srgb,var(--primary) 78%,#ffffff 22%),color-mix(in srgb,var(--primary-strong) 86%,#ffffff 14%));display:grid;place-items:center;overflow:hidden;box-shadow:0 12px 20px color-mix(in srgb,var(--primary) 34%,transparent)}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{font-size:16px;font-weight:800;color:#fff}.profile-meta{min-width:0}.profile-name{margin:0;font-size:clamp(17px,1.2vw,21px);line-height:1.1;font-weight:800;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-subtext{margin:6px 0 0;font-size:15px;font-weight:600;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-actions{display:grid;grid-template-columns:84px 1fr;gap:12px}.erp-shell[data-role=faculty] .profile-footer-card{border-color:color-mix(in srgb,#60a5fa 40%,var(--border) 60%)}.erp-shell[data-role=admin] .profile-footer-card{border-color:color-mix(in srgb,#3b82f6 46%,var(--border) 54%)}.erp-shell[data-role=faculty] .theme-icon-toggle{border-color:color-mix(in srgb,#60a5fa 45%,var(--border-strong) 55%)}.erp-shell[data-role=admin] .theme-icon-toggle{border-color:color-mix(in srgb,#3b82f6 45%,var(--border-strong) 55%);background:color-mix(in srgb,var(--surface-strong) 92%,#eff6ff 8%)}.profile-actions .theme-icon-toggle{min-height:56px;border-radius:16px;background:#fff;border:1px solid color-mix(in srgb,var(--primary) 34%,#dbeafe 66%);box-shadow:0 8px 16px #142c5c1f}.profile-actions .logout-btn{min-height:56px;border-radius:16px;box-shadow:0 12px 22px #d61d5447}html.dark .profile-footer-card{border-color:color-mix(in srgb,var(--primary) 34%,rgba(148,163,184,.2) 66%);background:linear-gradient(180deg,#212e4af5,#162035f0);box-shadow:0 14px 28px #00000052}html.dark .profile-card-head{background:#ffffff0a}html.dark .profile-actions .theme-icon-toggle{background:linear-gradient(180deg,#293956f0,#1f2d46f5);border-color:color-mix(in srgb,var(--primary) 32%,rgba(148,163,184,.22) 68%);box-shadow:0 8px 16px #0000003d}html.dark .erp-nav-scroll{scrollbar-color:color-mix(in srgb,var(--primary) 55%,rgba(191,219,254,.2) 45%) rgba(255,255,255,.05)}html.dark .erp-nav-scroll::-webkit-scrollbar-track{background:linear-gradient(180deg,#ffffff0f,#ffffff08);box-shadow:inset 0 0 0 1px #94a3b81f}html.dark .erp-nav-scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg,color-mix(in srgb,var(--primary) 78%,#dbeafe 22%),color-mix(in srgb,var(--primary-strong) 88%,#bfdbfe 12%));background-clip:padding-box}html.dark input[type=file]{background:#293956e0;border-color:#64a5ff47}html.dark input[type=file]::file-selector-button{background:linear-gradient(120deg,#364a70f5,#27395ef5);color:#dbeafe;border-color:#93c5fd52}html.dark .custom-select-trigger{background:linear-gradient(180deg,#293956eb,#222f49f5);border-color:#93c5fd33;box-shadow:0 12px 24px #0000003d}html.dark .custom-select-trigger:hover,html.dark .custom-select-trigger.open{background:linear-gradient(180deg,#324464f5,#253652fa);border-color:#93c5fd66}html.dark .custom-select-menu{background:linear-gradient(180deg,#1d273dfa,#161f31fa);border-color:#93c5fd2e;box-shadow:0 20px 36px #00000057}html.dark .custom-select-option.active{background:linear-gradient(120deg,#60a5fa38,#3b82f62e);border-color:#93c5fd57;color:#dbeafe}html.dark .date-input-field{background:linear-gradient(180deg,#293956eb,#222f49f5);border-color:#93c5fd33;box-shadow:0 12px 24px #0000003d;color:#eaf2ff}html.dark .date-input-field:hover,html.dark .date-input-field:focus{background:linear-gradient(180deg,#324464f5,#253652fa);border-color:#93c5fd66}html.dark .date-input-icon{color:#b7c9ea}.erp-shell[data-role=student] .erp-sidebar:after{content:"";position:absolute;left:12px;right:12px;bottom:102px;height:44px;pointer-events:none;opacity:.24;background:radial-gradient(circle at 12% 58%,#7dd3fc 0 10px,transparent 11px),radial-gradient(circle at 42% 38%,#34d399 0 9px,transparent 10px),radial-gradient(circle at 70% 65%,#fbbf24 0 8px,transparent 9px),radial-gradient(circle at 88% 35%,#60a5fa 0 8px,transparent 9px)}.erp-shell[data-role=faculty] .erp-sidebar:after,.erp-shell[data-role=admin] .erp-sidebar:after{content:none}.section-title{letter-spacing:-.03em}.form-stack>.card,.table-shell,.glass-panel,.card{transition:transform .2s ease,box-shadow .22s ease,border-color .2s ease}.card:hover,.table-shell:hover{border-color:color-mix(in srgb,var(--primary) 32%,var(--border-strong) 68%)}.card:has(.section-title){box-shadow:var(--elev-hard)}.row{gap:14px}button,.btn-secondary,.btn-danger,.logout-btn{border-radius:14px}.btn-secondary{font-weight:700}.table-shell table tbody tr{transition:background-color .15s ease}.table-shell table tbody tr:hover{background:color-mix(in srgb,var(--surface-strong) 90%,var(--primary) 10%)}.table-shell table tbody tr:nth-child(2n){background:color-mix(in srgb,var(--surface-strong) 96%,#000 4%)}.auth-shell-split{border-radius:24px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border) 76%)}.auth-left-panel{background:linear-gradient(150deg,#1554ce,#1d63d8,#0c49b8)}.auth-form-card{border:1px solid color-mix(in srgb,var(--primary) 25%,var(--border) 75%)}.auth-form-title{font-size:clamp(32px,2.8vw,42px);line-height:1.05;letter-spacing:-.02em}.auth-error,.auth-success{padding:10px 12px;border-radius:10px;font-size:13px;font-weight:700}.auth-error{border:1px solid color-mix(in srgb,#ef4444 55%,white 45%);background:color-mix(in srgb,#fee2e2 75%,var(--surface-strong) 25%);color:#b91c1c}.auth-success{border:1px solid color-mix(in srgb,#10b981 50%,white 50%);background:color-mix(in srgb,#dcfce7 75%,var(--surface-strong) 25%);color:#047857}.auth-role-panel .role-card{min-height:320px}.theme-icon-toggle:focus-visible,.erp-nav-link:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 80%,white 20%);outline-offset:2px}@keyframes shellEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1080px){.profile-footer-card{margin-top:8px}.erp-nav-group-title{padding-left:2px}}@media(max-width:760px){.profile-footer-card{gap:10px;padding:10px;border-radius:18px}.profile-card-head{grid-template-columns:48px 1fr;gap:10px;padding:2px}.profile-avatar-wrap{width:48px;height:48px;border-radius:14px}.profile-name{font-size:16px}.profile-subtext{margin-top:2px;font-size:12px}.profile-actions{grid-template-columns:64px 1fr;gap:10px}.profile-actions .mode-btn,.profile-actions .logout-btn{width:100%;min-width:0}.profile-actions .theme-icon-toggle,.profile-actions .logout-btn{min-height:48px;border-radius:14px}}
