@import url("https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--ink:#0d0d0b;--paper:#f5f2eb;--cream:#ede9df;--green:#1a5c3a;--green-light:#2a7a50;--green-pale:#e8f2ec;--gold:#c8973a;--gold-pale:#faf3e3;--red:#c0392b;--red-pale:#fdecea;--muted:#6b6a62;--border:rgba(13,13,11,.12);--serif:"Instrument Serif",Georgia,serif;--sans:"DM Sans",sans-serif}.dark{--ink:#ede9df;--paper:#0d0d0b;--cream:#141413;--muted:#8c8b82;--border:hsla(42,33%,94%,.08);--green-pale:rgba(26,92,58,.25);--gold-pale:rgba(200,151,58,.2)}.light-theme-reset{--ink:#0d0d0b;--paper:#f5f2eb;--cream:#ede9df;--muted:#6b6a62;--border:rgba(13,13,11,.12);--green-pale:#e8f2ec;--gold-pale:#faf3e3}body,html{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.6;min-height:100vh;transition:background-color .3s,color .3s}.switcher{position:fixed;top:0;left:0;right:0;z-index:9999;background:#0d0d0b;padding:10px 24px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;border-bottom:1px solid hsla(0,0%,100%,.08)}.switcher-label{font-size:11px;color:hsla(0,0%,100%,.4);font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-right:4px}.sw-btn{background:hsla(0,0%,100%,.07);color:hsla(0,0%,100%,.6);border:1px solid hsla(0,0%,100%,.1);border-radius:6px;padding:5px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--sans)}.sw-btn:hover{background:hsla(0,0%,100%,.12);color:#fff}.sw-btn.active{background:var(--green);color:#fff;border-color:var(--green)}.page{display:none;min-height:100vh;background:var(--paper);padding-top:0}.page.active{display:block}.app-nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:var(--green);justify-content:space-between;padding:0 32px;height:60px;box-shadow:0 2px 12px rgba(0,0,0,.15)}.app-nav,.app-nav-logo{display:flex;align-items:center}.app-nav-logo{font-family:var(--serif);font-size:20px;color:#fff;gap:10px}.app-nav-logo-icon{width:30px;height:30px;background:hsla(0,0%,100%,.15);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px}.app-nav-links{display:flex;align-items:center;gap:4px}.app-nav-links a{color:hsla(0,0%,100%,.75);font-size:13px;font-weight:500;text-decoration:none;padding:7px 14px;border-radius:7px;transition:all .15s;cursor:pointer}.app-nav-links a.active,.app-nav-links a:hover{background:hsla(0,0%,100%,.12);color:#fff}.app-nav-links .logout{color:hsla(0,100%,85%,.8)}.app-nav-links .logout:hover{background:rgba(192,57,43,.2);color:#faa}.pg{max-width:960px}.pg,.pg-wide{margin:0 auto;padding:32px 24px}.pg-wide{max-width:1100px}.card{background:var(--paper);border-radius:14px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.05)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-bottom:28px}.stat-card{background:var(--paper);border-radius:14px;padding:22px 24px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.05)}.stat-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.stat-val{font-size:32px;font-weight:600;color:var(--ink);line-height:1}.stat-val.g{color:var(--green)}.stat-val.r{color:var(--red)}.stat-sub{font-size:12px;color:var(--muted);margin-top:6px}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .15s;font-family:var(--sans);text-decoration:none}.btn-green{background:var(--green);color:#fff;box-shadow:0 2px 8px rgba(26,92,58,.2)}.btn-green:hover{background:var(--green-light);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--green);border:1.5px solid var(--green)}.btn-outline:hover{background:var(--green-pale)}.btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--cream);color:var(--ink)}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.btn-wa{background:#25d366;color:#fff}.btn-wa:hover{background:#1da855}.btn-amber{background:var(--gold-pale);color:var(--gold);border:1px solid rgba(200,151,58,.3)}.btn-amber:hover{background:#f0e4c0}.btn-danger{background:var(--red-pale);color:var(--red);border:1px solid rgba(192,57,43,.2)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge-paid{background:var(--green-pale);color:var(--green)}.badge-unpaid{background:var(--red-pale);color:var(--red)}.badge-partial{background:var(--gold-pale);color:var(--gold)}.input-group{margin-bottom:18px}.input-label{display:block;font-size:13px;font-weight:500;color:var(--ink);margin-bottom:6px}.input{width:100%;padding:11px 16px;border:1.5px solid var(--border);border-radius:10px;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;outline:none;transition:border-color .2s}.input:focus{border-color:var(--green)}.input::placeholder{color:hsla(53,4%,40%,.5)}.input-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.sec-title{font-size:16px;font-weight:600;color:var(--ink)}.sec-sub{font-size:13px;color:var(--muted);margin-top:2px}.student-list{display:flex;flex-direction:column;gap:10px}.student-card{background:var(--paper);border-radius:12px;padding:16px 20px;border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px;transition:box-shadow .15s}.student-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.07)}.student-left{gap:14px}.student-avatar,.student-left{display:flex;align-items:center}.student-avatar{width:42px;height:42px;border-radius:50%;background:var(--cream);color:var(--green);font-size:14px;font-weight:700;flex-shrink:0;justify-content:center}.student-name{font-size:15px;font-weight:600;color:var(--ink)}.student-meta{font-size:12px;color:var(--muted);margin-top:2px}.student-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.badge-col{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.badge-time{font-size:10px;color:var(--muted)}.action-btns{display:flex;gap:6px}.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}table{width:100%;border-collapse:collapse}thead tr{background:var(--cream)}thead th{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:12px 16px;text-align:left}tbody tr{border-top:1px solid var(--border);background:var(--paper)}tbody tr:hover{background:#fafaf8}tbody td{padding:14px 16px;font-size:14px;color:var(--ink)}.td-muted{color:var(--muted);font-size:13px}.auth-wrap{min-height:calc(100vh - 46px);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card,.auth-wrap{background:var(--paper)}.auth-card{border-radius:20px;border:1px solid var(--border);box-shadow:0 8px 40px rgba(0,0,0,.08);padding:44px 40px;width:100%;max-width:420px}.auth-logo{gap:10px;margin-bottom:32px}.auth-logo,.auth-logo-icon{display:flex;align-items:center}.auth-logo-icon{width:34px;height:34px;background:var(--green-pale);border-radius:9px;justify-content:center;font-size:16px}.auth-logo-text{font-family:var(--serif);font-size:20px;color:var(--green)}.auth-divider{border:none;border-top:1px solid var(--border);margin:0 0 28px}.auth-title{font-size:26px;font-weight:600;color:var(--ink);margin-bottom:6px}.auth-sub{font-size:15px;color:var(--muted);margin-bottom:28px}.auth-footer{text-align:center;margin-top:22px;font-size:14px;color:var(--muted)}.auth-footer a{color:var(--green);font-weight:500;text-decoration:underline;cursor:pointer}.auth-error{background:var(--red-pale);border:1px solid rgba(192,57,43,.2);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--red);margin-bottom:16px}.modal-overlay{position:fixed;inset:0;background:rgba(13,13,11,.5);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--paper);border-radius:18px;padding:32px;width:100%;max-width:480px;box-shadow:0 24px 64px rgba(0,0,0,.18)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:18px;font-weight:600;color:var(--ink)}.modal-close{width:30px;height:30px;border-radius:50%;border:none;background:var(--cream);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.upload-zone{border:2px dashed rgba(26,92,58,.25);border-radius:14px;background:var(--green-pale);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s}.upload-zone:hover{border-color:var(--green);background:#ddeee6}.upload-icon{font-size:40px;margin-bottom:14px}.upload-title{font-size:17px;font-weight:600;color:var(--ink);margin-bottom:6px}.upload-sub{font-size:14px;color:var(--muted)}.preview-table-wrap{margin-top:24px}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.preview-count{font-size:13px;color:var(--muted)}.preview-count strong{color:var(--green)}.reconcile-row{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:16px;gap:16px;margin-bottom:28px}.reconcile-card{background:var(--paper);border-radius:12px;padding:20px 22px;border:1px solid var(--border);text-align:center}.reconcile-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.reconcile-val{font-size:26px;font-weight:600}.reconcile-val.g{color:var(--green)}.reconcile-val.r{color:var(--red)}.reconcile-val.b{color:var(--ink)}.progress-bar-wrap{background:var(--cream);border-radius:20px;height:10px;overflow:hidden;margin-top:16px;margin-bottom:6px}.progress-bar{height:100%;background:var(--green);border-radius:20px;transition:width .6s ease}.progress-label{font-size:12px;color:var(--muted)}.progress-label strong{color:var(--green)}.pg-header{margin-bottom:28px}.pg-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.pg-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);text-decoration:none;cursor:pointer;margin-bottom:12px;transition:color .15s}.pg-back:hover{color:var(--green)}.pg-title{font-size:26px;font-weight:600;color:var(--ink)}.pg-subtitle{font-size:14px;color:var(--muted);margin-top:4px}.month-pill{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--border);border-radius:20px;padding:6px 16px;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .35s ease both}.empty-state{text-align:center;padding:64px 24px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-title{font-size:17px;font-weight:600;color:var(--ink);margin-bottom:8px}.empty-sub{font-size:14px;color:var(--muted);max-width:320px;margin:0 auto 24px;line-height:1.6}.toast{position:fixed;bottom:24px;right:24px;z-index:9000;background:var(--ink);color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);display:flex;align-items:center;gap:10px;animation:fadeUp .3s ease}.toast.success{background:var(--green)}.toast.error{background:var(--red)}@font-face{font-family:__Outfit_ed3508;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/98848575513c9742-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Outfit_ed3508;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/7b0b24f36b1a6d0b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Outfit_Fallback_ed3508;src:local("Arial");ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.00%;size-adjust:99.82%}.__className_ed3508{font-family:__Outfit_ed3508,__Outfit_Fallback_ed3508;font-style:normal}