@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Fraunces:opsz,wght@9..144,600;9..144,800&display=swap";:root{color-scheme:light;--bg: #f7f2ea;--panel: #ffffff;--ink: #1e1a17;--muted: #635b55;--accent: #c85c2b;--accent-2: #2f4858;--line: #e5d9ce;--shadow: 0 18px 60px rgba(30, 26, 23, .08);--radius: 18px;font-family:Space Grotesk,sans-serif;background-color:var(--bg);color:var(--ink)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,#f9f0dd,transparent 55%),radial-gradient(circle at 70% 10%,#fbe5d2,transparent 50%),linear-gradient(120deg,#f9f4ee,#f6efe6 40%,#f4ece2)}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{padding:28px 24px;background:#241b16;color:#fff3e8;display:flex;flex-direction:column;gap:22px}.brand-lockup{display:block;margin-bottom:12px}.brand-lockup-large{margin-bottom:18px}.brand-image{display:block;width:100%;max-width:220px;border-radius:24px;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 28px #0000001f;background:#ffe77a}.role-pill{display:inline-flex;padding:6px 12px;border-radius:999px;background:#ffffff1f;font-size:12px;text-transform:uppercase;letter-spacing:1px}.sidebar-user-card{display:grid;gap:6px;padding:14px 16px;border-radius:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.08)}.sidebar-user-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#fff3e8a6}.sidebar-user-card strong{font-size:16px;line-height:1.3}.sidebar-user-status{font-size:13px;color:#fff3e8d1}.sidebar-footer{margin-top:auto;display:grid;gap:14px}.nav{display:flex;flex-direction:column;gap:12px}.nav a{padding:10px 14px;border-radius:12px;color:#fff3e8;transition:all .2s ease}.nav-link-inner{display:inline-flex;align-items:center;gap:10px}.nav-icon{flex-shrink:0;font-size:18px}.nav a.active,.nav a:hover{background:#ffffff24}.sidebar-logout{display:inline-flex;align-items:center;justify-content:center;gap:10px;align-self:stretch}.sidebar-logout-icon{font-size:18px}.main{padding:32px 40px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-family:Fraunces,serif;font-size:28px;margin:0}.panel{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;border:1px solid var(--line)}.panel+.panel{margin-top:20px}.panel-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.list-search{margin-bottom:16px}.form-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}input,select,textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:#fffaf4;font-family:inherit}.search-select{position:relative}.search-select input{padding-right:42px}.search-select-disabled{opacity:.7}.search-select-toggle{position:absolute;top:50%;right:8px;transform:translateY(-50%);border:none;background:transparent;padding:6px 8px;border-radius:8px;color:var(--muted);font-size:14px}.search-select-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;display:grid;gap:4px;max-height:240px;overflow-y:auto;padding:8px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}.search-select-option{width:100%;text-align:left;border:1px solid transparent;background:transparent;color:var(--ink);border-radius:10px;padding:8px 10px;font-weight:500}.search-select-option:hover,.search-select-option-active{background:#fff3e8;border-color:#efdac7}.search-select-empty{padding:8px 10px;color:var(--muted);font-size:14px}input[type=checkbox]{width:auto}.input-row{display:flex;gap:10px;align-items:center}.input-row input{flex:1}.toggle-button{padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:#f2e4d4;color:#6d3a1f;font-size:12px;font-weight:600}textarea{min-height:90px}button{border:none;border-radius:999px;padding:10px 18px;font-family:inherit;font-weight:600;cursor:pointer}button.primary{background:var(--accent);color:#fff}button.ghost,.link-button.ghost{background:transparent;border:1px solid var(--line);color:var(--accent-2)}button.danger{background:#7b1d1d;color:#fff}.table{width:100%;border-collapse:collapse;font-size:14px}.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left}.table-row-link{cursor:pointer}.table-row-link:hover td{background:#fff8ef}.tag{display:inline-flex;padding:4px 10px;border-radius:999px;background:#f2e4d4;color:#6d3a1f;font-size:12px;font-weight:600}.notice{padding:12px 16px;border-radius:12px;background:#fff3e8;color:#8a3b17;font-size:14px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(420px,100%);background:var(--panel);padding:32px;border-radius:24px;box-shadow:var(--shadow);border:1px solid var(--line)}.login-card h1{font-family:Fraunces,serif;margin:0 0 12px}.brand-lockup-large .brand-image{max-width:280px;margin:0 auto}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat{padding:18px;border-radius:16px;background:#fff8ef;border:1px dashed #e7d2bf}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#18120e8c;display:grid;place-items:center;padding:24px;z-index:20}.modal{width:min(640px,100%);background:var(--panel);border-radius:20px;padding:24px;border:1px solid var(--line);box-shadow:var(--shadow)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-header h2{margin:0;font-family:Fraunces,serif}.modal-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center;margin-top:8px}.days-of-week{display:flex;flex-direction:column;gap:10px;align-items:flex-start}.day-option{display:inline-flex;align-items:center;gap:8px;margin-bottom:0;font-size:14px;color:var(--ink);cursor:pointer}.day-option input{margin:0}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-size:14px;color:var(--muted)}.pagination-controls{display:flex;align-items:center;gap:10px}.pagination select{width:auto}.table-scroll{overflow-x:auto}.attendance-table th,.attendance-table td{text-align:center;white-space:nowrap}.attendance-table th:first-child,.attendance-table td:first-child,.attendance-table th:nth-child(2),.attendance-table td:nth-child(2){text-align:left}.muted-cell{background:#f8f0e6}.muted-text{color:var(--muted)}.page-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px}.group-overview-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(260px,1fr);gap:20px;margin-bottom:20px}.group-summary-card h2,.section-header h2{margin:8px 0;font-family:Fraunces,serif}.group-summary-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.group-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:18px}.group-meta-card{display:flex;align-items:stretch}.info-list{display:grid;gap:14px;width:100%}.info-list div{display:grid;gap:4px;padding-bottom:10px;border-bottom:1px solid var(--line)}.info-list div:last-child{border-bottom:none;padding-bottom:0}.info-list span{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.info-list strong{font-size:18px}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.section-header p{margin:0}.link-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.attendance-filters{display:flex;gap:12px;align-items:flex-end}.attendance-filters>div{min-width:140px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.dashboard-shell{display:grid;gap:20px}.dashboard-hero{display:grid;grid-template-columns:minmax(260px,1fr) auto;gap:20px;align-items:start;background:radial-gradient(circle at top right,rgba(200,92,43,.12),transparent 38%),linear-gradient(135deg,#fffaf4,#fff3e3)}.dashboard-hero-copy h2{margin:10px 0 12px;font-family:Fraunces,serif;font-size:34px}.dashboard-hero-copy .muted{color:var(--muted);max-width:58ch}.dashboard-controls{display:grid;grid-template-columns:repeat(2,minmax(150px,1fr));gap:12px;min-width:320px}.dashboard-hero-stats{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.dashboard-spotlight{background:#ffffffbf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dashboard-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:20px}.dashboard-kpi-card{display:grid;gap:8px}.dashboard-kpi-card span,.dashboard-year-totals span,.dashboard-group-cell span,.dashboard-payment-item span,.trend-card-meta span{color:var(--muted);font-size:13px}.dashboard-kpi-card strong{font-size:34px;line-height:1}.dashboard-main-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,1fr);gap:20px}.dashboard-trend-card{grid-column:1 / -1}.dashboard-groups-card{grid-column:1}.dashboard-side-card{grid-column:2}.dashboard-year-totals{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:18px;width:100%;max-width:720px}.dashboard-year-totals strong{display:block;margin-top:4px;font-size:18px;line-height:1.2;overflow-wrap:anywhere}.dashboard-trend-header{align-items:start;flex-wrap:wrap}.dashboard-trend-header>div:first-child{min-width:min(360px,100%)}.trend-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:8px;align-items:end;overflow:hidden;padding-bottom:4px}.trend-card{min-width:0;border:1px solid var(--line);border-radius:16px;padding:10px;background:#fffaf4;display:grid;gap:8px}.trend-card-active{border-color:#c85c2b73;box-shadow:0 10px 24px #c85c2b24}.trend-card-head{display:grid;gap:4px}.trend-card-head strong{font-size:16px}.trend-card-head span{font-size:12px;line-height:1.3;overflow-wrap:anywhere}.trend-stack{min-height:112px;display:flex;align-items:end;gap:4px}.trend-bar{flex:1;min-height:8px;border-radius:999px 999px 10px 10px}.trend-bar-collected{background:linear-gradient(180deg,#2f4858,#43697d)}.trend-bar-billed{background:linear-gradient(180deg,#c85c2b,#df865f)}.trend-bar-salary{background:linear-gradient(180deg,#d6b16d,#edd9ad)}.trend-card-meta{display:grid;gap:3px}.trend-card-meta span{font-size:11px;line-height:1.35;overflow-wrap:anywhere}.dashboard-group-cell{display:grid;gap:2px}.dashboard-payment-list{display:grid;gap:10px}.dashboard-payment-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fff8ef}.dashboard-payment-item>div{display:grid;gap:4px}.hero-card{grid-column:1 / -1;display:grid;grid-template-columns:minmax(240px,1fr) 1.3fr;gap:24px}.hero-text h2{font-family:Fraunces,serif;margin:12px 0;font-size:28px}.hero-text .muted{color:var(--muted)}.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.stat-card{background:#fff8ef;border-radius:16px;padding:16px;border:1px solid #edd8c4;display:grid;gap:6px}.stat-card strong{font-size:24px}.stat-card small{color:var(--muted)}.chart-card h3{margin:0}.chart-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:16px}.donut{width:180px;height:180px;border-radius:50%;display:grid;place-items:center;margin:0 auto 16px;position:relative}.donut:after{content:"";width:120px;height:120px;background:var(--panel);border-radius:50%;position:absolute}.donut-center{position:relative;z-index:1;text-align:center}.donut-center strong{display:block;font-size:28px}.donut-center span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px}.legend{display:grid;gap:8px;font-size:14px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.legend-dot.accent{background:var(--accent)}.legend-dot.neutral{background:#f2e4d4}.bar-list{display:grid;gap:10px}.bar-row{display:grid;grid-template-columns:44px 1fr 40px;align-items:center;gap:10px;font-size:14px}.bar-track{background:#f2e4d4;border-radius:999px;height:8px;overflow:hidden}.bar-fill{background:var(--accent-2);height:100%;border-radius:999px}.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.method-card{border:1px dashed #e4d2c0;background:#fff8ef;border-radius:16px;padding:16px;display:grid;gap:6px}@media (max-width: 1100px){.dashboard-main-grid{grid-template-columns:1fr}.dashboard-trend-card,.dashboard-groups-card,.dashboard-side-card{grid-column:auto}.dashboard-year-totals{grid-template-columns:1fr;max-width:none}}.method-card strong{font-size:22px}@media (max-width: 980px){.group-overview-grid{grid-template-columns:1fr}.section-header{flex-direction:column}.attendance-filters{width:100%;flex-wrap:wrap}.hero-card{grid-template-columns:1fr}}.debt-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#f2e4d4;color:#6d3a1f;font-size:12px;font-weight:600}.chip:disabled{opacity:.45;cursor:not-allowed}.day-button{border:1px solid var(--line);background:#fff8ef;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer}.attendance-modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin:16px 0}.chip-active{background:var(--accent);color:#fff}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap}.main{padding:24px}}
