*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fdf8f3;--bg2: #f5ede0;--surface: #ffffff;--surface2: #fdf6ef;--border: #e9ddd0;--border2: #d5c0aa;--brand: #bf4010;--brand-h: #d4500f;--brand-bg: #fff2ed;--brand-border: #f9c4ae;--amber: #c47d0a;--amber-bg: #fffbeb;--amber-border: #fde68a;--green: #15803d;--green-bg: #f0fdf4;--green-border: #86efac;--blue: #1d4ed8;--blue-bg: #eff6ff;--blue-border: #93c5fd;--red: #b91c1c;--red-bg: #fef2f2;--red-border: #fca5a5;--purple: #6d28d9;--purple-bg: #f5f3ff;--text: #1a1008;--text2: #6b5540;--text3: #a8896e;--ff: "Plus Jakarta Sans", sans-serif;--ff-brand: "Bebas Neue", cursive;--r: 14px;--r2: 9px;--r3: 6px;--shadow-sm: 0 1px 4px rgba(80,40,10,.08), 0 2px 8px rgba(80,40,10,.06);--shadow: 0 4px 16px rgba(80,40,10,.1), 0 1px 4px rgba(80,40,10,.06);--shadow-lg: 0 8px 32px rgba(80,40,10,.14), 0 2px 8px rgba(80,40,10,.08);--shadow-brand: 0 3px 12px rgba(191,64,16,.3)}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--ff);font-size:15px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}img,svg{display:block}button{font-family:var(--ff)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes pop{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.header{position:sticky;top:0;z-index:100;background:#fdf8f3f5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 20px;height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}.header-brand{display:flex;align-items:center;gap:9px;flex-shrink:0}.header-brand .logo-img{height:32px}.header-brand .brand-text{font-family:var(--ff-brand);font-size:1.35rem;letter-spacing:.06em;color:var(--text2);white-space:nowrap}.header-brand .brand-text span{color:var(--brand)}.header-badge{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:4px;background:var(--brand-bg);color:var(--brand);border:1px solid var(--brand-border);margin-left:2px;white-space:nowrap}.header-nav{display:flex;align-items:center;gap:2px}.nav-btn{background:none;border:none;cursor:pointer;font-family:var(--ff);font-size:.8rem;font-weight:600;color:var(--text2);padding:6px 11px;border-radius:var(--r3);transition:all .18s;text-decoration:none;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.nav-btn:hover{color:var(--text);background:var(--bg2)}.nav-btn.active{color:var(--brand);background:var(--brand-bg)}.nav-btn.danger:hover{color:var(--red);background:var(--red-bg)}.mobile-nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--r3);color:var(--text2);font-size:1.3rem;line-height:1;transition:background .15s}.mobile-nav-toggle:hover{background:var(--bg2)}.mobile-nav-drawer{display:none!important;position:fixed;top:60px;left:0;right:0;bottom:0;background:var(--surface);z-index:99;overflow-y:auto;padding:16px;border-top:1px solid var(--border);animation:fadeIn .15s ease;flex-direction:column;gap:4px}.mobile-nav-item{display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:var(--r2);font-size:.95rem;font-weight:600;color:var(--text);background:none;border:none;cursor:pointer;font-family:var(--ff);text-align:left;transition:background .15s}.mobile-nav-item:hover{background:var(--bg2)}.mobile-nav-item.active{background:var(--brand-bg);color:var(--brand)}.mobile-nav-item.danger{color:var(--red)}.mobile-nav-item.danger:hover{background:var(--red-bg)}.mobile-nav-divider{border:none;border-top:1px solid var(--border);margin:8px 0}.mobile-nav-email{padding:8px 16px 12px;font-size:.8rem;color:var(--text3)}.account-wrap{position:relative}.account-avatar{width:34px;height:34px;border-radius:50%;background:var(--brand-bg);border:1.5px solid var(--brand-border);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .18s;color:var(--brand);flex-shrink:0;-webkit-user-select:none;user-select:none}.account-avatar:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);min-width:190px;box-shadow:var(--shadow-lg);animation:pop .15s ease;overflow:hidden;z-index:150}.dropdown-header{padding:12px 16px 8px;border-bottom:1px solid var(--border)}.dropdown-email{font-size:.75rem;color:var(--text3);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:.88rem;color:var(--text);background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.dropdown-item:hover{background:var(--bg2)}.dropdown-item.danger{color:var(--red)}.dropdown-item.danger:hover{background:var(--red-bg)}.main-content{flex:1;max-width:700px;width:100%;margin:0 auto;padding:28px 16px}.main-content.wide{max-width:1060px}.footer{text-align:center;padding:20px 16px;color:var(--text3);font-size:.78rem;border-top:1px solid var(--border)}.auth-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse 55% 45% at 8% 92%,rgba(191,64,16,.07) 0%,transparent 50%),radial-gradient(ellipse 45% 40% at 92% 8%,rgba(196,125,10,.05) 0%,transparent 50%),var(--bg)}.auth-brand{text-align:center;margin-bottom:28px;animation:fadeUp .4s ease}.auth-brand .big-emoji{font-size:3rem;display:block;margin-bottom:10px}.auth-brand h1{font-family:var(--ff-brand);font-size:2.8rem;letter-spacing:.06em;color:var(--text);line-height:1}.auth-brand h1 span{color:var(--brand)}.auth-brand p{color:var(--text2);font-size:.9rem;margin-top:7px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm);animation:fadeUp .3s ease both}.card+.card{margin-top:14px}.card-title{font-family:var(--ff-brand);font-size:1.2rem;letter-spacing:.04em;margin-bottom:5px;color:var(--text)}.card-subtitle{color:var(--text2);font-size:.85rem;margin-bottom:18px;line-height:1.5}.card-divider{border:none;border-top:1px solid var(--border);margin:18px -22px}.section-title{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.field{margin-bottom:14px}.field:last-child{margin-bottom:0}.label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);margin-bottom:5px}.input,.select,textarea{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r2);color:var(--text);font-family:var(--ff);font-size:.92rem;padding:10px 13px;outline:none;transition:border-color .18s,box-shadow .18s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.input::placeholder,textarea::placeholder{color:var(--text3)}.input:focus,.select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #bf40101a}.input:disabled{opacity:.5;cursor:not-allowed;background:var(--bg2)}.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23a8896e' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}.select option{background:#fff}.input-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.check-group{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px}.check-pill{display:flex;align-items:center;gap:5px;padding:6px 13px;border-radius:100px;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;font-size:.84rem;color:var(--text2);transition:all .16s;-webkit-user-select:none;user-select:none;font-weight:500}.check-pill input{display:none}.check-pill.on{border-color:var(--brand);background:var(--brand-bg);color:var(--brand)}.check-pill:hover{border-color:var(--border2);color:var(--text)}.check-pill.on:hover{border-color:var(--brand-h)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--ff);font-size:.88rem;font-weight:600;border:none;border-radius:var(--r2);padding:9px 18px;cursor:pointer;transition:all .18s;white-space:nowrap;position:relative}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){background:var(--brand-h);transform:translateY(-1px);box-shadow:0 5px 16px #bf401061}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg2);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--border2);background:var(--border)}.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border2);background:var(--bg2)}.btn-danger{background:var(--red-bg);color:var(--red);border:1.5px solid var(--red-border)}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-success{background:var(--green-bg);color:var(--green);border:1.5px solid var(--green-border)}.btn-success:hover:not(:disabled){background:#dcfce7}.btn-amber{background:var(--amber-bg);color:var(--amber);border:1.5px solid var(--amber-border)}.btn-sm{padding:5px 11px;font-size:.79rem;border-radius:var(--r3)}.btn-lg{padding:12px 24px;font-size:.94rem;width:100%;border-radius:var(--r2)}.btn-icon{padding:7px;border-radius:var(--r2);background:var(--bg2);border:1.5px solid var(--border);color:var(--text2);line-height:1}.btn-icon:hover{color:var(--text);border-color:var(--border2)}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.btn-row .btn{flex:1;min-width:0}.alert{display:flex;align-items:flex-start;gap:9px;padding:11px 14px;border-radius:var(--r2);font-size:.87rem;margin-top:12px;border:1.5px solid;line-height:1.45}.alert-success{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}.alert-error{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.alert-warning{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}.alert-info{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue)}.notif-stack{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10;display:flex;flex-direction:column;gap:7px;pointer-events:none;width:max-content;max-width:min(420px,calc(100vw - 32px));align-items:center}.notif{padding:10px 18px;border-radius:100px;font-size:.87rem;font-weight:600;box-shadow:0 4px 20px #0000001f;animation:slideUp .22s ease;border:1.5px solid;pointer-events:auto;display:inline-flex;align-items:center;gap:7px;background:#fff;white-space:nowrap}.notif-success{border-color:var(--green-border);color:var(--green)}.notif-error{border-color:var(--red-border);color:var(--red)}.notif-warning{border-color:var(--amber-border);color:var(--amber)}.notif-info{border-color:var(--blue-border);color:var(--blue)}.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;margin:32px auto}.spinner-sm{width:15px;height:15px;border-width:2px;margin:0}.badge{display:inline-flex;align-items:center;gap:3px;font-size:.69rem;font-weight:700;letter-spacing:.04em;padding:2px 8px;border-radius:100px;border:1.5px solid;white-space:nowrap}.badge-brand{background:var(--brand-bg);color:var(--brand);border-color:var(--brand-border)}.badge-green{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.badge-red{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.badge-amber{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.badge-blue{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.badge-purple{background:var(--purple-bg);color:var(--purple);border-color:#ddd6fe}.badge-muted{background:var(--bg2);color:var(--text2);border-color:var(--border)}.list-row{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r2);transition:border-color .16s,box-shadow .16s;gap:12px}.list-row+.list-row{margin-top:7px}.list-row:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}.list-row-info{flex:1;min-width:0}.list-row-info .name{font-weight:600;font-size:.93rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-info .sub{color:var(--text2);font-size:.8rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-actions{display:flex;gap:5px;align-items:center;flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px;margin-bottom:20px}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:16px;transition:all .18s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand);border-radius:var(--r) var(--r) 0 0}.stat-card:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}.stat-card.green:before{background:var(--green)}.stat-card.amber:before{background:var(--amber)}.stat-card.blue:before{background:var(--blue)}.stat-card.purple:before{background:var(--purple)}.stat-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}.stat-value{font-size:2rem;font-weight:800;color:var(--text);line-height:1.1;margin:5px 0 2px;font-family:var(--ff-brand)}.stat-sub{font-size:.76rem;color:var(--text2)}.tabs{display:flex;gap:2px;margin-bottom:22px;background:var(--bg2);padding:3px;border-radius:var(--r);border:1px solid var(--border);flex-wrap:wrap}.tab{padding:7px 14px;border-radius:11px;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text2);border:1px solid transparent;background:none;transition:all .18s;display:flex;align-items:center;gap:5px;font-family:var(--ff);white-space:nowrap}.tab:hover{color:var(--text);background:#0000000a}.tab.active{color:var(--brand);background:var(--surface);box-shadow:var(--shadow-sm);border-color:var(--border)}.filter-bar{display:flex;align-items:center;gap:9px;margin-bottom:14px;flex-wrap:wrap}.filter-bar .select{width:auto;min-width:180px;flex:1}.pay-all-bar{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--amber-bg);border:1.5px solid var(--amber-border);border-radius:var(--r2);margin-bottom:14px;gap:12px;flex-wrap:wrap}.pay-all-bar p{color:var(--amber);font-size:.88rem;font-weight:600}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:400;animation:fadeIn .15s ease;padding:16px}.dialog{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:24px;width:100%;max-width:360px;box-shadow:var(--shadow-lg);animation:pop .2s ease}.dialog h3{font-family:var(--ff-brand);font-size:1.2rem;margin-bottom:8px}.dialog p{color:var(--text2);margin-bottom:20px;font-size:.9rem;line-height:1.5}.dialog-actions{display:flex;gap:8px}.dialog-actions .btn{flex:1}.school-group{margin-bottom:22px}.school-group-title{font-family:var(--ff-brand);font-size:1.05rem;letter-spacing:.04em;color:var(--brand);margin-bottom:9px;padding-bottom:7px;border-bottom:2px solid var(--brand-border);display:flex;align-items:center;gap:7px}.class-group{margin-bottom:10px;padding-left:11px;border-left:3px solid var(--border)}.class-group-title{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);margin-bottom:5px}.chart-wrap{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--r);padding:18px;height:260px;position:relative}.empty{text-align:center;padding:40px 20px;color:var(--text2)}.empty-icon{font-size:2.2rem;display:block;margin-bottom:9px}.empty h3{font-weight:600;margin-bottom:5px;color:var(--text);font-size:.95rem}.empty p{font-size:.85rem}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.combo-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.87rem}.combo-item:last-child{border-bottom:none}.combo-rank{width:21px;height:21px;border-radius:50%;background:var(--brand-bg);color:var(--brand);font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:var(--bg)}.message-page .icon{font-size:3.5rem;margin-bottom:14px}.message-page h2{font-family:var(--ff-brand);font-size:2rem;letter-spacing:.04em;margin-bottom:7px}.message-page p{color:var(--text2);font-size:.92rem}@media(max-width:640px){.header{padding:0 14px;height:56px}.header-brand .brand-text{font-size:1.2rem}.header-badge{display:none}.mobile-nav-toggle{display:flex!important;align-items:center;justify-content:center}.desktop-nav{display:none!important}.mobile-nav-drawer.open{display:flex!important}.main-content,.main-content.wide{padding:14px 12px}.card{padding:16px;border-radius:var(--r2)}.card-divider{margin:14px -16px}.input-grid-2{grid-template-columns:1fr;gap:0}.detail-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr;gap:9px}.list-row{flex-wrap:wrap}.list-row-actions{width:100%;justify-content:flex-end}.tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0}.btn-sm{padding:7px 12px}.btn-lg{padding:12px 20px}.notif-stack{bottom:16px;right:12px;left:12px;max-width:none;width:auto}.overlay{align-items:flex-end;padding:0}.dialog{border-radius:var(--r) var(--r) 0 0;max-width:100%;padding:20px}.stat-value{font-size:1.7rem}.chart-wrap{height:200px}.pay-all-bar{flex-direction:column;align-items:flex-start;gap:9px}.pay-all-bar .btn{width:100%}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .select{min-width:0}.filter-bar .btn{width:100%}}@media(max-width:380px){.stats-grid{grid-template-columns:1fr}.check-group{gap:5px}.check-pill{padding:5px 10px;font-size:.8rem}}@media(min-width:641px)and (max-width:900px){.main-content{padding:22px 16px}.detail-grid{grid-template-columns:1fr}.mobile-nav-toggle{display:none!important}.desktop-nav{display:flex!important}}@media(min-width:901px){.mobile-nav-toggle{display:none!important}.desktop-nav{display:flex!important}}
