:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#0ea5e914,#0000 28%),radial-gradient(circle at 100% 0,#f59e0b14,#0000 30%),linear-gradient(#eff6ff 0%,#f8fafc 55% 100%);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{color:#0f172a;min-width:320px;margin:0}button,input,select,textarea{font:inherit}img{max-width:100%;display:block}#root{min-height:100vh}::selection{background:#0ea5e92e}.app-shell{isolation:isolate;min-height:100vh;padding:24px;position:relative}.ambient{z-index:-1;filter:blur(80px);opacity:.22;pointer-events:none;border-radius:50%;width:36rem;height:36rem;position:fixed;inset:auto}.ambient-left{background:radial-gradient(circle,#0ea5e98c,#0ea5e900);top:-8rem;left:-10rem}.ambient-right{background:radial-gradient(circle,#f59e0b73,#f59e0b00);top:10rem;right:-10rem}.topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffc;border:1px solid #94a3b833;border-radius:24px;justify-content:space-between;align-items:end;gap:16px;margin-bottom:20px;padding:20px 22px;display:flex;box-shadow:0 18px 50px #0f172a14}.topbar h1{letter-spacing:-.03em;margin:4px 0;font-size:clamp(1.5rem,2.6vw,2.35rem);line-height:1.05}.topbar-kicker{text-transform:uppercase;letter-spacing:.22em;color:#0f766e;margin:0;font-size:.78rem;font-weight:700}.topbar-subtitle{color:#475569;max-width:52ch}.topbar-meta{justify-items:end;gap:10px;display:grid}.topbar-chip{color:#0f172a;white-space:nowrap;background:#0f172a0d;border-radius:999px;padding:10px 14px;font-size:.9rem}.workspace{grid-template-columns:280px minmax(0,1fr);align-items:start;gap:20px;display:grid}.sidebar{gap:16px;display:grid;position:sticky;top:20px}.content{min-width:0}.stack{gap:18px;display:grid}.panel,.hero-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd6;border:1px solid #94a3b82e;border-radius:24px;box-shadow:0 18px 55px #0f172a14}.panel{padding:18px}.panel.large{min-height:100%}.panel-title{text-transform:uppercase;letter-spacing:.2em;color:#475569;margin-bottom:14px;font-size:.78rem;font-weight:700}.nav-stack{gap:10px;display:grid}.nav-item{color:#0f172a;text-align:left;cursor:pointer;background:#0f172a0a;border:1px solid #0000;border-radius:16px;padding:12px 14px;font-weight:600;transition:transform .18s,background .18s,border-color .18s}.nav-item:hover,.nav-item:focus-visible{background:#0ea5e914;border-color:#0ea5e92e;transform:translateY(-1px)}.nav-item.active{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9)}.mini-stat{border-top:1px solid #94a3b826;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.mini-stat:first-of-type{border-top:none}.mini-stat span{color:#64748b;font-size:.95rem}.mini-stat strong{color:#0f172a;font-size:1rem}.danger{color:#b91c1c}.success{color:#166534}.hero-card{grid-template-columns:1.2fr 1fr;gap:18px;padding:22px;display:grid;position:relative;overflow:hidden}.hero-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#0ea5e92e,#0ea5e900);border-radius:50%;width:18rem;height:18rem;position:absolute;inset:auto -6rem -5rem auto}.section-label{color:#0f766e;text-transform:uppercase;letter-spacing:.22em;margin:0 0 8px;font-size:.82rem;font-weight:700}.hero-copy h2{letter-spacing:-.04em;max-width:13ch;margin:0;font-size:clamp(1.7rem,3vw,2.6rem);line-height:1.08}.hero-text{color:#475569;max-width:62ch;margin-top:12px;line-height:1.7}.hero-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-content:stretch;gap:12px;display:grid}.stat-card{color:#fff;border-radius:20px;flex-direction:column;justify-content:space-between;min-height:116px;padding:16px;display:flex;box-shadow:inset 0 1px #ffffff2e}.stat-card span{opacity:.92;font-size:.88rem}.stat-card strong{margin-top:16px;font-size:clamp(1.2rem,2vw,1.7rem);line-height:1.05}.stat-card.teal{background:linear-gradient(135deg,#0f766e,#14b8a6)}.stat-card.gold{background:linear-gradient(135deg,#92400e,#f59e0b)}.stat-card.red{background:linear-gradient(135deg,#991b1b,#ef4444)}.stat-card.blue{background:linear-gradient(135deg,#1d4ed8,#0ea5e9)}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.panel-header{justify-content:space-between;align-items:start;gap:12px;margin-bottom:16px;display:flex}.panel-header h3{margin:0;font-size:1.15rem}.panel-header p{color:#64748b;margin-top:4px}.summary-bars{gap:18px;display:grid}.summary-bar{grid-template-columns:88px minmax(0,1fr) 48px;align-items:center;gap:12px;display:grid}.summary-bar span{color:#475569;font-weight:600}.summary-bar strong{text-align:right}.bar-track{background:#94a3b82e;border-radius:999px;height:12px;overflow:hidden}.bar-fill{border-radius:999px;height:100%}.bar-fill.success{background:linear-gradient(90deg,#0f766e,#14b8a6)}.bar-fill.danger-fill{background:linear-gradient(90deg,#ef4444,#fb7185)}.message-list{gap:12px;display:grid}.message-card{background:#0f172a0a;border:1px solid #94a3b829;border-radius:18px;gap:10px;padding:14px 16px;display:grid}.message-card p{line-height:1.5}.empty-state{text-align:center;color:#64748b;background:#0f172a08;border-radius:18px;padding:18px}.form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.fees-grid,.report-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.field{gap:8px;display:grid}.field span{color:#475569;font-size:.92rem;font-weight:600}.field input,.field select,.search-input,.filter-row input,.filter-row select{color:#0f172a;background:#ffffffeb;border:1px solid #94a3b859;border-radius:14px;outline:none;width:100%;padding:12px 14px;transition:border-color .18s,box-shadow .18s}.field input:focus,.field select:focus,.search-input:focus,.filter-row input:focus,.filter-row select:focus{border-color:#0ea5e980;box-shadow:0 0 0 4px #0ea5e91f}.field input[readonly]{color:#334155;background:#f8fafce6}.form-actions{flex-wrap:wrap;align-items:end;gap:12px;display:flex}.search-row,.filter-row,.compact{flex-wrap:wrap;gap:10px;display:flex}.primary-button,.secondary-button,.ghost-button,.text-button,.pill-button,.status-button{cursor:pointer;font:inherit;border:none}.primary-button,.secondary-button,.ghost-button{border-radius:14px;min-height:46px;padding:0 16px;font-weight:700}.primary-button{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9);box-shadow:0 12px 22px #0ea5e933}.secondary-button{color:#0f172a;background:#0f172a0f}.ghost-button{color:#0f172a;background:0 0;border:1px solid #94a3b84d}.text-button{color:#0f766e;background:0 0;padding:0;font-weight:700}.text-button.danger{color:#b91c1c}.table-wrap{border:1px solid #94a3b829;border-radius:18px;overflow:auto}table{border-collapse:collapse;background:#ffffffb3;width:100%;min-width:860px}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #94a3b81f;padding:14px 16px}th{text-transform:uppercase;letter-spacing:.14em;color:#475569;background:#0f172a08;font-size:.84rem}tbody tr:hover{background:#0ea5e908}.pending-row{background:#f871710d}.paid-row{background:#22c55e0a}.row-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pill{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:6px 10px;font-size:.84rem;font-weight:700;display:inline-flex}.pill-neutral,.report-chip{color:#0f172a;background:#0f172a12}.pill-success,.status-green{color:#166534;background:#1665341f}.pill-danger,.status-red{color:#b91c1c;background:#b91c1c1f}.pill-button{color:#0f172a;background:#0f172a0f;border-radius:999px;padding:10px 12px;font-weight:700}.pill-button.active{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9)}.attendance-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.attendance-stat{border-radius:18px;gap:6px;padding:16px;display:grid}.attendance-stat strong{font-size:1.6rem;line-height:1}.attendance-stat span{color:#475569;font-weight:600}.success-bg{background:#16653414}.danger-bg{background:#b91c1c14}.neutral-bg{background:#0f172a0d}.attendance-list{gap:12px;display:grid}.attendance-row{background:#0f172a08;border:1px solid #94a3b81f;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.muted{color:#64748b;margin-top:4px;font-size:.9rem}.status-button{color:#0f172a;background:#0f172a14;border-radius:14px;padding:10px 14px;font-weight:700}.status-button.present.active{color:#166534;background:#16653424}.status-button.absent.active{color:#b91c1c;background:#b91c1c24}.report-grid{gap:14px;display:grid}.report-card{background:#0f172a08;border:1px solid #94a3b81f;border-radius:20px;padding:16px}.report-card span{color:#64748b;font-size:.92rem}.report-card strong{color:#0f172a;margin:10px 0 8px;font-size:1.5rem;display:block}.report-card p{color:#475569;line-height:1.5}.report-chip{border-radius:999px;padding:10px 14px;font-weight:700}.report-message{gap:10px;display:grid}@media (width<=1180px){.workspace{grid-template-columns:1fr}.sidebar{grid-template-columns:repeat(3,minmax(0,1fr));position:static}.topbar{align-items:start}}@media (width<=920px){.hero-card,.dashboard-grid,.form-grid,.report-grid,.attendance-summary,.sidebar,.hero-card{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:start}.topbar-meta{justify-items:start}.panel-header,.attendance-row{flex-direction:column;align-items:start}.summary-bar{grid-template-columns:72px minmax(0,1fr) 40px}}@media (width<=640px){.app-shell{padding:14px}.topbar,.panel,.hero-card{border-radius:18px}.topbar-chip{white-space:normal;width:100%}.primary-button,.secondary-button,.ghost-button,.nav-item{justify-content:center;width:100%}.row-actions{width:100%}.row-actions>*{flex:1 1 0}.attendance-row{width:100%}}
