*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--gold: #C4A13A;--gold-dark: #9E7F28;--gold-light: #E8C96A;--gold-bg: rgba(196,161,58,.1);--bg: #F2EFE8;--surface: #FFFFFF;--black: #18181B;--gray: #71717A;--gray-light: #D4CEC3;--gray-bg: #F4F4F5;--border: #E4E0D8;--error: #DC2626;--error-bg: #FEF2F2;--error-border: #FECACA;--success: #16A34A;--success-bg: #F0FDF4;--success-border: #BBF7D0;--warning: #D97706;--info: #2563EB;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 4px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 16px rgba(0,0,0,.09), 0 1px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 40px rgba(0,0,0,.14), 0 4px 12px rgba(0,0,0,.08);--card-border: #D9D4CA;--card-shadow: 0 1px 3px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.06);--card-shadow-hover: 0 4px 18px rgba(0,0,0,.12), 0 1px 4px rgba(0,0,0,.06);--radius: 14px;--radius-sm: 8px;--sidebar-w: 248px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--black);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:#111113;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .26s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(255,255,255,.06)}.sidebar-brand{padding:20px 18px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:11px}.sidebar-logo{width:38px;height:38px;border-radius:10px;object-fit:contain;background:#ffffff14;padding:4px;flex-shrink:0}.sidebar-name{font-size:15px;font-weight:700;color:#fff;line-height:1.2;letter-spacing:-.01em}.sidebar-name span{display:block;font-size:10px;font-weight:500;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-top:3px;opacity:.9}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;color:#ffffff80;font-weight:500;font-size:13.5px;transition:background .14s,color .14s;position:relative;letter-spacing:-.005em}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:#c4a13a1f;color:var(--gold-light);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:3px;background:var(--gold);border-radius:0 2px 2px 0}.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;opacity:.85}.nav-item.active .nav-icon{opacity:1}.sidebar-bottom{padding:14px;border-top:1px solid rgba(255,255,255,.06)}.user-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:9px 10px;border-radius:9px;background:#ffffff0a}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--gold);color:#111;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:10px;color:var(--gold);margin-top:1px;letter-spacing:.06em;text-transform:uppercase;opacity:.85}.logout-btn{width:100%;padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:transparent;color:#fff6;font-size:12.5px;font-weight:500;transition:background .14s,color .14s,border-color .14s}.logout-btn:hover{background:#dc26261f;color:#fca5a5;border-color:#dc262640}.main-wrap{flex:1;margin-left:var(--sidebar-current, var(--sidebar-w));display:flex;flex-direction:column;min-height:100vh;transition:margin-left .22s cubic-bezier(.4,0,.2,1)}.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-xs)}.topbar-menu{display:none;background:none;border:none;font-size:20px;color:var(--black);padding:5px 8px;border-radius:7px}.topbar-menu:hover{background:var(--gray-bg)}.topbar-logo{width:28px;height:28px;object-fit:contain;border-radius:7px;background:var(--bg);padding:2px}.topbar-title{font-size:13px;font-weight:600;color:var(--gray);letter-spacing:-.01em}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.topbar-user{display:flex;align-items:center;gap:7px;padding:5px 11px;border-radius:20px;background:var(--gray-bg);border:1px solid var(--border);transition:background .14s,border-color .14s}.topbar-user:hover{background:var(--bg);border-color:var(--gray-light)}.topbar-avatar{width:26px;height:26px;border-radius:50%;background:var(--black);color:var(--gold);font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center}.topbar-uname{font-size:12.5px;font-weight:600;color:var(--black)}.page-content{padding:24px 28px;flex:1}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:12px}.page-header h1{font-size:21px;font-weight:800;color:var(--black);margin-bottom:3px;letter-spacing:-.03em}.page-header p{font-size:13px;color:var(--gray)}.btn{padding:9px 18px;border-radius:9px;font-weight:600;font-size:13.5px;border:none;transition:background .14s,opacity .14s,transform .1s,box-shadow .14s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;letter-spacing:-.01em}.btn:active{transform:scale(.97)}.btn-gold{background:var(--gold);color:var(--black);box-shadow:0 1px 3px #c4a13a4d}.btn-gold:hover{background:var(--gold-dark);box-shadow:0 2px 8px #c4a13a59}.btn-dark{background:var(--black);color:var(--gold)}.btn-dark:hover{background:#27272a}.btn-ghost{background:var(--surface);color:var(--black);border:1px solid var(--border)}.btn-ghost:hover{background:var(--gray-bg);border-color:var(--gray-light)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:5px 12px;font-size:12px;border-radius:6px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--card-border);box-shadow:var(--card-shadow);overflow:hidden;transition:box-shadow .2s,border-color .2s,transform .15s}.card:hover{box-shadow:var(--card-shadow-hover);border-color:var(--gray-light);transform:translateY(-1px)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:26px}.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--card-border);padding:20px;display:flex;align-items:center;gap:16px;text-decoration:none;position:relative;overflow:hidden;transition:box-shadow .2s,transform .15s,border-color .2s;box-shadow:var(--card-shadow)}.stat-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px);border-color:var(--gray-light)}.stat-bar{position:absolute;top:0;left:0;right:0;height:3px}.stat-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.stat-card-body{flex:1;min-width:0}.stat-emoji{font-size:28px}.stat-count{font-size:28px;font-weight:800;line-height:1;letter-spacing:-.04em;margin-bottom:3px}.stat-label{font-size:12px;color:var(--gray);font-weight:500}.stat-arrow{color:var(--gray-light);font-size:14px;flex-shrink:0}.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.quick-card{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--radius);padding:16px 18px;border:1px solid var(--card-border);text-decoration:none;transition:box-shadow .2s,transform .15s,border-color .2s;box-shadow:var(--card-shadow)}.quick-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px);border-color:var(--gold-light)}.quick-icon{width:42px;height:42px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;border:1px solid var(--border)}.quick-emoji{font-size:26px;flex-shrink:0}.quick-title{font-size:14px;font-weight:700;color:var(--black);letter-spacing:-.01em}.quick-sub{font-size:12px;color:var(--gray);margin-top:2px}.quick-arrow{margin-left:auto;font-size:14px;color:var(--gray-light)}.section-title{font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}.search-bar{width:100%;padding:9px 13px;border-radius:9px;border:1px solid var(--border);background:var(--surface);font-size:13.5px;color:var(--black);outline:none;margin-bottom:14px;transition:border-color .14s,box-shadow .14s;box-shadow:var(--shadow-xs)}.search-bar:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c4a13a1a}.search-bar::placeholder{color:var(--gray-light)}.list{display:flex;flex-direction:column;gap:7px}.empty-state{text-align:center;padding:54px 20px;color:var(--gray);font-size:14px}.empty-icon{font-size:36px;margin-bottom:10px;opacity:.4}.act-btn{padding:4px 11px;border-radius:6px;border:1px solid var(--border);background:none;font-size:12px;font-weight:600;color:var(--black);transition:background .14s,border-color .14s;white-space:nowrap}.act-btn:hover{background:var(--gray-bg);border-color:var(--gray-light)}.act-btn.warn{border-color:#d9770666;color:var(--warning)}.act-btn.warn:hover{background:#d977060f}.act-btn.ok{border-color:#16a34a66;color:var(--success)}.act-btn.ok:hover{background:#16a34a0f}.act-btn.danger{border-color:#dc262666;color:var(--error)}.act-btn.danger:hover{background:#dc26260f}.badge{display:inline-flex;align-items:center;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.02em}.badge-gold{background:#c4a13a1f;color:var(--gold-dark);border:1px solid rgba(196,161,58,.25)}.badge-type{color:#fff;text-transform:capitalize}.subject-tag{background:var(--gray-bg);border:1px solid var(--border);border-radius:5px;padding:2px 8px;font-size:11px;color:var(--gray);font-weight:500}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-box{background:var(--surface);border-radius:14px;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modalIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:none}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:15px;font-weight:700;letter-spacing:-.02em}.modal-close{width:28px;height:28px;border-radius:7px;background:var(--gray-bg);border:none;font-size:13px;color:var(--gray);display:flex;align-items:center;justify-content:center;transition:background .14s}.modal-close:hover{background:var(--border);color:var(--black)}.modal-body{padding:18px 20px;overflow-y:auto;flex:1}.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}.field{margin-bottom:13px}.field-label{display:block;font-size:12px;font-weight:600;color:var(--gray);margin-bottom:5px;letter-spacing:.01em}.field-input,.field-select{width:100%;padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);font-size:13.5px;color:var(--black);outline:none;transition:border-color .14s,box-shadow .14s}.field-input:focus,.field-select:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c4a13a1a;background:var(--surface)}.field-input::placeholder{color:var(--gray-light)}.err-box{background:var(--error-bg);border:1px solid var(--error-border);border-radius:8px;padding:9px 12px;color:var(--error);font-size:13px;margin-bottom:13px}.ok-box{background:var(--success-bg);border:1px solid var(--success-border);border-radius:8px;padding:9px 12px;color:var(--success);font-size:13px;margin-bottom:13px}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:16px;background-image:radial-gradient(ellipse at 20% 50%,rgba(196,161,58,.07) 0%,transparent 55%),radial-gradient(ellipse at 80% 10%,rgba(196,161,58,.04) 0%,transparent 50%)}.login-card{background:var(--surface);border-radius:18px;padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--border)}.login-logo{width:76px;height:76px;object-fit:contain;margin:0 auto 16px;display:block;border-radius:14px;background:var(--bg);padding:6px}.login-title{font-size:21px;font-weight:800;color:var(--black);margin-bottom:5px;letter-spacing:-.03em}.login-sub{font-size:13px;color:var(--gray);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:14px;text-align:left}.login-btn{margin-top:4px;padding:11px;border-radius:9px;background:var(--black);color:var(--gold);font-weight:700;font-size:14px;border:none;transition:background .14s;letter-spacing:-.01em}.login-btn:hover{background:#27272a}.login-btn:disabled{opacity:.55}.tag-chip{background:var(--gray-bg);border:1px solid var(--border);border-radius:5px;padding:3px 10px;font-size:12px;color:var(--gray);font-weight:500;transition:background .14s;display:inline-flex;align-items:center;gap:4px}.tag-chip:hover{background:var(--border);color:var(--black)}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.welcome-banner{background:var(--black);border-radius:var(--radius);padding:18px 22px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;overflow:hidden;position:relative}.welcome-banner:before{content:"";position:absolute;top:-30px;right:-20px;width:130px;height:130px;border-radius:50%;background:#c4a13a0f}.welcome-banner-text h2{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:3px}.welcome-banner-text p{font-size:13px;color:#ffffff7a}.welcome-badge{background:#c4a13a24;border:1px solid rgba(196,161,58,.25);border-radius:7px;padding:5px 11px;color:var(--gold-light);font-size:11.5px;font-weight:600;white-space:nowrap;flex-shrink:0;position:relative;z-index:1}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--gray-bg);border:1px solid var(--border);border-radius:9px;padding:6px 12px;transition:border-color .14s,box-shadow .14s;max-width:220px;flex:1}.topbar-search:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px #c4a13a1a;background:var(--surface)}.topbar-search-icon{color:var(--gray);flex-shrink:0}.topbar-search-input{border:none;background:transparent;outline:none;font-size:13px;color:var(--black);width:100%}.topbar-search-input::placeholder{color:var(--gray-light)}.topbar-icon-btn{width:34px;height:34px;border-radius:8px;background:var(--gray-bg);border:1px solid var(--border);color:var(--gray);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:background .14s,border-color .14s,color .14s}.topbar-icon-btn:hover{background:var(--bg);color:var(--black);border-color:var(--gray-light)}.topbar-notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--error);border:1.5px solid var(--surface)}.profile-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--card-border);border-radius:11px;box-shadow:var(--card-shadow-hover);min-width:210px;z-index:100;padding:10px}.profile-dropdown-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding-bottom:10px;border-bottom:1px solid var(--border)}.profile-dd-avatar{width:38px;height:38px;border-radius:50%;background:var(--black);color:var(--gold);font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-dd-name{font-weight:700;font-size:13.5px;color:var(--black);letter-spacing:-.01em}.profile-dd-email{font-size:11.5px;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.profile-dd-role{font-size:10.5px;color:var(--gold-dark);font-weight:600;margin-top:2px;letter-spacing:.05em;text-transform:uppercase}.profile-dd-logout{width:100%;padding:7px 10px;background:var(--error-bg);border:1px solid var(--error-border);border-radius:7px;color:var(--error);font-size:12.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px}.profile-dd-logout:hover{background:#fee2e2}.hero-banner{background:linear-gradient(135deg,#18181b,#27272a 60%,#1a1a20);border-radius:16px;padding:26px 28px;margin-bottom:24px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.07);box-shadow:0 4px 24px #0000002e}.hero-banner-glow{position:absolute;top:-40px;right:-40px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(196,161,58,.15) 0%,transparent 70%);pointer-events:none}.hero-banner-content{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}.hero-banner-greeting{font-size:20px;font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:4px}.hero-banner-date{font-size:12.5px;color:#ffffff73;margin-bottom:3px;font-weight:500}.hero-banner-sub{font-size:13px;color:#ffffff61}.hero-stat-pill{display:flex;align-items:center;gap:5px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:5px 11px;color:#ffffffbf;font-size:12px;font-weight:500}.hero-role-badge{display:flex;align-items:center;gap:5px;background:#c4a13a26;border:1px solid rgba(196,161,58,.28);border-radius:20px;padding:5px 12px;color:var(--gold-light);font-size:12px;font-weight:600}.stat-grid-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card-v2{background:var(--surface);border:1px solid var(--card-border);border-radius:14px;padding:20px 20px 16px;text-decoration:none;display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;box-shadow:var(--card-shadow);transition:box-shadow .2s,transform .15s,border-color .2s;position:relative;overflow:hidden}.stat-card-v2:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px);border-color:var(--gray-light)}.stat-card-v2 .stat-bar{height:5px;border-radius:0;width:100%}.stat-card-v2-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0}.stat-card-v2-count{font-size:32px;font-weight:800;line-height:1;letter-spacing:-.05em;margin-bottom:5px;text-align:center}.stat-card-v2-label{font-size:13px;color:var(--gray);font-weight:500;margin-bottom:16px;text-align:center}.stat-card-v2-footer{display:flex;align-items:center;gap:5px;margin-top:auto;padding-top:8px}.quick-card-v2{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--card-border);border-radius:12px;padding:14px 16px;text-decoration:none;box-shadow:var(--card-shadow);transition:box-shadow .2s,transform .15s,border-color .2s}.quick-card-v2:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-1px);border-color:var(--gold-light)}.quick-card-v2-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-card-v2-title{font-size:13.5px;font-weight:700;color:var(--black);letter-spacing:-.01em}.quick-card-v2-sub{font-size:12px;color:var(--gray);margin-top:2px}.quick-card-v2-arrow{color:var(--gray-light);transition:color .14s,transform .14s}.quick-card-v2:hover .quick-card-v2-arrow{color:var(--gold);transform:translate(2px)}.recent-teacher-row{display:flex;align-items:center;gap:11px;padding:11px 14px;transition:background .14s}.recent-teacher-row:hover{background:var(--gray-bg)}.recent-teacher-avatar{width:34px;height:34px;border-radius:50%;background:var(--black);color:var(--gold);font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.recent-teacher-name{font-size:13px;font-weight:600;color:var(--black);letter-spacing:-.01em}.recent-teacher-meta{font-size:11.5px;color:var(--gray);margin-top:1px}.recent-teacher-badge{font-size:10.5px;font-weight:600;border-radius:5px;padding:2px 8px;border:1px solid;flex-shrink:0}.recent-teacher-badge.active{color:var(--success);background:var(--success-bg);border-color:var(--success-border)}.recent-teacher-badge.inactive{color:var(--error);background:var(--error-bg);border-color:var(--error-border)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray)}@media (max-width: 1024px){.stat-grid-v2{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main-wrap{margin-left:0!important}.topbar-menu{display:flex}.topbar-title{display:none}.page-content{padding:14px 16px}.stat-grid,.stat-grid-v2{grid-template-columns:repeat(2,1fr)}.quick-grid{grid-template-columns:1fr}.login-card{padding:28px 20px}.welcome-banner,.hero-banner-content{flex-direction:column;align-items:flex-start}.topbar-search{max-width:140px}}@media (max-width: 640px){.stat-grid-v2{grid-template-columns:1fr 1fr}.topbar-search{display:none}}
