:root{--bg:#eef2f0;--surface:#fff;--soft:#f7faf8;--ink:#1c2522;--muted:#64716c;--line:#d8e0dc;--primary:#176b52;--dark:#0f4d3d;--blue:#2563a8;--gold:#9a6a12;--red:#b42318;--shadow:0 18px 40px rgba(21,32,28,.09);--radius:8px;--font:"Segoe UI",Arial,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font:15px var(--font)}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{background:#172521;color:#f3fbf7;padding:22px 16px}.brand{display:flex;align-items:center;gap:12px;padding:0 8px 22px}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:8px;background:#f2c94c;color:#172521;font-weight:800}.brand strong,.brand span{display:block}.brand span{color:#aab8b2;font-size:12px;margin-top:3px}.nav-list{display:grid;gap:6px}.nav-item{width:100%;min-height:42px;border:0;border-radius:8px;background:transparent;color:#d8e5df;padding:0 12px;text-align:left}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.1);color:#fff}.workspace{min-width:0;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.eyebrow{margin:0 0 3px;color:var(--muted);font-size:13px}h1,h2{margin:0;letter-spacing:0}h1{font-size:30px;line-height:1.15}h2{font-size:18px}.top-actions,.inline-actions,.dialog-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.button,.icon-button{border:1px solid transparent;border-radius:8px;min-height:38px;padding:0 14px;font-weight:700}.button.primary{background:var(--primary);color:#fff}.button.primary:hover{background:var(--dark)}.button.secondary{background:#fff;color:var(--primary);border-color:var(--line)}.button.quiet{background:transparent;color:var(--muted);border-color:var(--line)}.button.danger{background:var(--red);color:#fff}.button.full{width:100%}.icon-button{width:38px;padding:0;background:var(--soft);color:var(--ink);font-size:18px}.view{display:none}.view.active{display:block}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}.metric,.panel,.report-tile{background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.metric{min-height:116px;padding:18px;border-left:5px solid var(--primary)}.metric.accent-blue{border-left-color:var(--blue)}.metric.accent-gold{border-left-color:var(--gold)}.metric span,.report-tile span{display:block;color:var(--muted);font-size:13px;margin-bottom:12px}.metric strong{display:block;font-size:28px;line-height:1.1}.split-layout,.form-layout{display:grid;grid-template-columns:minmax(300px,.95fr) minmax(420px,1.4fr);gap:16px}.panel{min-width:0;padding:16px}.compact-panel{max-width:760px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.action-button{display:flex;align-items:center;gap:12px;min-height:82px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--soft);color:var(--ink);text-align:left}.action-button b{display:grid;place-items:center;min-width:42px;height:38px;border-radius:8px;background:#e3f2ed;color:var(--primary)}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px}table{width:100%;border-collapse:collapse;min-width:680px}th,td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{background:#2f6f62;color:#fff;font-size:13px;white-space:nowrap}tbody tr:nth-child(even){background:#f2f8f6}tbody tr:last-child td{border-bottom:0}.number{text-align:right;font-variant-numeric:tabular-nums}.actions-col{width:138px;text-align:right}.row-actions{display:flex;justify-content:flex-end;gap:8px}.small-action{min-height:30px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:0 10px;font-weight:700}.small-action.danger{color:var(--red);background:#ffe8e5;border-color:#ffc7c1}.empty-row{color:var(--muted);text-align:center}.status{display:inline-flex;align-items:center;min-height:26px;border-radius:999px;padding:0 10px;background:#e3f2ed;color:var(--dark);font-weight:700;font-size:12px}.status.inactive{background:#eef0f2;color:#5f666b}.search-input,.report-select,input,select,textarea{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.search-input,.report-select{min-height:38px;padding:0 11px}.stack-form{display:grid;gap:13px}label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:700}input,select,textarea{min-height:40px;padding:8px 10px;color:var(--ink);font-weight:500}textarea{resize:vertical}.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.report-tile{min-height:104px;padding:16px;box-shadow:none}.report-tile strong{display:block;font-size:22px}dialog{width:min(620px,calc(100vw - 28px));border:0;border-radius:8px;padding:0;box-shadow:0 28px 80px rgba(0,0,0,.28)}dialog::backdrop{background:rgba(17,24,22,.45)}.dialog-form{display:grid;gap:14px;padding:18px}.dialog-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.danger-copy{margin:0;padding:12px;border-radius:8px;background:#ffe8e5;color:#7a1b14;font-weight:700}.toast{position:fixed;right:18px;bottom:18px;max-width:min(360px,calc(100vw - 36px));min-height:42px;display:none;align-items:center;padding:10px 14px;border-radius:8px;background:#172521;color:#fff;box-shadow:var(--shadow);z-index:10}.toast.show{display:flex}@media(max-width:1080px){.app-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:8;padding:12px}.brand{padding:0 4px 10px}.nav-list{grid-template-columns:repeat(8,minmax(0,1fr));overflow-x:auto}.nav-item{text-align:center;min-width:112px}.metric-grid,.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-layout,.form-layout{grid-template-columns:1fr}}@media(max-width:720px){.workspace{padding:16px}.topbar,.section-heading{align-items:stretch;flex-direction:column}.top-actions,.inline-actions{width:100%}.top-actions .button,.inline-actions .button,.search-input,.report-select{flex:1 1 140px}.metric-grid,.report-grid,.action-grid,.two-col{grid-template-columns:1fr}h1{font-size:24px}}
.hidden{display:none!important}.form-actions{display:grid;gap:10px}

.location-report-panel{margin-top:16px}.location-report-table{margin-top:14px}

.db-status{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;padding:0 10px;background:#eef0f2;color:#5f666b;font-size:12px;font-weight:800;white-space:nowrap}.db-status.connected{background:#e3f2ed;color:#0f4d3d}.db-status.pending{background:#fff4d8;color:#9a6a12}

.attendance-report-detail{margin-top:16px}.report-filters{justify-content:flex-end}.wide-table{min-width:1040px}

.report-filters .button{flex:0 0 auto}

.login-screen{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(135deg,#e9f3ef 0%,#f7faf8 52%,#eef2f0 100%)}
.login-panel{width:min(430px,calc(100vw - 36px));display:grid;gap:16px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:24px}.login-brand{padding:0 0 6px;color:var(--ink)}.login-brand span{color:var(--muted)}.login-panel h1{font-size:26px}.login-message{min-height:20px;margin:0;color:var(--muted);font-weight:700}.login-message.error{color:var(--red)}.login-message.success{color:var(--primary)}.user-chip{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;padding:0 10px;background:#fff;border:1px solid var(--line);color:var(--muted);font-size:12px;font-weight:800;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:720px){.user-chip{max-width:none;width:100%;justify-content:center}}
