@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,500;0,9..144,700;0,9..144,900;1,9..144,500&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Yellowtail&display=swap";:root{--green:#1a5c1a;--green-deep:#0f3d10;--green-soft:#2a7a2a;--green-light:#e8f5e8;--gold:#f0b429;--gold-soft:#fcd34d;--gold-light:#fffbeb;--cream:#faf4e3;--cream-soft:#fffdf5;--paper:#f7efd9;--ink:#15201a;--muted:#5a6a5a;--line:#1a5c1a24;--white:#fff;--font-body:"Plus Jakarta Sans", sans-serif;--font-heading:"Fraunces", serif;--font-script:"Yellowtail", cursive;--radius:16px;--radius-sm:8px;--radius-lg:24px;--shadow:0 4px 24px #0f3d101a;--shadow-lg:0 8px 40px #0f3d1026;--bp-mobile:880px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--ink);-webkit-font-smoothing:antialiased;background:linear-gradient(160deg,#d4edda 0%,#faf4e3 55%,#fffbeb 100%) fixed;line-height:1.6}h1,h2,h3,h4,h5{font-family:var(--font-heading);line-height:1.15}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}input,select,textarea{font-family:var(--font-body)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--green);font-size:11px;font-weight:700}.btn-primary{background:var(--green);color:var(--white);border-radius:999px;align-items:center;gap:8px;padding:13px 24px;font-size:15px;font-weight:700;transition:background .18s,transform .14s;display:inline-flex}.btn-primary:hover{background:var(--green-deep);transform:translateY(-1px)}.btn-ghost{color:var(--green);border:1.5px solid var(--line);background:0 0;border-radius:999px;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:700;transition:border-color .18s,background .18s;display:inline-flex}.btn-ghost:hover{border-color:var(--green);background:var(--green-light)}.btn-danger{color:#fff;background:#ef4444;border-radius:999px;align-items:center;gap:8px;padding:13px 24px;font-size:15px;font-weight:700;transition:background .18s,transform .14s;display:inline-flex}.btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.section-wrap{max-width:1180px;margin:0 auto;padding:0 24px}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0}.reveal.visible{animation:.6s both fadeSlideUp}.navbar{z-index:100;-webkit-backdrop-filter:blur(12px);background:#0f3d10ed;border-bottom:1px solid #0000;transition:border-color .2s,box-shadow .2s;position:sticky;top:0}.navbar.scrolled{border-color:#ffffff1f;box-shadow:0 2px 20px #0f3d1059}.nav-inner{align-items:center;gap:24px;max-width:1180px;height:68px;margin:0 auto;padding:0 24px;display:flex}.nav-brand{flex-shrink:0;align-items:center;gap:12px;text-decoration:none;display:flex}.nav-badge{object-fit:contain;flex-shrink:0;width:44px;height:44px}.nav-name{color:var(--white);max-width:180px;font-size:14px;font-weight:700;line-height:1.25}.nav-links{align-items:center;gap:4px;margin-left:auto;display:flex}.nav-links button,.nav-links a:not(.nav-cta){font-family:var(--font-body);color:#ffffffd9;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 12px;font-size:14px;font-weight:600;text-decoration:none;transition:color .15s,background .15s}.nav-links button:hover,.nav-links a:not(.nav-cta):hover{color:var(--gold);background:#ffffff1f}.nav-cta{margin-left:8px;padding:9px 18px!important;font-size:13px!important}.nav-burger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;margin-left:auto;padding:8px;display:none}.nav-burger span{background:var(--white);border-radius:2px;width:22px;height:2px;transition:all .2s;display:block}@media (width<=880px){.nav-burger{display:flex}.nav-links{background:var(--green-deep);border-bottom:1px solid #ffffff1f;flex-direction:column;gap:4px;padding:12px 24px 20px;display:none;position:absolute;top:68px;left:0;right:0;box-shadow:0 8px 24px #0f3d1059}.nav-links.open{display:flex}.nav-links button,.nav-links a:not(.nav-cta){text-align:left;width:100%}.nav-cta{justify-content:center;width:100%;margin-top:8px;margin-left:0}}.hero{background:linear-gradient(135deg,#d4edda 0%,#fffdf5 55%,#fffbeb 100%);padding:80px 0;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#1a5c1a21 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;right:-100px}.hero:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#f0b4292e 0%,#0000 70%);border-radius:50%;width:380px;height:380px;position:absolute;bottom:-80px;left:-80px}.hero-inner{z-index:1;grid-template-columns:1.15fr 1fr;align-items:center;gap:56px;display:grid;position:relative}.hero-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--green);align-items:center;gap:8px;margin-bottom:20px;font-size:11px;font-weight:700;display:inline-flex}.hero-dot{background:var(--gold);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}@keyframes heroEnter{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero-eyebrow{animation:.6s both heroEnter}.hero-heading{animation:.6s .1s both heroEnter}.hero-lede{animation:.6s .2s both heroEnter}.hero-chips{animation:.6s .3s both heroEnter}.hero-actions{animation:.6s .4s both heroEnter}.hero-heading{color:var(--green-deep);margin-bottom:20px;font-size:clamp(42px,6vw,72px);line-height:1.05}.hero-script{font-family:var(--font-script);color:var(--green);margin-right:8px;font-size:.78em;display:inline-block;transform:rotate(-3deg)}.hero-sub{font-family:var(--font-body);color:var(--muted);vertical-align:middle;margin:0 8px;font-size:.45em;font-weight:600}.hero-open{background:var(--gold);color:var(--green-deep);vertical-align:middle;letter-spacing:.06em;border-radius:999px;align-items:center;padding:4px 18px;font-size:.55em;font-weight:900;display:inline-flex}.hero-lede{color:var(--muted);max-width:480px;margin-bottom:24px;font-size:16px;line-height:1.7}.hero-chips{flex-wrap:wrap;gap:8px;margin-bottom:28px;display:flex}.hero-chip{background:var(--white);border:1px solid var(--line);color:var(--ink);border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;display:inline-flex}.chip-icon{font-size:14px}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.hero-collage{height:460px;position:relative}.collage-img{border:4px solid var(--white);width:62%;box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/3;border-radius:16px;position:absolute}@keyframes floatA{0%,to{transform:rotate(-3deg)translateY(0)}50%{transform:rotate(-3deg)translateY(-12px)}}@keyframes floatB{0%,to{transform:rotate(2deg)translateY(0)}50%{transform:rotate(2deg)translateY(-12px)}}@keyframes floatC{0%,to{transform:translate(-50%)rotate(1deg)translateY(0)}50%{transform:translate(-50%)rotate(1deg)translateY(-12px)}}@keyframes spinSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.c1{z-index:1;animation:4s ease-in-out infinite floatA;top:0;left:0}.c2{z-index:2;animation:4s ease-in-out 1.3s infinite floatB;top:60px;right:0}.c3{z-index:3;animation:4s ease-in-out 2.6s infinite floatC;bottom:0;left:50%}.collage-sticker{background:var(--gold);width:64px;height:64px;color:var(--green-deep);text-align:center;z-index:10;box-shadow:var(--shadow);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:800;line-height:1.3;animation:12s linear infinite spinSlow;display:flex;position:absolute;bottom:80px;left:-10px}@media (width<=880px){.hero-inner{grid-template-columns:1fr;gap:40px}.hero-collage{height:280px}.collage-img{width:52%}}.about{background:linear-gradient(135deg,#e8f5e8 0%,#fffdf5 60%,#fffbeb 100%);padding:96px 0;position:relative;overflow:hidden}.about:before{content:"";pointer-events:none;background:radial-gradient(circle,#f0b42924 0%,#0000 70%);border-radius:50%;width:420px;height:420px;position:absolute;top:-80px;right:-80px}.about:after{content:"";pointer-events:none;background:radial-gradient(circle,#1a5c1a1a 0%,#0000 70%);border-radius:50%;width:320px;height:320px;position:absolute;bottom:-60px;left:-60px}.about-inner{z-index:1;grid-template-columns:1fr 1.2fr;align-items:center;gap:64px;display:grid;position:relative}.about-img-wrap{position:relative}.about-img{border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/3}.about-badge{background:var(--gold);color:var(--green-deep);letter-spacing:.1em;border-radius:999px;padding:8px 14px;font-size:11px;font-weight:800;position:absolute;bottom:20px;right:20px}.about-content h2{color:var(--green-deep);margin:12px 0 20px;font-size:clamp(28px,4vw,40px)}.about-body{color:var(--muted);margin-bottom:28px;font-size:16px;line-height:1.75}.pillars-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.pillar-box{border:1px solid var(--line);border-radius:var(--radius);text-align:center;padding:16px}.pillar-box strong{color:var(--green-deep);margin-bottom:6px;font-size:13px;display:block}.pillar-box p{color:var(--muted);font-size:12px;line-height:1.5}@media (width<=880px){.about-inner,.pillars-grid{grid-template-columns:1fr}}.programs{background:linear-gradient(160deg,#fffbeb 0%,#faf4e3 50%,#d4edda 100%);padding:96px 0;position:relative;overflow:hidden}.programs:before{content:"";pointer-events:none;background:radial-gradient(circle,#f0b42921 0%,#0000 70%);border-radius:50%;width:460px;height:460px;position:absolute;top:-100px;left:-100px}.programs:after{content:"";pointer-events:none;background:radial-gradient(circle,#1a5c1a1a 0%,#0000 70%);border-radius:50%;width:380px;height:380px;position:absolute;bottom:-80px;right:-80px}.programs-inner{z-index:1;position:relative}.programs-inner h2{color:var(--green-deep);max-width:600px;margin:12px 0 40px;font-size:clamp(26px,3.5vw,38px)}.programs-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.program-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;overflow:hidden}.program-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.program-img-wrap{position:relative}.program-img{aspect-ratio:16/9;object-fit:cover;width:100%}.program-tag{background:var(--white);color:var(--green-deep);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:12px;left:12px}.program-body{padding:24px}.program-label{letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-size:11px;font-weight:700}.program-title{color:var(--green-deep);margin-bottom:10px;font-size:22px}.program-desc{color:var(--muted);margin-bottom:16px;font-size:14px;line-height:1.65}.program-levels{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.level-pill{background:var(--green-light);color:var(--green);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.program-link{color:var(--green);font-size:14px;font-weight:700;text-decoration:none}.program-link:hover{text-decoration:underline}@media (width<=640px){.programs-grid{grid-template-columns:1fr}}.tuition{background:linear-gradient(135deg,#d4edda 0%,#f7efd9 55%,#fffbeb 100%);padding:96px 0;position:relative;overflow:hidden}.tuition:before{content:"";pointer-events:none;background:radial-gradient(circle,#1a5c1a1c 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:-60px;right:-60px}.tuition:after{content:"";pointer-events:none;background:radial-gradient(circle,#f0b42926 0%,#0000 70%);border-radius:50%;width:360px;height:360px;position:absolute;bottom:-80px;left:-80px}.tuition-inner{z-index:1;position:relative}.tuition-inner h2{color:var(--green-deep);margin:12px 0 32px;font-size:clamp(26px,3.5vw,38px)}.tuition-tabs{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:28px;display:flex}.tuition-tab{background:var(--white);border:1.5px solid var(--line);color:var(--green);font-family:var(--font-body);cursor:pointer;border-radius:999px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.tuition-tab.active,.tuition-tab:hover{background:var(--green);color:var(--white);border-color:var(--green)}.tuition-panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.panel-header{background:linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);color:var(--white);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 28px;display:flex}.panel-title{margin-bottom:4px;font-size:18px;font-weight:700}.panel-subtitle{opacity:.8;font-size:13px}.panel-save{background:var(--gold);color:var(--green-deep);letter-spacing:.08em;white-space:nowrap;border-radius:999px;align-self:flex-start;padding:6px 14px;font-size:11px;font-weight:800}.panel-body{grid-template-columns:1.2fr 1fr;gap:24px;padding:28px;display:grid}.fee-row{border-bottom:1px solid var(--line);color:var(--ink);justify-content:space-between;padding:10px 0;font-size:15px;display:flex}.fee-row:last-child{border-bottom:none}.fee-row span:last-child{color:var(--green-deep);font-weight:600}.fee-totals{flex-direction:column;gap:12px;display:flex}.total-card{border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px}.total-gold{background:var(--gold-light);border-color:var(--gold)}.total-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:11px;font-weight:700}.total-amount{font-family:var(--font-heading);color:var(--green-deep);font-size:28px;font-weight:700}.total-sub{color:var(--muted);margin-top:2px;font-size:12px}.total-gold .total-amount{color:var(--green-deep)}@media (width<=640px){.panel-body{grid-template-columns:1fr}}.why{color:var(--white);background:linear-gradient(135deg,#0f3d10 0%,#1a5c1a 60%,#0f3d10 100%);padding:96px 0;position:relative;overflow:hidden}.why:before{content:"";pointer-events:none;background:radial-gradient(circle,#f0b4291f 0%,#0000 70%);border-radius:50%;width:460px;height:460px;position:absolute;top:-80px;right:-80px}.why:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0f 0%,#0000 70%);border-radius:50%;width:340px;height:340px;position:absolute;bottom:-60px;left:-60px}.why-inner{z-index:1;position:relative}.why-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#fff9;margin-bottom:12px;font-size:11px;font-weight:700}.why-inner h2{color:var(--white);margin-bottom:40px;font-size:clamp(28px,4vw,44px)}.why-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.why-card{border-radius:var(--radius-lg);background:#ffffff0f;border:1px solid #ffffff1a;padding:32px 24px;transition:transform .2s,background .2s;position:relative;overflow:hidden}.why-card:hover{background:#ffffff1a;transform:translateY(-4px)}.why-num{font-family:var(--font-heading);color:#ffffff14;font-size:48px;font-weight:900;line-height:1;position:absolute;top:16px;right:20px}.why-icon{background:var(--gold);border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;font-size:22px;display:inline-flex}.why-card h3{color:var(--white);margin-bottom:10px;font-size:20px}.why-card p{color:#ffffffb8;font-size:14px;line-height:1.7}@media (width<=880px){.why-grid{grid-template-columns:1fr}}.cta-band{background:linear-gradient(135deg,#f0b429 0%,#fcd34d 50%,#f0b429 100%);padding:64px 0;position:relative;overflow:hidden}.cta-band:before{content:"";pointer-events:none;background:radial-gradient(circle,#0f3d101a 0%,#0000 70%);border-radius:50%;width:320px;height:320px;position:absolute;top:-60px;left:-60px}.cta-band:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff2e 0%,#0000 70%);border-radius:50%;width:300px;height:300px;position:absolute;bottom:-60px;right:-60px}.cta-inner{z-index:1;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:32px;display:flex;position:relative}.cta-content h2{color:var(--green-deep);margin-bottom:8px;font-size:clamp(24px,3vw,34px)}.cta-content p{color:#0f3d10cc;max-width:480px;font-size:15px;line-height:1.65}.cta-btn{white-space:nowrap;background:var(--green-deep)!important}.footer{background:var(--green-deep);color:#ffffffbf;padding:56px 0 0}.footer-inner{max-width:1180px;margin:0 auto;padding:0 24px}.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;display:grid}.footer-brand{align-items:center;gap:12px;margin-bottom:12px;display:flex}.footer-badge{object-fit:contain;flex-shrink:0;width:44px;height:44px}.footer-name{color:var(--white);font-size:14px;font-weight:700;line-height:1.3}.footer-mission{font-size:13px;line-height:1.6}.footer-heading{font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:12px;font-size:12px;font-weight:700}.footer p{font-size:14px;line-height:1.7}.footer-fb{color:var(--gold-soft);font-size:14px;line-height:1.7;text-decoration:underline;display:block}.footer-social{gap:12px;margin-top:4px;display:flex}.footer-social-link{color:var(--gold-soft);border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:color .15s,border-color .15s,background .15s;display:flex}.footer-social-link:hover{color:var(--white);border-color:var(--white);background:#ffffff14}.footer-links{flex-direction:column;gap:8px;list-style:none;display:flex}.footer-links a{font-size:14px;transition:color .15s}.footer-links a:hover{color:var(--white)}.footer-bottom{border-top:1px solid #ffffff1a;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-size:13px;display:flex}.footer-tagline{color:#ffffff8c}@media (width<=880px){.footer-grid{grid-template-columns:1fr 1fr}.footer-bottom{text-align:center;flex-direction:column}}@media (width<=520px){.footer-grid{grid-template-columns:1fr}}.summary-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);position:sticky;top:88px;overflow:hidden}.summary-header{background:linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);color:var(--white);padding:20px 22px}.summary-header h3{margin-bottom:2px;font-size:16px;font-weight:700}.summary-header p{opacity:.75;font-size:13px}.summary-body{padding:18px 22px}.summary-level{background:var(--green-light);border-radius:var(--radius-sm);flex-direction:column;gap:4px;margin-bottom:14px;padding:10px 14px;display:flex}.summary-level-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:700}.summary-level strong{color:var(--green-deep);font-size:15px}.pay-chip{background:var(--green-light);color:var(--green);letter-spacing:.08em;border:1px solid var(--line);border-radius:999px;width:fit-content;padding:3px 10px;font-size:10px;font-weight:700;display:inline-block}.pay-chip.cash{background:var(--gold-light);color:var(--green-deep);border-color:var(--gold)}.summary-breakdown{margin-bottom:14px}.srow{border-bottom:1px solid var(--line);color:var(--ink);justify-content:space-between;padding:7px 0;font-size:13px;display:flex}.srow span:last-child{font-weight:600}.srow-total{border-bottom:none;border-top:2px solid var(--line);color:var(--green-deep);padding-top:10px;font-weight:700}.summary-empty{text-align:center;color:var(--muted);padding:32px 16px}.empty-icon{margin-bottom:10px;font-size:32px;display:block}.summary-empty p{font-size:13px;line-height:1.6}.summary-total{background:var(--gold-light);border:1px solid var(--gold);border-radius:var(--radius);margin-bottom:4px;padding:14px 16px}.st-label{letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep);margin-bottom:4px;font-size:10px;font-weight:700}.st-amount{font-family:var(--font-heading);color:var(--green-deep);font-size:30px;font-weight:700}.st-sub{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.5}.summary-footer{border-top:1px solid var(--line);color:var(--muted);padding:12px 22px;font-size:11px;line-height:1.5}.enroll-form{flex-direction:column;gap:28px;display:flex}.form-error-banner{color:#991b1b;border-radius:var(--radius-sm);background:#fee2e2;border:1px solid #fca5a5;padding:12px 16px;font-size:14px}.form-group{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:24px;display:flex}.group-header{align-items:flex-start;gap:14px;margin-bottom:4px;display:flex}.group-num{background:var(--green);width:32px;height:32px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.group-header h3{color:var(--green-deep);font-size:17px;font-family:var(--font-body);font-weight:700}.group-header p{color:var(--muted);font-size:13px}.field-row{gap:14px;display:grid}.col1{grid-template-columns:1fr}.col2{grid-template-columns:1fr 1fr}.col3{grid-template-columns:1fr 1fr 1fr}.field{flex-direction:column;gap:6px;display:flex}.field.has-error input,.field.has-error textarea{border-color:#ef4444!important}.field-label{color:var(--green-deep);letter-spacing:.04em;font-size:12px;font-weight:700}.req{color:#ef4444;margin-left:2px}.field input,.field textarea,.field select{color:var(--ink);background:#faf6ea;border:1.5px solid #0000;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-size:14px;transition:border-color .15s,background .15s}.field input::placeholder,.field textarea::placeholder{color:#9aa89a}.field input:focus,.field textarea:focus{border-color:var(--green);background:var(--white)}.radio-pills{flex-wrap:wrap;gap:8px;display:flex}.radio-pill{border:1.5px solid var(--line);color:var(--ink);cursor:pointer;background:#faf6ea;border-radius:999px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.radio-pill input{display:none}.radio-pill.checked{background:var(--green);color:var(--white);border-color:var(--green);box-shadow:0 2px 8px #1a5c1a33}.radio-pill.checked:after{content:"✓";color:var(--gold);font-size:12px}.level-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.level-pill{border:1.5px solid var(--line);color:var(--ink);cursor:pointer;text-align:center;background:#faf6ea;border-radius:999px;justify-content:center;align-items:center;padding:8px 10px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.level-pill input{display:none}.level-pill.checked{background:var(--green);color:var(--white);border-color:var(--green);box-shadow:0 2px 8px #1a5c1a33}.pay-cards{grid-template-columns:1fr 1fr;gap:12px;display:grid}.pay-card{border:1.5px solid var(--line);border-radius:var(--radius);cursor:pointer;background:var(--white);padding:16px;transition:all .15s}.pay-card input{display:none}.pay-card.checked{border-color:var(--green);background:var(--cream-soft);box-shadow:0 2px 12px #1a5c1a1a}.pay-card-title{color:var(--green-deep);align-items:center;gap:8px;margin-bottom:6px;font-size:15px;font-weight:700;display:flex}.save-badge{background:var(--gold);color:var(--green-deep);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:800}.pay-card-desc{color:var(--muted);font-size:13px;line-height:1.5}.form-submit-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.form-disclaimer{color:var(--muted);max-width:340px;font-size:13px;line-height:1.5}.success-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow);padding:48px 32px}.success-check{background:var(--gold);width:64px;height:64px;color:var(--green-deep);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:28px;font-weight:900;animation:.4s cubic-bezier(.4,0,.2,1) popIn;display:flex}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.success-card h2{color:var(--green-deep);margin-bottom:10px;font-size:22px}.success-card p{color:var(--muted);margin-bottom:20px;font-size:15px;line-height:1.65}.success-ref{background:var(--green-light);color:var(--green-deep);border-radius:var(--radius-sm);margin-bottom:24px;padding:12px 20px;font-size:14px;display:inline-block}.success-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.slip{display:none}@page{size:5in 7in;margin:.3in}@media print{.navbar,.enroll-hero,.enroll-right,.enroll-fee-mobile,.footer{display:none!important}body{background:#fff!important}.enroll-layout{padding:0!important;display:block!important}.enroll-left{width:100%!important}.success-card{box-shadow:none!important;text-align:left!important;border:none!important;border-radius:0!important;max-width:100%!important;padding:0!important}.success-screen{display:none!important}.slip{color:#000;box-sizing:border-box;border:2px solid #0f3d10;width:100%;margin:0;padding:14px;font-family:Arial,sans-serif;display:block!important}.slip-header{align-items:center;gap:10px;margin-bottom:8px;display:flex!important}.slip-logo{width:38px;height:38px}.slip-school{color:#0f3d10;margin:0;font-size:13px;font-weight:700;line-height:1.2}.slip-addr{color:#555;margin:2px 0 0;font-size:9.5px;line-height:1.2}.slip-rule{border:none;border-top:2px solid #0f3d10;margin:8px 0 10px}.slip-title{text-align:center;letter-spacing:.1em;color:#0f3d10;margin:0 0 3px;font-family:Arial,sans-serif;font-size:12px;font-weight:800}.slip-sy{text-align:center;color:#666;margin:0 0 12px;font-size:10px}.slip-table{border:1px solid #ccc;margin-bottom:12px}.slip-row{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:6px 10px;font-size:11px;display:flex!important}.slip-row:last-child{border-bottom:none}.slip-row span{color:#555}.slip-row strong{color:#0f3d10;font-weight:700}.slip-row-total{background:#e8f5e8;font-weight:700}.slip-row-total span{color:#0f3d10;font-weight:700}.slip-row-total strong{font-size:12px}.slip-note{color:#555;border-top:1px dashed #ccc;margin-bottom:10px;padding-top:8px;font-size:9.5px;line-height:1.5}.slip-footer{text-align:center;color:#999;letter-spacing:.12em;margin:0;font-size:9.5px}}@media (width<=640px){.col2,.col3{grid-template-columns:1fr}.level-grid{grid-template-columns:1fr 1fr}.pay-cards{grid-template-columns:1fr}}.enroll-hero{background:linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);color:var(--white);padding:56px 0 48px;position:relative;overflow:hidden}.enroll-hero-inner{z-index:1;position:relative}.enroll-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#fff9;margin-bottom:12px;font-size:11px;font-weight:700}.enroll-heading{color:var(--white);margin-bottom:12px;font-size:clamp(28px,4vw,44px)}.enroll-script{font-family:var(--font-script);font-size:1em}.enroll-lede{color:#fffc;max-width:500px;margin-bottom:24px;font-size:15px;line-height:1.65}.progress-steps{flex-wrap:wrap;gap:24px;display:flex}.step{color:#fffc;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.step-num{width:26px;height:26px;color:var(--white);background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.enroll-layout{grid-template-columns:1.5fr 1fr;align-items:start;gap:32px;padding-top:36px;padding-bottom:64px;display:grid}.enroll-fee-mobile{display:none}@media (width<=880px){.enroll-layout{grid-template-columns:1fr}.enroll-right{display:none}.enroll-fee-mobile{margin-bottom:24px;display:block}}.login-screen{background:linear-gradient(135deg, var(--green-deep) 0%, var(--green) 60%, var(--green-soft) 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);text-align:center;padding:40px 36px}.login-logo{object-fit:contain;width:64px;height:64px;margin:0 auto 16px;display:block}.login-title{color:var(--green-deep);margin-bottom:6px;font-size:22px}.login-sub{color:var(--muted);margin-bottom:24px;font-size:14px}.login-portal{color:var(--gold);font-weight:700}.login-form{text-align:left;flex-direction:column;gap:16px;margin-bottom:20px;display:flex}.login-error{color:#991b1b;border-radius:var(--radius-sm);background:#fee2e2;border:1px solid #fca5a5;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{letter-spacing:.08em;color:var(--green-deep);font-size:11px;font-weight:700}.login-field input{font-size:14px;font-family:var(--font-body);color:var(--ink);background:#faf6ea;border:1.5px solid #0000;border-radius:10px;outline:none;width:100%;padding:12px 16px;transition:border-color .15s}.login-field input:focus{border-color:var(--green);background:var(--white)}.pw-wrap{position:relative}.pw-wrap input{padding-right:44px}.pw-toggle{cursor:pointer;background:0 0;border:none;font-size:16px;line-height:1;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-btn{background:var(--green);width:100%;color:var(--white);font-family:var(--font-body);cursor:pointer;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;transition:background .15s}.login-btn:hover{background:var(--green-deep)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.sidebar{background:linear-gradient(180deg, var(--green-deep) 0%, #0a2a0b 100%);z-index:50;flex-direction:column;flex-shrink:0;width:248px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sb-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.sb-badge{object-fit:contain;flex-shrink:0;width:40px;height:40px}.sb-name{color:var(--white);font-size:14px;font-weight:700}.sb-portal{letter-spacing:.12em;color:var(--gold-soft);font-size:9px;font-weight:700}.sb-nav{padding:12px 12px 4px}.sb-section-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff59;margin-bottom:4px;padding:4px 8px;font-size:10px;font-weight:700}.sb-link{width:100%;font-family:var(--font-body);color:#ffffffb3;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:600;transition:background .15s,color .15s;display:flex}.sb-link:hover:not(.disabled){color:var(--white);background:#ffffff14}.sb-link.active{color:var(--white);background:#ffffff1f}.sb-link.disabled{opacity:.45;cursor:default}.sb-icon{font-size:16px}.sb-soon{letter-spacing:.08em;color:#ffffff80;background:#ffffff1a;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:700}.sb-footer{border-top:1px solid #ffffff14;align-items:center;gap:10px;margin-top:auto;padding:12px 16px;display:flex}.sb-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sb-avatar{background:var(--gold);width:32px;height:32px;color:var(--green-deep);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex}.sb-username{color:var(--white);font-size:13px;font-weight:700}.sb-role{color:#ffffff80;font-size:11px}.sb-logout{color:#ffffff73;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:18px;transition:color .15s}.sb-logout:hover{color:var(--white)}.sidebar-backdrop{z-index:49;background:#0006;display:none;position:fixed;inset:0}@media (width<=880px){.sidebar{height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block}}.topbar{background:var(--white);border-bottom:1px solid var(--line);z-index:40;justify-content:space-between;align-items:center;gap:16px;height:64px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #0f3d100d}.topbar-left{align-items:center;gap:14px;display:flex}.topbar-breadcrumb{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:700}.topbar-title{color:var(--green-deep);font-size:16px;font-weight:700}.topbar-date{color:var(--muted);white-space:nowrap;font-size:13px}.topbar-burger{color:var(--green);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px;display:none}@media (width<=880px){.topbar-burger{display:block}.topbar-date{display:none}}.dashboard{flex-direction:column;gap:24px;padding:24px;display:flex}.dash-loading{text-align:center;color:var(--muted);padding:64px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stat-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);align-items:flex-start;gap:14px;padding:20px;display:flex}.stat-card-clickable{cursor:pointer;transition:box-shadow .15s,transform .15s}.stat-card-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;display:flex}.stat-green .stat-icon{background:var(--green-light)}.stat-gold .stat-icon{background:var(--gold-light)}.stat-blue .stat-icon{background:#eff6ff}.stat-purple .stat-icon{background:#f5f3ff}.stat-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-size:10px;font-weight:700}.stat-value{font-family:var(--font-heading);color:var(--green-deep);margin-bottom:4px;font-size:32px;font-weight:700;line-height:1}.stat-sub{color:var(--muted);font-size:12px}.charts-row{grid-template-columns:1.4fr 1fr 1fr;align-items:start;gap:16px;display:grid}.chart-panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px}.bar-wrap{height:280px;position:relative;overflow:hidden}.bar-wrap canvas{position:absolute;top:0;left:0;width:100%!important;height:100%!important}.chart-title{color:var(--green-deep);font-size:15px;font-weight:700}.chart-sub{color:var(--muted);margin-bottom:16px;font-size:12px}.donut-wrap{width:180px;margin:0 auto 16px;position:relative}.donut-center{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-total{font-family:var(--font-heading);color:var(--green-deep);font-size:28px;font-weight:700}.donut-label{color:var(--muted);font-size:11px}.donut-legend{flex-direction:column;gap:8px;display:flex}.legend-item{color:var(--ink);align-items:center;gap:8px;font-size:13px;display:flex}.legend-item strong{color:var(--green-deep);margin-left:auto;font-size:15px}.legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.legend-dot.green{background:var(--green)}.legend-dot.gold{background:var(--gold)}.legend-dot.blue{background:#3b82f6}.legend-dot.purple{background:#7c3aed}.recent-panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.recent-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.view-all-btn{color:var(--green);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:700}.view-all-btn:hover{text-decoration:underline}.recent-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap;padding:10px 16px;font-size:10px;font-weight:700}.admin-table td{border-bottom:1px solid var(--line);color:var(--ink);vertical-align:top;padding:10px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--cream-soft)}.td-id{color:var(--muted);font-size:12px;font-weight:600}.student-cell{align-items:center;gap:10px;display:flex}.student-avatar{background:var(--green-light);width:32px;height:32px;color:var(--green-deep);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex}.student-name{color:var(--ink);font-weight:600}.student-meta{color:var(--muted);font-size:11px}.pay-tag{background:var(--green-light);color:var(--green-deep);border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.pay-tag.cash{background:var(--gold-light);color:var(--green-deep)}.status-badge{border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.status-badge.pending{color:#713f12;background:#fef9c3}.status-badge.confirmed{color:#14532d;background:#dcfce7}.status-badge.rejected{color:#7f1d1d;background:#fee2e2}.student-type-tag{vertical-align:middle;border-radius:999px;margin-left:6px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.student-type-tag.new{color:#1e40af;background:#dbeafe}.student-type-tag.returning{color:#5b21b6;background:#ede9fe}@media (width<=1100px){.stats-grid{grid-template-columns:1fr 1fr}.charts-row{grid-template-columns:1.4fr 1fr}}@media (width<=880px){.charts-row{grid-template-columns:1fr}}@media (width<=640px){.stats-grid{grid-template-columns:1fr}}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--white);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:640px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000040}.modal.modal-sm{max-width:440px}.modal-header{background:linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);align-items:center;gap:16px;padding:24px;display:flex;position:relative}.modal-header h2{color:var(--white);font-size:20px}.modal-header p{color:#ffffffbf;margin-top:2px;font-size:13px}.modal-avatar{background:var(--gold);width:56px;height:56px;color:var(--green-deep);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:800;display:flex}.modal-close{color:var(--white);cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex;position:absolute;top:16px;right:16px}.modal-body{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.modal-section h4{font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);margin-bottom:12px;padding-bottom:6px;font-size:12px;font-weight:700}.modal-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.reject-reason{color:#dc2626;font-size:13px}.ref-number{color:var(--muted,#6b7280);letter-spacing:.5px;margin-top:6px;font-size:12px}.modal-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.detail-row.full{grid-column:1/-1}.detail-label{color:var(--muted);letter-spacing:.04em;margin-bottom:2px;font-size:11px;font-weight:700}.detail-value{color:var(--ink);font-size:14px}.fee-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px}.fee-card-top{align-items:center;gap:10px;margin-bottom:6px;display:flex}.fee-level{color:var(--green-deep);font-size:15px;font-weight:700}.fee-group{color:var(--muted);margin-bottom:8px;font-size:12px}.fee-total{font-family:var(--font-heading);color:var(--green-deep);font-size:28px;font-weight:700}.fee-sub{color:var(--muted);font-size:12px}.fee-payments{border-top:1px solid var(--line);flex-direction:column;gap:6px;margin-top:14px;padding-top:10px;display:flex}.fee-pay-row{color:var(--muted);justify-content:space-between;font-size:13px;display:flex}.fee-pay-val{color:var(--ink);font-weight:700}.fee-balance-due{color:#dc2626}.modal-footer{border-top:1px solid var(--line);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.modal-footer .btn-primary,.modal-footer .btn-ghost,.modal-footer .btn-danger{padding:9px 18px;font-size:13px}.modal-reject-btn{color:#dc2626;font-family:var(--font-body);cursor:pointer;background:#fee2e2;border:none;border-radius:999px;padding:10px 20px;font-size:14px;font-weight:700}.modal-reject-btn:hover{background:#fca5a5}.danger-btn{color:var(--white);font-family:var(--font-body);cursor:pointer;background:#dc2626;border:none;border-radius:999px;padding:10px 20px;font-size:14px;font-weight:700}.danger-btn:hover{background:#b91c1c}.modal-lg{max-width:740px}.add-error-banner{color:#dc2626;background:#fee2e2;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600}.add-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.add-field{flex-direction:column;gap:4px;display:flex}.add-field.add-full{grid-column:1/-1}.add-field input{background:var(--cream);border:1.5px solid var(--line);width:100%;font-family:var(--font-body);color:var(--ink);border-radius:10px;outline:none;padding:9px 12px;font-size:14px;transition:border-color .15s}.add-field input:focus{border-color:var(--green)}.add-field.has-error input{border-color:#dc2626}.field-error{color:#dc2626;font-size:11px}.req{color:#dc2626}.add-pills{flex-wrap:wrap;gap:8px;display:flex}.add-pill{border:1.5px solid var(--line);color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.add-pill input[type=radio]{display:none}.add-pill.checked{background:var(--green-light);border-color:var(--green);color:var(--green-deep);font-weight:700}.modal-title-sm{color:var(--green-deep);margin-bottom:10px;font-size:18px}.modal-desc{color:var(--muted);margin-bottom:16px;font-size:14px;line-height:1.65}.modal-textarea{background:var(--cream);border:1.5px solid var(--line);width:100%;font-family:var(--font-body);color:var(--ink);resize:vertical;border-radius:12px;outline:none;padding:12px 16px;font-size:14px;transition:border-color .15s}.modal-textarea:focus{border-color:var(--green)}.edit-input{background:var(--cream);border:1.5px solid var(--line);width:100%;font-family:var(--font-body);color:var(--ink);border-radius:8px;outline:none;padding:6px 10px;font-size:13px;transition:border-color .15s}.edit-input:focus{border-color:var(--green)}.attach-list{flex-direction:column;gap:6px;display:flex}.attach-row{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.attach-icon{flex-shrink:0}.attach-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.attach-date{color:var(--muted);flex-shrink:0;font-size:11px}.attach-action{color:var(--green);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:13px;font-weight:700;text-decoration:none}.attach-delete{color:#dc2626}.attach-delete:hover{color:#b91c1c}.student-type-badge{border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.student-type-badge.new{color:#1e40af;background:#dbeafe}.student-type-badge.returning{color:#5b21b6;background:#ede9fe}.student-type-toggle{border:1.5px solid var(--line);border-radius:var(--radius-sm);display:inline-flex;overflow:hidden}.student-type-toggle button{font-size:13px;font-weight:600;font-family:var(--font-body);color:var(--muted);cursor:pointer;background:0 0;border:none;padding:7px 16px;transition:background .15s,color .15s}.student-type-toggle button+button{border-left:1.5px solid var(--line)}.student-type-toggle button.active{background:var(--green-light);color:var(--green-deep)}.enrollments-view{flex-direction:column;gap:16px;padding:24px;display:flex}.toolbar{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px;display:flex}.search-box{background:var(--cream);border:1.5px solid #0000;border-radius:10px;flex:1;align-items:center;gap:8px;min-width:200px;padding:9px 14px;transition:border-color .15s;display:flex}.search-box:focus-within{border-color:var(--green);background:var(--white)}.search-icon{color:var(--muted);font-size:14px}.search-box input{font-family:var(--font-body);color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:14px}.toolbar select{background:var(--cream);border:1.5px solid var(--line);font-family:var(--font-body);color:var(--ink);cursor:pointer;border-radius:10px;outline:none;padding:9px 14px;font-size:13px}.toolbar select:focus{border-color:var(--green)}.date-range{color:var(--muted);align-items:center;gap:6px;font-size:13px;display:flex}.date-range input{background:var(--cream);border:1.5px solid var(--line);font-family:var(--font-body);color:var(--ink);border-radius:10px;outline:none;padding:8px 12px;font-size:13px}.date-range input:focus{border-color:var(--green)}.reset-btn{color:#dc2626;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:13px;font-weight:600}.reset-btn:hover{text-decoration:underline}.toolbar-spacer{flex:1}.export-btn.primary-sm{background:var(--green);color:var(--white);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:700}.export-btn.primary-sm:hover{background:var(--green-deep)}.add-btn.primary-sm{background:var(--gold);color:var(--green-deep);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:700}.add-btn.primary-sm:hover{background:var(--gold-soft)}.bulk-bar{background:var(--green-deep);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.bulk-left{color:var(--white);align-items:center;gap:12px;font-size:14px;display:flex}.bulk-left strong{color:var(--gold-soft)}.bulk-actions{gap:8px;display:flex}.bulk-btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:700}.bulk-btn.confirm{background:var(--green);color:var(--white);border:1px solid #fff3}.bulk-btn.reject,.bulk-btn.export{color:var(--white);background:#ffffff1a}.bulk-btn.delete{color:var(--white);background:#dc2626}.table-wrap{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);position:relative;overflow-x:auto}.table-loading{color:var(--muted);z-index:5;background:#ffffffb3;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;inset:0}.enrollments-table{min-width:900px}.enrollments-table input[type=checkbox]{cursor:pointer;accent-color:var(--green)}.enrollments-table tr.selected td{background:#f0fdf0}.td-sm{white-space:nowrap;font-size:12px}.td-date{white-space:nowrap;color:var(--muted);font-size:12px}.td-addr{white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:12px;line-height:1.4;overflow:hidden}.row-actions{gap:4px;display:flex}.row-actions button{border:1px solid var(--line);background:var(--cream);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .13s;display:flex}.row-actions button:hover{background:var(--green-light);border-color:var(--green)}.row-actions button.danger:hover{background:#fee2e2;border-color:#ef4444}.empty-state{text-align:center;padding:48px 16px!important}.empty-state div{margin-bottom:8px;font-size:28px}.empty-state p{color:var(--muted);margin-bottom:12px;font-size:14px}.empty-state button{color:var(--green);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:600;text-decoration:underline}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.pager-info{color:var(--muted);font-size:13px}.pager-controls{align-items:center;gap:8px;display:flex}.pager-controls select{background:var(--cream);border:1px solid var(--line);font-size:13px;font-family:var(--font-body);border-radius:8px;padding:6px 10px}.pager-controls button{background:var(--white);border:1px solid var(--line);cursor:pointer;border-radius:8px;padding:6px 12px;font-size:14px;transition:background .12s}.pager-controls button:hover:not(:disabled){background:var(--green-light);border-color:var(--green)}.pager-controls button:disabled{opacity:.4;cursor:default}.pager-controls span{color:var(--muted);text-align:center;min-width:48px;font-size:13px}@media (width<=880px){.enrollments-view{gap:12px;padding:12px}.toolbar{gap:8px;padding:12px}.toolbar-spacer{display:none}.date-range{flex-wrap:wrap}.table-wrap{box-shadow:none;background:0 0;border:none;border-radius:0;overflow:visible}.enrollments-table{background:0 0;min-width:0}.enrollments-table thead{display:none}.enrollments-table tbody tr{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:8px;padding:14px;box-shadow:0 1px 3px #0000000a}.enrollments-table td{border:none;padding:0;font-size:13px}.enrollments-table tbody tr:has(.empty-state){border:1px solid var(--line);box-shadow:none;background:0 0;display:block}.enrollments-table td.empty-state{display:block;padding:48px 16px!important}.et-enrollments tbody tr{grid-template-columns:1fr auto;gap:4px 8px;display:grid}.et-enrollments td:first-child{display:none}.et-enrollments td:nth-child(2){color:var(--muted);grid-area:1/1/2/2;font-size:11px}.et-enrollments td:nth-child(3){display:none}.et-enrollments td:nth-child(4){grid-area:2/1/3/3;padding:4px 0}.et-enrollments td:nth-child(5){grid-area:3/1/4/2;align-items:center;display:flex}.et-enrollments td:nth-child(6){grid-area:3/2/4/3;justify-content:flex-end;align-items:center;display:flex}.et-enrollments td:nth-child(7){grid-area:1/2/2/3;justify-content:flex-end;align-items:center;display:flex}.et-enrollments td:nth-child(8){border-top:1px solid var(--line);grid-area:4/1/5/3;margin-top:4px;padding-top:10px}.et-enrollments .row-actions{justify-content:flex-end}.et-enrollments .row-actions button{width:36px;height:36px;font-size:15px}.et-students tbody tr{grid-template-columns:1fr auto;gap:3px 8px;display:grid}.et-students td:first-child{grid-area:1/1/2/2}.et-students td:nth-child(2),.et-students td:nth-child(3){display:none}.et-students td:nth-child(4){color:var(--muted);grid-area:2/1/3/3;font-size:12px}.et-students td:nth-child(5){color:var(--muted);text-overflow:ellipsis;white-space:nowrap;grid-area:3/1/4/3;max-width:100%;font-size:12px;overflow:hidden}.et-students td:nth-child(6){color:var(--muted);grid-area:4/1/5/2;font-size:12px}.et-students td:nth-child(7){color:var(--muted);text-align:right;text-overflow:ellipsis;white-space:nowrap;grid-area:4/2/5/3;max-width:130px;font-size:12px;overflow:hidden}.et-students td:nth-child(8){display:none}.et-students td:nth-child(9){grid-area:1/2/2/3;justify-content:flex-end;align-items:flex-start;display:flex}.et-students td:nth-child(10){border-top:1px solid var(--line);grid-area:5/1/6/3;margin-top:4px;padding-top:10px}.et-students .row-actions{justify-content:flex-end}.et-students .row-actions button{width:36px;height:36px;font-size:15px}.pagination{flex-direction:column;align-items:flex-start;gap:8px}}.pay-tabs{border-bottom:2px solid var(--line);background:#fff;gap:4px;display:flex}.pay-tab{font-family:var(--font-body);color:var(--muted);cursor:pointer;border-radius:var(--radius) var(--radius) 0 0;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.pay-tab:hover{color:var(--ink)}.pay-tab.active{color:var(--green-deep);border-bottom-color:var(--green);font-weight:600}.ledger-wrap{overflow-x:auto}.ledger-table{table-layout:fixed;min-width:1200px;font-size:13px}.th-ref{width:100px}.th-name{width:160px}.th-level{width:110px}.th-month{width:58px;font-size:11px}.ledger-table .th-month{text-align:center}.th-paid,.th-bal{width:90px}.ledger-table .th-paid,.ledger-table .th-bal{text-align:right}.td-ref{color:var(--green);white-space:nowrap;font-size:11px;font-weight:600}.td-name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.ledger-table .td-sm{flex-direction:column;gap:3px;display:flex}.pay-type-cash{color:#16a34a;background:#dcfce7;border-radius:4px;width:fit-content;padding:1px 5px;font-size:10px;font-weight:700}.pay-type-inst{color:#6b7280;background:#f3f4f6;border-radius:4px;width:fit-content;padding:1px 5px;font-size:10px;font-weight:700}.td-paid{text-align:right;font-weight:600}.td-bal{text-align:right;font-weight:700}.bal-zero{color:#16a34a}.bal-owing{color:#dc2626}.td-month{text-align:center;cursor:pointer;transition:background .1s;padding:4px 2px!important}.td-month.is-paid{cursor:default;background:#f0fdf4}.td-month.is-unpaid:hover{background:#fefce8}.td-month.is-disabled{cursor:not-allowed;background:#f9fafb}.paid-cell{color:#16a34a;cursor:pointer;white-space:nowrap;background:#dcfce7;border-radius:4px;padding:2px 4px;font-size:11px;font-weight:600;display:inline-block}.paid-cell:hover{color:#dc2626;background:#fecaca}.unpaid-cell{color:#9ca3af;border:1.5px dashed #d1d5db;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:14px;line-height:1;display:inline-flex}.disabled-cell{color:#e5e7eb;font-size:12px}.th-extra{width:90px}.td-extra{text-align:center;white-space:nowrap}.extra-toggle{border:1px solid var(--line);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:600}.extra-toggle:hover{border-color:var(--green);color:var(--green)}.extra-toggle.open{border-color:var(--green);color:var(--green);background:var(--green-light)}.extra-fees-row td{border-top:none!important;padding:0!important}.extra-fees-inner{border-top:1px solid var(--line);border-bottom:2px solid var(--line);background:#f8fafc;padding:12px 20px 14px}.extra-fees-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.extra-fees-title{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:700}.extra-fees-empty{color:var(--muted);margin:0;font-size:13px}.btn-add-fee{border:1.5px dashed var(--green);color:var(--green);cursor:pointer;background:0 0;border-radius:7px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:700}.btn-add-fee:hover{background:var(--green-light)}.extra-fee-list{flex-direction:column;gap:6px;display:flex}.extra-fee-item{background:var(--white);border:1px solid var(--line);border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.fee-name{flex:0 0 180px;font-weight:600}.fee-amount{color:var(--ink);flex:0 0 80px;font-weight:700}.fee-paid-chip{color:#16a34a;background:#dcfce7;border-radius:6px;flex:1;padding:3px 8px;font-size:12px;font-weight:600}.fee-pay-btn{background:var(--green);color:var(--white);cursor:pointer;border:none;border-radius:7px;margin-left:auto;padding:5px 12px;font-size:12px;font-weight:700}.fee-pay-btn:hover{opacity:.85}.fee-undo-btn{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:7px;margin-left:auto;padding:4px 10px;font-size:11px;font-weight:700}.fee-undo-btn:hover{background:#fef2f2}.fee-del-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.fee-del-btn:hover{color:#dc2626}.inst-expected{color:#9ca3af;white-space:nowrap;margin-bottom:2px;font-size:10px;font-weight:500;display:block}.inst-badge-wrap{cursor:default;position:relative}.inst-badge-wrap:hover .inst-schedule-tip{display:flex}.inst-schedule-tip{z-index:200;border:1.5px solid var(--line);white-space:nowrap;pointer-events:none;background:#fff;border-radius:8px;flex-direction:column;gap:3px;min-width:170px;padding:8px 10px;display:none;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 4px 12px #0000001f}.tip-row{color:var(--ink);justify-content:space-between;gap:12px;font-size:11px;font-weight:500;display:flex}.tip-row span:first-child{color:var(--muted);font-weight:400}.tip-total{border-top:1px solid var(--line);padding-top:4px;font-weight:700}.ledger-legend{align-items:center;gap:12px;font-size:12px;display:flex}.cell-paid-eg{color:#16a34a;font-weight:600}.cell-unpaid-eg{color:#9ca3af}.balance-summary{background:var(--cream);border-radius:10px;flex-wrap:wrap;gap:20px;padding:10px 14px;font-size:13px;display:flex}.balance-summary .green{color:#16a34a}.balance-summary .red{color:#dc2626}.discount-row{align-items:center;gap:8px;display:flex}.discount-type-toggle{border:1.5px solid var(--line);border-radius:8px;flex-shrink:0;display:flex;overflow:hidden}.discount-type-toggle button{cursor:pointer;color:var(--muted);font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;border:none;padding:9px 14px;transition:background .1s,color .1s}.discount-type-toggle button:first-child{border-right:1.5px solid var(--line)}.discount-type-toggle button.active{background:var(--green-light);color:var(--green-deep)}.discount-value-input{border:1.5px solid var(--line);font-family:var(--font-body);background:var(--white);border-radius:10px;outline:none;flex:1;min-width:0;padding:10px 14px;font-size:14px}.discount-value-input:focus{border-color:var(--green)}.discount-preview{color:var(--green-deep);white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:700}.cash-tendered-row{align-items:center;gap:10px;display:flex}.cash-tendered-row input{flex:1;min-width:0}.change-display{color:#16a34a;white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:700}.change-display.change-short{color:#dc2626}.pay-modal{max-width:480px}.pay-error{color:#dc2626;margin-top:8px;font-size:13px}.field-group{flex-direction:column;gap:6px;display:flex}.field-group.full{grid-column:1/-1}.field-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.field-group input,.field-group select{border:1.5px solid var(--line);font-family:var(--font-body);background:var(--white);border-radius:10px;outline:none;padding:10px 14px;font-size:14px}.field-group input:focus,.field-group select:focus{border-color:var(--green)}.ledger-mobile-cards{display:none}.lmc-loading{text-align:center;color:var(--muted);padding:24px;font-size:14px}.lmc-empty{text-align:center;color:var(--muted);padding:48px 16px;font-size:14px}.lmc-empty div{margin-bottom:8px;font-size:28px}.ledger-drawer-overlay{z-index:1000;background:#00000080;align-items:flex-end;display:flex;position:fixed;inset:0}.ledger-drawer{background:var(--white);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:column;width:100%;max-height:80vh;display:flex;overflow:hidden}.ledger-drawer-header{background:var(--green-deep);color:var(--white);flex-shrink:0;align-items:center;gap:12px;padding:16px 20px;display:flex}.ldh-info{flex:1;min-width:0}.ldh-info h3{font-family:var(--font-body);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:15px;font-weight:700;overflow:hidden}.ldh-meta{color:#ffffffa6;margin:2px 0 0;font-size:12px}.ldh-balance{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;font-size:12px;display:flex}.ldh-balance strong{color:var(--gold-soft)}.ldh-balance .bal-zero{color:#86efac}.ldh-balance .bal-owing{color:#fca5a5}.ledger-drawer-close{width:28px;height:28px;color:var(--white);cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.ledger-drawer-close:hover{background:#ffffff40}.ledger-drawer-months{flex:1;padding:4px 0;overflow-y:auto}.drawer-month-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:12px 20px;display:flex}.drawer-month-row:last-child{border-bottom:none}.drawer-month-row.is-paid{background:#f0fdf4}.drawer-month-row.is-disabled{opacity:.45}.dmr-left{flex:1;min-width:0}.dmr-month{color:var(--ink);font-size:14px;font-weight:600;display:block}.dmr-detail{color:var(--muted);margin-top:2px;font-size:12px;display:block}.dmr-expected{color:#9ca3af}.dmr-na{color:#d1d5db}.dmr-right{flex-shrink:0}.dmr-pay-btn{background:var(--green);color:var(--white);font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700}.dmr-pay-btn:hover{background:var(--green-deep)}.dmr-edit-btn{background:var(--cream);color:var(--ink);border:1px solid var(--line);font-family:var(--font-body);cursor:pointer;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600}.dmr-edit-btn:hover{border-color:var(--green);color:var(--green)}@media (width<=880px){.ledger-mobile-cards{display:block}.table-wrap.ledger-wrap,.ledger-legend{display:none}.lmc-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:8px;padding:14px;box-shadow:0 1px 3px #0000000a}.lmc-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.lmc-ref{color:var(--green);font-size:11px;font-weight:600}.lmc-name{color:var(--ink);margin-bottom:2px;font-size:15px;font-weight:700}.lmc-level{color:var(--muted);margin-bottom:10px;font-size:12px}.lmc-footer{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding-top:10px;display:flex}.lmc-amounts{flex-direction:column;gap:2px;font-size:12px;display:flex}.lmc-amounts strong{color:var(--ink);font-weight:700}.lmc-amounts .bal-zero{color:#16a34a;font-weight:700}.lmc-amounts .bal-owing{color:#dc2626;font-weight:700}.lmc-view-btn{background:var(--green);color:var(--white);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;flex-shrink:0;padding:9px 16px;font-size:13px;font-weight:700}.lmc-view-btn:hover{background:var(--green-deep)}}.searchable-select{position:relative}.searchable-select-trigger{background:var(--cream);border:1.5px solid var(--line);font-family:var(--font-body);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;min-width:140px;color:inherit;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;font-size:14px;display:flex}.searchable-select-trigger:focus{border-color:var(--green);outline:none}.searchable-select-trigger.open{border-color:var(--green)}.searchable-select-arrow{opacity:.6;font-size:11px}.searchable-select-dropdown{border:1.5px solid var(--line);z-index:100;background:#fff;border-radius:10px;min-width:100%;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 4px 16px #0000001a}.searchable-select-search{border:none;border-bottom:1px solid var(--line);width:100%;font-family:var(--font-body);background:var(--cream);box-sizing:border-box;outline:none;padding:8px 12px;font-size:14px}.searchable-select-list{max-height:200px;overflow-y:auto}.searchable-select-option{cursor:pointer;font-size:14px;font-family:var(--font-body);padding:8px 14px}.searchable-select-option:hover{background:var(--cream)}.searchable-select-option.selected{color:var(--green);font-weight:600}.amount-hint{color:var(--muted);margin-top:4px;font-size:11px}.walkin-section-header{border-top:2px dashed var(--line);justify-content:space-between;align-items:flex-start;gap:16px;margin-top:8px;padding:20px 0 0;display:flex}.walkin-title{color:var(--green-deep);margin-bottom:2px;font-size:15px;font-weight:700}.walkin-sub{color:var(--muted);font-size:12px}.report-summary{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:0;margin-bottom:12px;padding:16px 24px;display:flex}.report-summary-item{flex:1;min-width:140px;padding:0 16px}.report-summary-item:first-child{padding-left:0}.report-summary-divider{background:var(--line);flex-shrink:0;width:1px;height:40px}.rs-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 4px;font-size:10px;font-weight:700}.rs-value{color:var(--text);margin:0;font-size:20px;font-weight:700}.rs-grand .rs-value{color:var(--green,#2e7d32);font-size:24px}.report-total-row td{background:var(--cream);border-top:2px solid var(--line);padding:10px 12px}.badge-confirmed,.badge-pending,.badge-walkin{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.badge-confirmed{color:#14532d;background:#dcfce7}.badge-pending{color:#713f12;background:#fef9c3}.badge-walkin{color:#5b21b6;background:#ede9fe}.discount-chip{color:#854d0e;white-space:nowrap;background:#fef9c3;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:700;display:inline-block}@media (width<=880px){.report-summary{gap:12px;margin-bottom:0;padding:12px 16px}.report-summary-item{min-width:120px;padding:0}.report-summary-divider{display:none}.et-reports tbody tr{grid-template-columns:1fr auto;gap:3px 8px;display:grid}.et-reports td:first-child{color:var(--muted);grid-area:1/1/2/2;font-size:12px}.et-reports td:nth-child(5){grid-area:1/2/2/3;justify-content:flex-end;align-items:center;display:flex}.et-reports td:nth-child(2){grid-area:2/1/3/2;font-size:14px;font-weight:600}.et-reports td:nth-child(3){color:var(--muted);grid-area:2/2/3/3;justify-content:flex-end;align-items:center;font-size:11px;display:flex}.et-reports td:nth-child(4){color:var(--muted);grid-area:3/1/4/2;font-size:12px}.et-reports td:nth-child(7){color:var(--muted);grid-area:3/2/4/3;justify-content:flex-end;align-items:center;font-size:12px;display:flex}.et-reports td:nth-child(6){grid-area:4/1/5/3;font-size:13px}.et-reports td:nth-child(8){display:none}.et-reports td:nth-child(9){grid-area:5/1/6/2;align-items:center;display:flex}.et-reports td:nth-child(10){color:var(--green-deep);grid-area:5/2/6/3;justify-content:flex-end;align-items:center;font-size:15px;font-weight:700;display:flex}.et-reports tfoot{display:none}}.sy-settings{grid-template-columns:1fr 1fr;align-items:start;gap:20px;padding:24px;display:grid}.sy-col{flex-direction:column;gap:20px;display:flex}.sy-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:28px;display:flex}.sy-title{color:var(--ink);margin:0;font-size:18px;font-weight:700}.sy-subtitle{color:var(--ink);margin:0;font-size:15px;font-weight:700}.sy-desc{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.sy-current{background:var(--green-light);border:1px solid var(--green);border-radius:12px;align-items:center;gap:12px;padding:14px 18px;display:flex}.sy-label{color:var(--green-deep);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700}.sy-badge{color:var(--green-deep);margin-left:auto;font-size:20px;font-weight:800}.sy-field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:700}.sy-row{gap:10px;display:flex}.sy-input{border:1.5px solid var(--line);font-family:var(--font-body);color:var(--ink);border-radius:10px;outline:none;flex:1;padding:11px 16px;font-size:15px;font-weight:600}.sy-input:focus{border-color:var(--green)}.sy-save-btn{background:var(--green);color:var(--white);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:11px 24px;font-size:14px;font-weight:700}.sy-save-btn:disabled{opacity:.45;cursor:default}.sy-hint{color:var(--muted);margin:0;font-size:12px}.sy-years{flex-direction:column;gap:8px;display:flex}.sy-year-row{border:1px solid var(--line);color:var(--ink);border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.sy-year-row.active{border-color:var(--green);background:var(--green-light)}.sy-active-tag{background:var(--green);color:var(--white);text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.sy-switch-btn{border:1px solid var(--line);font-family:var(--font-body);cursor:pointer;color:var(--green);background:0 0;border-radius:8px;margin-left:auto;padding:5px 12px;font-size:12px;font-weight:600}.sy-switch-btn:hover:not(:disabled){background:var(--green-light);border-color:var(--green)}.sy-switch-btn:disabled{color:var(--muted);cursor:default;border-color:#0000}.sy-months-list{flex-direction:column;gap:6px;display:flex}.sy-month-row{border:1px solid var(--line);border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;font-weight:500;display:flex}.sy-month-name{color:var(--ink);flex:1}.sy-month-actions{gap:4px;display:flex}.sy-arrow-btn{border:1px solid var(--line);cursor:pointer;width:28px;height:28px;color:var(--muted);background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:13px;display:flex}.sy-arrow-btn:hover:not(:disabled){background:var(--green-light);color:var(--green);border-color:var(--green)}.sy-arrow-btn:disabled{opacity:.3;cursor:default}.sy-remove-btn{cursor:pointer;color:#dc2626;background:0 0;border:1px solid #fca5a5;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:flex}.sy-remove-btn:hover{background:#fef2f2}.sy-add-month{gap:10px;display:flex}.sy-months-footer{justify-content:flex-end;display:flex}.roles-loading{text-align:center;color:var(--muted);padding:48px;font-size:14px}.roles-page{flex-direction:column;gap:20px;padding:24px;display:flex}.roles-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.roles-title{font-family:var(--font-head);color:var(--ink);margin:0 0 4px;font-size:17px;font-weight:700}.roles-sub{color:var(--muted);margin:0;font-size:13px}.roles-empty{background:var(--cream);border:1.5px dashed var(--line);border-radius:var(--radius-lg);text-align:center;color:var(--muted);padding:40px 24px;font-size:14px}.roles-list{flex-direction:column;gap:12px;display:flex}.role-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);flex-direction:column;gap:12px;padding:16px 20px;display:flex}.role-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.role-card-name{color:var(--ink);margin:0 0 2px;font-size:15px;font-weight:700}.role-card-meta{color:var(--muted);margin:0;font-size:12px}.role-card-actions{flex-shrink:0;gap:8px;display:flex}.role-perm-chips{flex-wrap:wrap;gap:6px;display:flex}.role-chip{background:var(--green-light);color:var(--green-deep);letter-spacing:.03em;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.role-no-perms{color:var(--muted);font-size:12px;font-style:italic}.role-name-input{box-sizing:border-box;background:var(--cream);border:1.5px solid var(--line);width:100%;font-family:var(--font-body);color:var(--ink);border-radius:10px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.role-name-input:focus{border-color:var(--green);background:var(--white)}.role-perm-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 8px;font-size:11px;font-weight:700}.role-module-list{flex-direction:column;gap:6px;display:flex}.role-module-row{flex-direction:column;gap:4px;display:flex}.role-perm-item{border:1.5px solid var(--line);color:var(--ink);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:border-color .15s,background .15s;display:flex}.role-perm-item input[type=checkbox]{accent-color:var(--green);cursor:pointer}.role-perm-item:hover{border-color:var(--green);background:var(--cream)}.role-perm-item.checked{border-color:var(--green);background:var(--green-light);color:var(--green-deep);font-weight:600}.role-subactions{flex-wrap:wrap;gap:5px;padding:4px 8px 6px 22px;display:flex}.role-subaction-item{border:1.5px solid var(--line);color:var(--ink);cursor:pointer;-webkit-user-select:none;user-select:none;text-transform:capitalize;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;transition:border-color .12s,background .12s;display:flex}.role-subaction-item input[type=checkbox]{accent-color:var(--green);cursor:pointer;width:12px;height:12px}.role-subaction-item:hover{border-color:var(--green);background:var(--cream)}.role-subaction-item.checked{border-color:var(--green);background:var(--green-light);color:var(--green-deep);font-weight:600}.role-badge{background:var(--green-light);color:var(--green-deep);letter-spacing:.03em;white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.role-badge.full-admin{color:#6b7280;background:#f3f4f6}.br-page{grid-template-columns:1fr 1fr;align-items:start;gap:20px;padding:24px;display:grid}.br-col{flex-direction:column;gap:20px;display:flex}.br-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);flex-direction:column;gap:16px;padding:28px;display:flex}.br-title{color:var(--ink);margin:0;font-size:18px;font-weight:700}.br-desc{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.br-desc code{background:var(--cream);border-radius:4px;padding:1px 5px;font-size:13px}.br-includes{flex-direction:column;gap:6px;margin:0;padding-left:20px;display:flex}.br-includes li{color:var(--ink);font-size:14px}.br-warning{background:#fef2f2;border:1px solid #fca5a5;border-radius:12px;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.br-warning-icon{color:#fff;background:#dc2626;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:800;display:flex}.br-warning-text{color:#7f1d1d;margin:0;font-size:13px;line-height:1.55}.br-warning-text strong{color:#dc2626}.br-file-row{align-items:center;display:flex}.br-file-label{cursor:pointer;align-items:center;gap:12px;width:100%;display:flex}.br-file-input{display:none}.br-file-btn{background:var(--white);border:1.5px solid var(--line);font-family:var(--font-body);color:var(--ink);cursor:pointer;white-space:nowrap;border-radius:10px;flex-shrink:0;padding:9px 18px;font-size:13px;font-weight:700}.br-file-label:hover .br-file-btn{border-color:var(--green);color:var(--green)}.br-file-name{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.br-btn{font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-self:flex-start;padding:11px 24px;font-size:14px;font-weight:700}.br-btn:disabled{opacity:.45;cursor:default}.br-btn-primary{background:var(--green);color:var(--white)}.br-btn-primary:hover:not(:disabled){opacity:.9}.br-btn-danger{color:#fff;background:#dc2626}.br-btn-danger:hover:not(:disabled){background:#b91c1c}.br-btn-ghost{background:var(--white);border:1.5px solid var(--line);color:var(--ink)}.br-btn-ghost:hover{border-color:var(--ink)}.br-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.br-modal{background:var(--white);border-radius:var(--radius-lg);flex-direction:column;gap:14px;width:100%;max-width:440px;padding:32px;display:flex;box-shadow:0 20px 60px #0003}.br-modal-title{color:var(--ink);margin:0;font-size:18px;font-weight:800}.br-modal-body{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.br-modal-body strong{color:var(--ink)}.br-modal-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}@media (width<=700px){.br-page{grid-template-columns:1fr}}.settings-page{flex-direction:column;height:100%;display:flex}.settings-tabs{border-bottom:1px solid var(--line);background:var(--white);gap:4px;padding:20px 24px 0;display:flex}.settings-tab{font-family:var(--font-body);color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 18px;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.settings-tab:hover{color:var(--ink)}.settings-tab.active{color:var(--green);border-bottom-color:var(--green)}.settings-body{flex:1;overflow:auto}.todo-loading{color:var(--muted);padding:40px;font-size:15px}.todo-page{height:calc(100vh - 60px);display:flex;overflow:hidden}.todo-projects-panel{border-right:1px solid var(--line);background:var(--cream-soft);flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow:hidden}.todo-panel-header{justify-content:space-between;align-items:center;gap:8px;padding:20px 20px 8px;display:flex}.todo-panel-title{font-family:var(--font-heading);color:var(--green-deep);margin:0;font-size:17px;font-weight:700}.todo-items-count{color:var(--muted);background:var(--green-light);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600}.todo-add-form{gap:8px;padding:0 12px 12px;display:flex}.todo-input{border:1px solid var(--line);border-radius:var(--radius-sm);min-width:0;font-size:13px;font-family:var(--font-body);color:var(--ink);background:var(--white);outline:none;flex:1;padding:8px 12px;transition:border-color .15s}.todo-input:focus{border-color:var(--green)}.todo-input::placeholder{color:#aab8aa}.todo-add-btn{background:var(--green);color:var(--white);border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;flex-shrink:0;padding:8px 14px;transition:background .15s}.todo-add-btn:hover:not(:disabled){background:var(--green-soft)}.todo-add-btn:disabled{opacity:.45;cursor:not-allowed}.todo-project-list{flex:1;margin:0;padding:0 8px;list-style:none;overflow-y:auto}.todo-project-list li{border-radius:var(--radius-sm);align-items:stretch;margin-bottom:2px;display:flex;overflow:hidden}.todo-project-list li:hover .todo-project-delete{opacity:1}.todo-project-btn{font-family:var(--font-body);color:var(--ink);cursor:pointer;text-align:left;border-radius:var(--radius-sm) 0 0 var(--radius-sm);background:0 0;border:none;flex:1;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:500;transition:background .12s;display:flex}.todo-project-btn:hover{background:var(--green-light)}.todo-project-btn.active{background:var(--green-light);color:var(--green-deep);font-weight:700}.todo-project-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.todo-project-count{color:var(--muted);background:var(--line);text-align:center;border-radius:20px;flex-shrink:0;min-width:20px;padding:1px 7px;font-size:11px;font-weight:700}.todo-project-delete{color:#c0392b;cursor:pointer;opacity:0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:0 0;border:none;flex-shrink:0;padding:0 10px;font-size:11px;transition:opacity .12s,background .12s}.todo-project-delete:hover{background:#fde8e6}.todo-empty-projects{color:var(--muted);text-align:center;padding:12px;font-size:13px}.todo-items-panel{background:var(--white);flex-direction:column;flex:1;display:flex;overflow:hidden}.todo-no-selection{color:var(--muted);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.todo-item-list{flex:1;margin:0;padding:0 20px;list-style:none;overflow-y:auto}.todo-item{border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:11px 0;display:flex}.todo-item:last-child{border-bottom:none}.todo-item:hover .todo-item-delete{opacity:1}.todo-item-label{cursor:pointer;flex:1;align-items:center;gap:12px;display:flex}.todo-checkbox{width:16px;height:16px;accent-color:var(--green);cursor:pointer;flex-shrink:0}.todo-item-text{color:var(--ink);font-size:14px;line-height:1.4;transition:color .15s}.todo-item.done .todo-item-text{color:var(--muted);text-decoration:line-through}.todo-drag-handle{color:var(--muted);cursor:grab;opacity:0;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 4px;font-size:16px;line-height:1;transition:opacity .12s,color .12s}.todo-item:hover .todo-drag-handle{opacity:1}.todo-drag-handle:active{cursor:grabbing}.todo-item.dragging{opacity:.4}.todo-item.drag-over{border-top:2px solid var(--green)}.todo-item-delete{color:#c0392b;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px 8px;font-size:11px;transition:opacity .12s,background .12s}.todo-item-delete:hover{background:#fde8e6}.todo-empty-items{color:var(--muted);padding:20px 0;font-size:13px}@media (width<=880px){.todo-page{flex-direction:column;height:auto}.todo-projects-panel{border-right:none;border-bottom:1px solid var(--line);width:100%;max-height:260px}.todo-items-panel{flex:unset;min-height:300px}}.toast{z-index:500;color:var(--white);border-radius:12px;align-items:center;gap:10px;padding:13px 20px;font-size:14px;font-weight:600;animation:.25s slideUp;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 24px #0000002e}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:var(--green-deep)}.toast-error{background:#dc2626}.toast-info{background:var(--gold);color:var(--green-deep)}.toast-icon{font-size:15px}.admin-app{--cream:#fff;--cream-soft:#f5f5f5;background:#fff;min-height:100vh;display:flex}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow-x:hidden}.admin-content{flex:1;overflow-y:auto}.admin-checking{min-height:100vh;color:var(--muted);background:#fff;justify-content:center;align-items:center;font-size:16px;display:flex}.page-loader{z-index:1000;background:var(--cream);opacity:1;pointer-events:all;justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}.page-loader--hidden{opacity:0;pointer-events:none}.pl-glow{pointer-events:none;background:radial-gradient(60% 60%,#f0b4292e 0%,#1a5c1a14 55%,#0000 80%);animation:3s ease-in-out infinite loaderGlow;position:absolute;inset:0}.pl-content{z-index:1;flex-direction:column;align-items:center;gap:16px;display:flex;position:relative}.pl-logo{object-fit:contain;width:96px;height:96px;animation:.5s both loaderFadeIn,3s ease-in-out .5s infinite pulse}.pl-tagline{font-family:var(--font-script);color:var(--green);letter-spacing:.04em;opacity:0;font-size:22px;animation:.5s .15s both loaderFadeIn}.pl-dots{opacity:0;align-items:flex-end;gap:10px;height:36px;animation:.5s .3s both loaderFadeIn;display:flex}.pl-dot{transform-origin:bottom;border-radius:50%;width:14px;height:14px;animation:1.1s ease-in-out infinite loaderBounce}.pl-dot--1{background:var(--green);animation-delay:0s}.pl-dot--2{background:var(--gold);animation-delay:.18s}.pl-dot--3{background:var(--gold-soft);animation-delay:.36s}@keyframes loaderBounce{0%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateY(0)scale(1)}40%{animation-timing-function:cubic-bezier(.55,.055,.675,.19);transform:translateY(-18px)scale(1.1)}60%{transform:translateY(-10px)scale(1.05)}}@keyframes loaderGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@keyframes loaderFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
