@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--navy-950: #060E1A;--navy-900: #0A1628;--navy-800: #0F2035;--navy-700: #163050;--navy-600: #1E4070;--navy-500: #2A5A99;--gold-600: #B8913A;--gold-500: #D4A853;--gold-400: #E4C06A;--gold-300: #F0D88A;--gold-200: #F7E8B0;--accent-400: #60A5FA;--accent-500: #3B82F6;--accent-600: #2563EB;--success-400: #4ADE80;--success-500: #22C55E;--success-600: #16A34A;--warning-400: #FBBF24;--warning-500: #F59E0B;--warning-600: #D97706;--danger-400: #F87171;--danger-500: #EF4444;--danger-600: #DC2626;--bg-primary: var(--navy-950);--bg-secondary: var(--navy-900);--bg-tertiary: var(--navy-800);--bg-card: #0C1929;--bg-card-hover: #10243D;--bg-elevated: var(--navy-700);--bg-input: #0B1522;--border-primary: rgba(22, 48, 80, .6);--border-secondary: rgba(30, 64, 112, .5);--border-hover: rgba(42, 90, 153, .5);--border-focus: var(--gold-500);--text-primary: #E8ECF4;--text-secondary: #8BA2C4;--text-tertiary: #506882;--text-inverse: #060E1A;--text-gold: var(--gold-400);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35), 0 1px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .45), 0 4px 12px rgba(0, 0, 0, .25);--shadow-gold: 0 4px 20px rgba(212, 168, 83, .15), 0 0 0 1px rgba(212, 168, 83, .08);--shadow-gold-lg: 0 8px 32px rgba(212, 168, 83, .2), 0 0 0 1px rgba(212, 168, 83, .1);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease-out;--transition-base: .28s ease-out;--transition-slow: .45s ease-out;--spring: cubic-bezier(.34, 1.56, .64, 1);--spring-soft: cubic-bezier(.25, 1, .5, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit;font-size:inherit}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}ul,ol{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--navy-700);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--navy-600)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes goldPulse{0%,to{box-shadow:0 0 #d4a85333}50%{box-shadow:0 0 0 6px #d4a85300}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;transition:all .2s var(--spring-soft);white-space:nowrap;border:1px solid transparent;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:var(--text-inverse);box-shadow:0 2px 10px #d4a85340}.btn-primary:hover{background:linear-gradient(135deg,var(--gold-400),var(--gold-500));box-shadow:var(--shadow-gold);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0) scale(.97)}.btn-secondary{background:var(--navy-800);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover{background:var(--navy-700);border-color:var(--border-hover);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:#16305066;color:var(--text-primary)}.btn-danger{background:var(--danger-600);color:#fff}.btn-danger:hover{background:var(--danger-500);box-shadow:0 4px 12px #ef444440;transform:translateY(-1px)}.btn-sm{padding:6px 14px;font-size:.8125rem;border-radius:var(--radius-sm)}.btn-lg{padding:13px 30px;font-size:1rem}.btn-icon{padding:8px;width:36px;height:36px;border-radius:var(--radius-sm)}.card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:24px;transition:all .28s var(--spring-soft);animation:fadeSlideUp .4s var(--spring-soft) both}.card:hover{border-color:var(--border-secondary)}.card-interactive:hover{border-color:#d4a8534d;box-shadow:var(--shadow-gold);transform:translateY(-3px)}.card:nth-child(1){animation-delay:0ms}.card:nth-child(2){animation-delay:60ms}.card:nth-child(3){animation-delay:.12s}.card:nth-child(4){animation-delay:.18s}.card:nth-child(5){animation-delay:.24s}.card:nth-child(6){animation-delay:.3s}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.input{padding:11px 16px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.input:focus{border-color:var(--gold-500);box-shadow:0 0 0 3px #d4a8531f}.input::placeholder{color:var(--text-tertiary)}.textarea{padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);resize:vertical;min-height:120px;transition:all var(--transition-fast)}.textarea:focus{border-color:var(--gold-500);box-shadow:0 0 0 3px #d4a8531f}.select{padding:11px 40px 11px 16px;background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast);appearance:none;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='%23506882' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.select:focus{border-color:var(--gold-500);box-shadow:0 0 0 3px #d4a8531f}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-primary{background:#d4a85326;color:var(--gold-400)}.badge-success{background:#22c55e1f;color:var(--success-400)}.badge-warning{background:#f59e0b1f;color:var(--warning-400)}.badge-danger{background:#ef44441f;color:var(--danger-400)}.badge-info{background:#3b82f61f;color:var(--accent-400)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0;color:#fff}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.stat-card{display:flex;align-items:flex-start;gap:16px;padding:22px}.stat-card .stat-icon{width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s var(--spring)}.stat-card:hover .stat-icon{transform:scale(1.08)}.stat-card .stat-content{flex:1}.stat-card .stat-value{font-size:1.875rem;font-weight:800;line-height:1;margin-bottom:4px;letter-spacing:-.02em}.stat-card .stat-label{font-size:.8125rem;color:var(--text-secondary)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px;animation:fadeSlideUp .35s var(--spring-soft) both}.page-header h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.page-header p{font-size:.875rem;color:var(--text-secondary);margin-top:2px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-primary);margin-bottom:24px}.tab{padding:10px 20px;background:transparent;color:var(--text-secondary);font-weight:500;font-size:.875rem;border-bottom:2px solid transparent;transition:all var(--transition-fast);margin-bottom:-1px}.tab.active{color:var(--gold-400);border-bottom-color:var(--gold-500)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state svg{color:var(--text-tertiary);margin-bottom:16px}.empty-state h3{font-size:1.125rem;font-weight:600;margin-bottom:8px}.empty-state p{color:var(--text-secondary);font-size:.875rem;max-width:360px}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#060e1abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease-out}.modal{background:var(--navy-900);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:32px;max-width:560px;width:100%;max-height:calc(100vh - 48px);overflow-y:auto;animation:slideUp .35s var(--spring-soft);box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.progress-bar{width:100%;height:8px;background:var(--navy-800);border-radius:var(--radius-full);overflow:hidden}.progress-bar .progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow);background:linear-gradient(90deg,var(--gold-600),var(--gold-400))}.submission-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent}.submission-item:hover{background:var(--navy-800);border-color:var(--border-primary)}.submissions-list{display:flex;flex-direction:column;gap:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-gold{color:var(--gold-400)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:16px}.mb-lg{margin-bottom:24px}.sidebar-mobile-overlay{position:fixed;inset:0;background:#060e1ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;animation:fadeIn .2s ease-out}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--navy-900);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;transition:width .3s var(--spring-soft);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border-primary);min-height:64px}.logo-icon{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-inverse);box-shadow:0 2px 8px #d4a85333;transition:transform .2s var(--spring)}.logo-icon:hover{transform:scale(1.05)}.logo-text{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;white-space:nowrap;color:var(--text-primary)}.sidebar-close-mobile{display:none;margin-left:auto;color:var(--text-tertiary);padding:4px}.sidebar-school-switcher{padding:8px 12px;position:relative}.school-switcher-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:#d4a8530f;border:1px solid rgba(212,168,83,.15);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary);font-size:.8125rem;font-weight:600}.school-switcher-btn:hover{background:#d4a8531f;border-color:#d4a8534d}.school-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px #0003}.school-name{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.school-chevron{flex-shrink:0;color:var(--text-tertiary);transition:transform .2s ease}.school-chevron.open{transform:rotate(180deg)}.school-dropdown{position:absolute;top:100%;left:12px;right:12px;background:var(--navy-800);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;padding:4px;animation:fadeSlideUp .15s ease-out}.school-dropdown-label{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:8px 10px 4px}.school-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:.8125rem;transition:all var(--transition-fast);text-decoration:none}.school-dropdown-item:hover{background:#ffffff0d;color:var(--text-primary)}.school-dropdown-item.active{background:#d4a8531a;color:var(--gold-400)}.school-dropdown-item.add{color:var(--gold-400);font-weight:600}.school-dropdown-divider{height:1px;background:var(--border-primary);margin:4px 0}.sidebar-user{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border-primary)}.sidebar-avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0;color:#fff;transition:transform .2s var(--spring)}.sidebar-avatar:hover{transform:scale(1.08)}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.75rem;color:var(--gold-400);font-weight:500}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:14px;padding:11px 14px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:.875rem;transition:all .18s var(--spring-soft);white-space:nowrap;border:1px solid transparent;position:relative;background:transparent;width:100%;text-align:left}.sidebar-link:hover{background:#16305080;color:var(--text-primary)}.sidebar-link.active{background:#d4a8531a;color:var(--gold-400);border-color:#d4a85326}.sidebar-link.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--gold-500)}.sidebar-bottom{padding:10px;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:2px}.sidebar-toggle{display:flex;align-items:center;gap:14px;padding:11px 14px;border-radius:var(--radius-md);color:var(--text-tertiary);font-weight:500;font-size:.8125rem;transition:all var(--transition-fast);background:transparent;width:100%;text-align:left;border:none}.sidebar-toggle:hover{background:#1630504d;color:var(--text-secondary)}@media(max-width:768px){.sidebar{transform:translate(-100%);box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar.collapsed{width:var(--sidebar-width);transform:translate(-100%)}.sidebar.collapsed.mobile-open{transform:translate(0)}.sidebar-close-mobile{display:block}}.header{height:var(--header-height);background:var(--navy-900);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.header-menu-btn{display:none;background:transparent;color:var(--text-secondary);padding:6px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.header-menu-btn:hover{color:var(--text-primary);background:#16305066}.header-search{position:relative;display:flex;align-items:center}.header-search svg{position:absolute;left:14px;color:var(--text-tertiary);pointer-events:none}.header-search input{padding:9px 14px 9px 40px;width:280px;background:var(--navy-800);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.header-search input::placeholder{color:var(--text-tertiary)}.header-search input:focus{width:340px;border-color:var(--gold-500);box-shadow:0 0 0 3px #d4a8531a}.header-right{display:flex;align-items:center;gap:8px}.header-notif-wrapper{position:relative}.header-notif-btn{position:relative;width:40px;height:40px;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.header-notif-btn:hover{background:#16305066;color:var(--text-primary)}.notif-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;border-radius:var(--radius-full);background:var(--gold-500);color:var(--text-inverse);font-size:.625rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--navy-900);animation:goldPulse 2s ease-in-out infinite}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:-12px;width:380px;max-height:480px;background:var(--navy-900);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .25s var(--spring-soft);z-index:200;display:flex;flex-direction:column}.notif-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 18px;border-bottom:1px solid var(--border-primary)}.notif-header h3{font-size:.9375rem;font-weight:700;flex:1}.notif-mark-read{background:none;color:var(--gold-400);font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.notif-mark-read:hover{background:#d4a8531a}.notif-close{background:none;color:var(--text-tertiary);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.notif-close:hover{color:var(--text-primary);background:#16305066}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{padding:32px 18px;text-align:center;color:var(--text-tertiary);font-size:.8125rem}.notif-item{display:flex;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border-primary);transition:background var(--transition-fast);cursor:pointer;background:transparent;width:100%;text-align:left;color:var(--text-primary)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--navy-800)}.notif-item.unread{background:#d4a8530a;border-left:3px solid var(--gold-500)}.notif-icon{font-size:1.25rem;flex-shrink:0;line-height:1;margin-top:2px}.notif-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-title{font-size:.8125rem;font-weight:600;line-height:1.4}.notif-message{font-size:.75rem;color:var(--text-secondary);line-height:1.4}@media(max-width:768px){.header-menu-btn{display:flex}.header-search input{width:180px}.header-search input:focus{width:220px}.notif-dropdown{right:-60px;width:calc(100vw - 20px);max-width:380px}}@media(max-width:480px){.header-search{display:none}.header{padding:0 16px}}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:var(--sidebar-width);transition:margin-left .3s var(--spring-soft);display:flex;flex-direction:column;min-height:100vh;min-width:0}.app-layout.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed)}.app-content{flex:1;padding:28px 32px;max-width:1200px;width:100%;overflow-x:hidden}@media(max-width:768px){.app-main{margin-left:0!important}.app-content{padding:20px 16px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 20% 50%,rgba(212,168,83,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(30,64,112,.15) 0%,transparent 50%),linear-gradient(170deg,var(--navy-950) 0%,#08111E 40%,var(--navy-950) 100%);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--gold-500),transparent);opacity:.5}.auth-card{width:100%;max-width:440px;background:var(--navy-900);border:1px solid rgba(212,168,83,.1);border-radius:var(--radius-xl);padding:40px 36px;box-shadow:var(--shadow-lg),0 0 60px #d4a8530a;animation:slideUp .5s var(--spring-soft)}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--text-inverse);box-shadow:0 4px 16px #d4a85333}.auth-logo h1{font-size:1.75rem;font-weight:800;letter-spacing:-.03em}.auth-logo h1 span{color:var(--gold-400)}.auth-logo p{font-size:.875rem;color:var(--text-secondary);margin-top:4px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-form .input-group label{color:var(--text-secondary)}.auth-input-wrapper{position:relative}.auth-input-wrapper .input{width:100%;padding-right:44px}.auth-input-wrapper .toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;color:var(--text-tertiary);padding:4px;transition:color var(--transition-fast)}.auth-input-wrapper .toggle-password:hover{color:var(--gold-400)}.auth-error{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger-400);font-size:.8125rem;animation:fadeSlideUp .2s ease-out}.auth-submit{width:100%;padding:13px;font-size:.9375rem}.auth-divider{display:flex;align-items:center;gap:16px;color:var(--text-tertiary);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-primary)}.auth-demo-accounts{display:flex;flex-direction:column;gap:8px}.demo-btn{width:100%;padding:12px;background:var(--navy-800);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;font-weight:500;transition:all .2s var(--spring-soft);display:flex;align-items:center;justify-content:center;gap:10px}.demo-btn:hover{background:var(--navy-700);border-color:#d4a85333;color:var(--text-primary);transform:translateY(-1px)}.demo-btn .demo-icon{font-size:1.25rem}.auth-link{text-align:center;margin-top:24px;font-size:.8125rem;color:var(--text-secondary)}.auth-link a{color:var(--gold-400);font-weight:600;transition:color var(--transition-fast)}.auth-link a:hover{color:var(--gold-300)}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px}.role-option{padding:14px;background:var(--navy-800);border:1.5px solid var(--border-primary);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all .2s var(--spring-soft);color:var(--text-secondary)}.role-option:hover{border-color:var(--border-hover);background:var(--navy-700)}.role-option.active{border-color:var(--gold-500);background:#d4a85314;color:var(--gold-400)}.role-option-icon{font-size:1.75rem;margin-bottom:6px}.role-option-label{font-size:.8125rem;font-weight:600}@media(max-width:480px){.auth-card{padding:28px 20px}}.dashboard{animation:fadeSlideUp .35s var(--spring-soft) both}.dashboard .stat-card{position:relative;overflow:hidden}.dashboard .stat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold-500),transparent);opacity:0;transition:opacity var(--transition-base)}.dashboard .stat-card:hover:after{opacity:1}.dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:24px}.dashboard-sidebar{display:flex;flex-direction:column;gap:20px}.dashboard-section{padding:0!important}.dashboard-section-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid var(--border-primary)}.dashboard-section-header h2{font-size:.9375rem;font-weight:700;display:flex;align-items:center;gap:10px}.dashboard-section-header h2 svg{color:var(--gold-400)}.dashboard-list{padding:6px 20px}.dashboard-list-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--border-primary);transition:all var(--transition-fast)}.dashboard-list-item:last-child{border-bottom:none}.dashboard-list-item:hover{padding-left:4px}.dashboard-list-color{width:4px;height:36px;border-radius:var(--radius-full);flex-shrink:0}.dashboard-list-info{flex:1;min-width:0;display:flex;flex-direction:column}.dashboard-list-title{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-list-meta{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.dashboard-list-badge{flex-shrink:0}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-class-list{padding:12px 20px;display:flex;flex-direction:column;gap:12px}.dashboard-class-item{display:flex;align-items:center;gap:12px;padding:8px 0;transition:transform var(--transition-fast);text-decoration:none;color:inherit}.dashboard-class-item:hover{transform:translate(4px)}.dashboard-class-color{width:6px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.classes-page{animation:fadeSlideUp .35s var(--spring-soft) both}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.class-card{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column}.class-card-header{padding:20px 22px 16px;position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-height:70px}.class-card-subject{font-size:.875rem;font-weight:600;color:#ffffffe6}.class-card-code-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#00000040;border-radius:6px;color:#ffffffd9;font-size:.6875rem;font-family:monospace;font-weight:600;border:none;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.class-card-code-btn:hover{background:#0006}.class-card-body{padding:18px 22px 22px;flex:1;display:flex;flex-direction:column}.class-card-body h3{font-size:1.0625rem;font-weight:700;margin-bottom:4px}.class-card-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.class-card-stats{display:flex;align-items:center;gap:16px;font-size:.8125rem;color:var(--text-secondary);margin-top:auto}.class-card-stats span{display:inline-flex;align-items:center;gap:5px}.class-card-stats svg{color:var(--gold-400)}.class-card-teacher{font-size:.75rem;color:var(--text-tertiary);margin-top:8px}.class-detail{animation:fadeSlideUp .35s var(--spring-soft) both}.class-detail-header{padding:28px;border-radius:var(--radius-lg);margin-bottom:24px;position:relative;overflow:hidden}.class-detail-header h1{position:relative;z-index:1;color:#fff}.class-detail-header p{position:relative;z-index:1;color:#fffc}@media(max-width:640px){.classes-grid{grid-template-columns:1fr}}.class-detail-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;position:relative;z-index:1}.class-detail-meta span{display:inline-flex;align-items:center;gap:6px;font-size:.8125rem;color:#ffffffd9;background:#0003;padding:4px 10px;border-radius:8px}.class-loading{display:flex;align-items:center;justify-content:center;padding:80px 0;color:var(--text-secondary);font-size:1.0625rem}.subjects-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.subject-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:var(--navy-800);border:1px solid var(--border-primary);font-size:.8125rem;color:var(--text-primary);font-weight:500}.subject-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subject-add{cursor:pointer;background:transparent;border-style:dashed;color:var(--text-secondary);transition:all var(--transition-fast)}.subject-add:hover{border-color:var(--gold-400);color:var(--gold-400)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-primary);margin-bottom:20px}.tab{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--gold-400);border-bottom-color:var(--gold-400)}.tab-content{animation:fadeIn .2s ease-out}.students-actions,.materials-actions,.forum-actions{display:flex;justify-content:flex-end;margin-bottom:16px}.student-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.student-card.student-paused{opacity:.55}.student-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.student-actions{display:flex;gap:4px;flex-shrink:0}.enrollment-links-section{background:var(--navy-850);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:16px}.enrollment-link-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-secondary)}.enrollment-link-card:last-child{border-bottom:none}.enrollment-link-card.expired{opacity:.4}.enrollment-link-info{display:flex;flex-direction:column;gap:2px;min-width:0}.enrollment-link-url{font-size:.75rem;color:var(--gold-400);background:var(--navy-900);padding:2px 6px;border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:360px}.enrollment-link-actions{display:flex;gap:4px}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.material-card{display:flex;align-items:center;gap:12px;padding:14px 16px!important}.material-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold-400)}.material-card-info{flex:1;min-width:0}.material-card-info h4{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.material-card-actions{display:flex;gap:4px;flex-shrink:0}.viewer-overlay{z-index:1100}.viewer-container{background:var(--navy-900);border:1px solid var(--border-primary);border-radius:var(--radius-xl);width:90vw;height:85vh;max-width:1200px;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .35s var(--spring-soft);box-shadow:var(--shadow-lg)}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.viewer-header h3{font-size:1rem;font-weight:600}.viewer-content{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:var(--navy-950)}.viewer-iframe{width:100%;height:100%;border:none}.viewer-video{max-width:100%;max-height:100%}.viewer-image{max-width:100%;max-height:100%;object-fit:contain}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h2{font-size:1.25rem;font-weight:700}@media(max-width:640px){.tabs{overflow-x:auto}.tab{padding:8px 12px;font-size:.8125rem;white-space:nowrap}.student-card{flex-direction:column;align-items:flex-start}.student-actions{width:100%;justify-content:flex-end}.materials-grid{grid-template-columns:1fr}.enrollment-link-url{max-width:200px}.viewer-container{width:100vw;height:100vh;border-radius:0}}.activities-page{animation:fadeSlideUp .35s var(--spring-soft) both}.activities-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.activities-filters .select{min-width:180px}.activities-list{display:flex;flex-direction:column;gap:12px}.activity-card{display:flex;flex-direction:column;padding:0;overflow:hidden}.activity-card-top{display:flex;align-items:center;gap:16px;padding:18px 22px}.activity-card-color{width:5px;height:44px;border-radius:var(--radius-full);flex-shrink:0}.activity-card-info{flex:1;min-width:0}.activity-card-info h3{font-size:.9375rem;font-weight:600;margin-bottom:2px}.activity-card-class{font-size:.75rem;color:var(--text-secondary)}.activity-card-desc{font-size:.8125rem;color:var(--text-tertiary);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-card-bottom{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:#16305026;border-top:1px solid var(--border-primary)}.activity-card-meta{display:flex;align-items:center;gap:14px;font-size:.8125rem;color:var(--text-secondary)}.activity-card-points{font-weight:700;color:var(--gold-400)}.activity-card-date{font-size:.75rem}.activity-card-date.expired{color:var(--danger-400)}.activity-detail{animation:fadeSlideUp .35s var(--spring-soft) both}.activity-detail-content{display:grid;grid-template-columns:1fr 300px;gap:24px}.activity-detail-header{display:flex;align-items:flex-start;gap:16px}.activity-detail-header .activity-card-color{width:5px;height:auto;align-self:stretch;border-radius:var(--radius-full)}.activity-detail-header h1{font-size:1.25rem;font-weight:800;letter-spacing:-.01em}.activity-body{white-space:pre-wrap;line-height:1.8;font-size:.9375rem;color:var(--text-secondary)}.create-activity{animation:fadeSlideUp .35s var(--spring-soft) both}.create-activity-form{max-width:720px;display:flex;flex-direction:column;gap:20px}.submission-item{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border-primary);cursor:pointer;transition:background var(--transition-fast)}.submission-item:last-child{border-bottom:none}.submission-item:hover{background:var(--bg-card-hover)}.submission-form{display:flex;flex-direction:column}@media(max-width:768px){.activity-detail-content{grid-template-columns:1fr}}@media(max-width:640px){.activity-card-top{padding:14px 18px}.activity-card-bottom{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 18px}}.forum-page{animation:fadeSlideUp .35s var(--spring-soft) both}.forum-filters{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:20px}.forum-filters .select{max-width:280px}.forum-list{display:flex;flex-direction:column;gap:8px}.forum-topic{padding:16px 22px}.forum-topic-main{display:flex;align-items:center;justify-content:space-between;gap:16px}.forum-topic-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.forum-topic-info{flex:1;min-width:0}.forum-topic-title-row{display:flex;align-items:center;gap:8px}.forum-pin-icon{color:var(--gold-400);flex-shrink:0}.forum-topic-info h3{font-size:.9375rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forum-topic-meta{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.forum-topic-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.forum-replies-count{display:flex;align-items:center;gap:4px;font-size:.8125rem;color:var(--text-tertiary);font-weight:500}.topic-detail{animation:fadeSlideUp .35s var(--spring-soft) both;max-width:800px}.topic-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.topic-body{white-space:pre-wrap;line-height:1.8;font-size:.9375rem;color:var(--text-secondary)}.topic-replies{display:flex;flex-direction:column;gap:12px}.reply-card{padding:16px 20px}.reply-card.teacher-reply{border-left:3px solid var(--gold-500)}.reply-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.reply-body{white-space:pre-wrap;line-height:1.7;font-size:.875rem;color:var(--text-secondary)}.reply-form{border:1px solid var(--border-primary)}@media(max-width:640px){.forum-topic-main{flex-direction:column;align-items:flex-start}.forum-topic-right{margin-left:54px}.topic-header{flex-direction:column}}.grades-page{animation:fadeSlideUp .35s var(--spring-soft) both}.grades-bimester-tabs{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:4px;width:fit-content}.grades-bim-tab{padding:8px 18px;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.grades-bim-tab:hover{background:#d4a85314;color:var(--text-primary)}.grades-bim-tab.active{background:#d4a85326;color:var(--gold-400)}.grades-bim-badge{font-size:.6875rem;font-weight:700;color:var(--gold-400);background:#d4a8531a;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.grades-th-bim{display:block;font-size:.5625rem;color:var(--gold-400);margin-top:2px;font-weight:600}.grades-class-card{padding:0;overflow:hidden}.grades-class-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-primary);gap:12px}.grades-class-color{width:40px;height:40px;border-radius:var(--radius-md);flex-shrink:0}.grades-class-avg{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.grades-avg-value{font-size:1.5rem;font-weight:800}.grades-avg-value.good{color:var(--success-400)}.grades-avg-value.ok{color:var(--warning-400)}.grades-avg-value.low{color:var(--danger-400)}.grades-table{padding:0}.grades-table-header{display:grid;grid-template-columns:1fr 50px 100px 160px;padding:10px 22px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary)}.grades-table-row{display:grid;grid-template-columns:1fr 50px 100px 160px;padding:12px 22px;align-items:center;border-bottom:1px solid var(--border-primary);transition:all var(--transition-fast);font-size:.875rem}.grades-table-row:last-child{border-bottom:none}.grades-table-row:hover{background:var(--bg-card-hover)}.grades-activity-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.grades-bar-wrapper{display:flex;align-items:center;gap:8px}.grades-bar-wrapper .progress-bar{flex:1}.grades-teacher-table{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.grades-teacher-table table{width:100%;min-width:500px;border-collapse:collapse;font-size:.8125rem;table-layout:auto}.grades-teacher-table th{padding:10px 14px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);text-align:left;white-space:nowrap}.grades-teacher-table td{padding:10px 14px;border-bottom:1px solid var(--border-primary);white-space:nowrap}.grades-teacher-table tr:hover td{background:var(--bg-card-hover)}.grades-student-name{display:flex;align-items:center;gap:10px;font-weight:600;white-space:nowrap;min-width:140px}.grades-cell{text-align:center;font-weight:500}.grades-cell.empty{color:var(--text-tertiary)}.grades-cell.graded{color:var(--text-primary)}.grades-cell.pending{color:var(--gold-400)}.grades-avg-cell{font-weight:800;text-align:center}.grades-avg-cell.good{color:var(--success-400)}.grades-avg-cell.ok{color:var(--warning-400)}.grades-avg-cell.low{color:var(--danger-400)}@media(max-width:768px){.grades-table-header,.grades-table-row{grid-template-columns:1fr 40px 70px 100px;padding:10px 14px}}@media(max-width:480px){.grades-table-header,.grades-table-row{grid-template-columns:1fr 35px 60px 80px;font-size:.75rem;padding:8px 12px}}.settings-page{animation:fadeSlideUp .35s var(--spring-soft) both}.settings-layout{max-width:640px;display:flex;flex-direction:column;gap:24px}.settings-section-title{display:flex;align-items:center;gap:10px;font-size:1rem;font-weight:700;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.settings-avatar-section{display:flex;align-items:center;gap:16px;margin-bottom:24px}.settings-danger-zone{border-color:#ef444433}.settings-danger-zone .settings-section-title{color:var(--danger-400)}.settings-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.settings-section-header .settings-section-title{margin-bottom:0;padding-bottom:0;border-bottom:none}.school-list{display:flex;flex-direction:column;gap:8px}.school-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.school-item.active{border-color:#d4a8534d;background:#d4a8530a}.school-item:hover{border-color:var(--border-secondary)}.school-item-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px #00000026}.school-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.school-item-name{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.school-item-meta{font-size:.75rem;color:var(--text-tertiary)}.school-item-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.school-item:hover .school-item-actions{opacity:1}.school-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;text-align:center;color:var(--text-tertiary)}.school-color-picker{display:flex;gap:8px;flex-wrap:wrap}.school-color-option{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all var(--transition-fast)}.school-color-option:hover{transform:scale(1.15)}.school-color-option.selected{border-color:#fff;transform:scale(1.15);box-shadow:0 0 12px #fff3}.calendar-page{animation:fadeSlideUp .35s var(--spring-soft) both}.calendar-filters{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:20px}.calendar-filters .select{max-width:280px}.calendar-layout{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.calendar-card{padding:20px!important}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.calendar-nav h2{font-size:1.125rem;font-weight:700}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day-name{text-align:center;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:8px 0}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);position:relative;padding:4px;color:var(--text-primary)}.calendar-day:hover{background:#16305066}.calendar-day.other-month{color:var(--text-tertiary);opacity:.5}.calendar-day.today{background:#d4a8531f;border-color:var(--gold-500)}.calendar-day.today .calendar-day-number{color:var(--gold-400);font-weight:800}.calendar-day.selected{background:#d4a85333;border-color:var(--gold-400);box-shadow:0 0 0 2px #d4a85326}.calendar-day-number{font-size:.8125rem;font-weight:500;line-height:1}.calendar-day-dots{display:flex;gap:3px;min-height:6px}.calendar-dot{width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.calendar-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-primary)}.calendar-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary)}.calendar-sidebar{display:flex;flex-direction:column;gap:16px}.calendar-events-card{padding:18px!important}.calendar-events-title{font-size:.875rem;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border-primary)}.calendar-events-title svg{color:var(--gold-400)}.calendar-no-events{text-align:center;color:var(--text-tertiary);font-size:.8125rem;padding:20px 0;display:flex;flex-direction:column;align-items:center;gap:8px}.calendar-events-list{display:flex;flex-direction:column;gap:2px}.calendar-event-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);transition:background var(--transition-fast);background:transparent;border:none;color:var(--text-primary);text-align:left;width:100%;cursor:pointer}.calendar-event-item:hover{background:#1630504d}.calendar-event-color{width:4px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.calendar-event-info{flex:1;min-width:0}.calendar-event-info strong{font-size:.8125rem;font-weight:600;display:block}.calendar-event-title-row{display:flex;align-items:center;gap:6px}.calendar-event-title-row svg{color:var(--text-tertiary);flex-shrink:0}.calendar-event-desc{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.calendar-event-class{font-size:.6875rem;color:var(--gold-400);font-weight:600;margin-top:2px;display:block}.calendar-event-date{font-size:.6875rem;color:var(--text-tertiary);margin-top:2px;display:block}@media(max-width:1024px){.calendar-layout{grid-template-columns:1fr}}@media(max-width:640px){.calendar-day-number{font-size:.6875rem}.calendar-dot{width:4px;height:4px}.calendar-card{padding:12px!important}}.materials-page{animation:fadeSlideUp .35s var(--spring-soft) both}.materials-filters{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:20px;flex-wrap:wrap}.materials-search{position:relative;display:flex;align-items:center;flex:1;min-width:200px}.materials-search svg{position:absolute;left:14px;color:var(--text-tertiary);pointer-events:none}.materials-search .input{padding-left:40px;width:100%}.materials-filters .select{min-width:180px}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.material-card{display:flex;padding:0!important;overflow:hidden;flex-direction:column}.material-card-icon{height:80px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.material-card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column}.material-card-body h3{font-size:.9375rem;font-weight:700;margin-bottom:4px;line-height:1.3}.material-card-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:12px;flex:1}.material-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.material-card-class{font-size:.6875rem;color:var(--text-tertiary);font-weight:500}.material-card-bim{font-size:.625rem;font-weight:700;color:var(--gold-400);background:#d4a8531f;padding:2px 8px;border-radius:var(--radius-full)}.badge-pdf{background:#ef444426;color:#ef4444}.badge-video{background:#3b82f626;color:#3b82f6}.badge-document{background:#22c55e26;color:#22c55e}.badge-link{background:#d4a85326;color:var(--gold-400)}.material-viewer-page .page-header h1{font-size:1.125rem}.material-viewer-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.material-viewer-content{min-height:400px;display:flex;align-items:center;justify-content:center;padding:0!important;overflow:hidden}.material-viewer-video{width:100%}.material-video-player{width:100%;display:block;border-radius:var(--radius-lg);background:#000;max-height:70vh}.material-viewer-pdf{width:100%;height:70vh}.material-pdf-frame{width:100%;height:100%;border:none;border-radius:var(--radius-lg)}.material-viewer-doc{width:100%;padding:24px}.material-doc-content{white-space:pre-wrap;font-family:inherit;font-size:.9375rem;line-height:1.8;color:var(--text-secondary)}.material-viewer-link{width:100%;display:flex;flex-direction:column;align-items:center}.material-link-frame{width:100%;height:60vh;border:none;border-radius:var(--radius-lg)}.material-viewer-placeholder{text-align:center;padding:60px 30px;color:var(--text-tertiary);display:flex;flex-direction:column;align-items:center;gap:12px}.material-viewer-placeholder h3{font-size:1rem;color:var(--text-primary)}.material-viewer-placeholder p{font-size:.875rem;max-width:400px}.material-viewer-sidebar{display:flex;flex-direction:column;gap:16px}.material-viewer-info h3{font-size:.875rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-primary)}.material-info-list{display:flex;flex-direction:column;gap:10px}.material-info-row{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.material-info-row>span:first-child{color:var(--text-tertiary)}.material-info-row>span:last-child{font-weight:600}@media(max-width:768px){.material-viewer-layout,.materials-grid{grid-template-columns:1fr}}.admin-dashboard{max-width:1200px}.admin-header{margin-bottom:28px}.admin-title{display:flex;align-items:center;gap:12px;font-size:1.75rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.admin-subtitle{color:var(--text-tertiary);font-size:.9375rem;margin-top:4px;margin-left:40px}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;transition:all var(--transition-fast)}.admin-stat-card:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.admin-stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-info{display:flex;flex-direction:column}.admin-stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.admin-stat-label{font-size:.8125rem;color:var(--text-tertiary);margin-top:2px}.admin-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}.admin-section-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border-primary)}.admin-section-header h2{display:flex;align-items:center;gap:10px;font-size:1.0625rem;font-weight:700;color:var(--text-primary)}.admin-action-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));border:none;border-radius:var(--radius-md);color:var(--text-inverse);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.admin-action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4a8534d}.admin-table-header,.admin-table-row{display:grid;grid-template-columns:1.5fr 1.2fr .8fr .6fr;padding:12px 24px;align-items:center;gap:12px}.admin-table-header{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);background:#ffffff03}.admin-table-row{font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}.admin-table-row:last-child{border-bottom:none}.admin-table-row:hover{background:#ffffff05}.admin-teacher-info{display:flex;align-items:center;gap:12px;color:var(--text-primary);font-weight:500}.admin-teacher-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;flex-shrink:0}.admin-email{color:var(--text-tertiary);font-size:.8125rem}.admin-classes-count{color:var(--text-secondary);font-size:.8125rem}.admin-status{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);width:fit-content}.admin-status.active{background:#22c55e1a;color:#22c55e}.admin-status.blocked{background:#ef44441a;color:#ef4444}.admin-classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:20px 24px}.admin-class-card{background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden;display:flex;transition:all var(--transition-fast)}.admin-class-card:hover{border-color:var(--border-secondary);transform:translateY(-1px)}.admin-class-color{width:4px;flex-shrink:0}.admin-class-info{padding:14px 16px;flex:1}.admin-class-info h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.admin-class-teacher{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:8px}.admin-class-meta{display:flex;gap:16px;font-size:.75rem;color:var(--text-secondary)}.admin-class-meta span{display:flex;align-items:center;gap:4px}.admin-overview-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:20px 24px}.admin-overview-card{background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:16px 20px;text-align:center}.admin-overview-label{display:block;font-size:.75rem;color:var(--text-tertiary);margin-bottom:8px}.admin-overview-value{display:block;font-size:1.5rem;font-weight:800;color:var(--gold-400)}.admin-empty{padding:32px 24px;text-align:center;color:var(--text-tertiary);font-size:.875rem}@media(max-width:768px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-table-header,.admin-table-row{grid-template-columns:1fr .6fr}.admin-table-header span:nth-child(2),.admin-table-row span:nth-child(2),.admin-email{display:none}.admin-overview-cards,.admin-classes-grid{grid-template-columns:1fr}}
