@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--red: #b1121a;--blue: #0033a0;--white: #ffffff;--gray-50: #f5f7fb;--gray-100: #e6eaf2;--gray-500: #6b7280;--gray-700: #263042;--shadow: 0 10px 20px rgba(15, 23, 42, .08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--gray-50);color:var(--gray-700)}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--blue);color:var(--white);padding:24px;display:flex;flex-direction:column;gap:24px}.brand{display:flex;align-items:center;gap:12px}.brand-title{margin:0;font-size:16px;font-weight:600}.brand-subtitle{margin:2px 0 0;font-size:12px;opacity:.8}.nav{display:flex;flex-direction:column;gap:8px}.nav-link{padding:10px 12px;border-radius:10px;font-weight:500;background:transparent;transition:background .2s ease}.nav-link:hover{background:#ffffff1f}.nav-link.active{background:var(--red)}.main{padding:28px 36px;display:flex;flex-direction:column;gap:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--white);border-radius:16px;padding:18px 22px;box-shadow:var(--shadow)}.page-title{margin:0;font-size:22px}.page-subtitle{margin:6px 0 0;color:var(--gray-500);font-size:13px}.user-chip{display:flex;align-items:center;gap:8px;background:var(--gray-100);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600}.link-button{border:none;background:transparent;color:var(--red);font-weight:600;cursor:pointer;padding:0 0 0 8px}.dot{width:8px;height:8px;background:var(--red);border-radius:50%}.content{display:flex;flex-direction:column;gap:20px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-overlay .card{margin:auto}.stack{display:flex;flex-direction:column;gap:20px}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{background:var(--white);border-radius:16px;padding:20px;box-shadow:var(--shadow)}.card.soft{background:#fef5f6;box-shadow:none;border:1px solid #f3d7db}.stat-card{border-left:4px solid var(--red)}.stat-label{margin:0;font-size:12px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em}.stat-value{margin:8px 0 4px;font-size:22px}.stat-note{margin:0;font-size:12px;color:var(--gray-500)}.list{margin:12px 0 0;padding-left:18px}.table{display:grid;gap:10px;margin-top:12px}.table.wide .table-row{grid-template-columns:repeat(4,1fr)}.table.wide-5 .table-row{grid-template-columns:repeat(5,1fr)}.table.wide-6 .table-row{grid-template-columns:repeat(6,1fr)}.table-row.email-history-row .email-history-cell{grid-column:1 / -1;padding:12px;background:var(--gray-50);border-radius:8px;font-size:13px}.table-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-100);font-size:14px}.table-row.header{font-weight:600;color:var(--gray-500);border-bottom:1px solid var(--gray-100)}.table-row span{display:inline-flex;align-items:center}.badge{padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.badge.active{background:#0033a01f;color:var(--blue)}.badge.inactive{background:#b1121a1f;color:var(--red)}.badge.present{background:#0033a01f;color:var(--blue)}.badge.absent{background:#b1121a1f;color:var(--red)}.badge.excused,.badge.neutral{background:#2630421f;color:var(--gray-700)}.badge.info{background:#0033a01f;color:var(--blue)}.badge.warning{background:#b1121a1f;color:var(--red)}.badge.success{background:#22c55e1f;color:#15803d}.muted{color:var(--gray-500);margin-top:4px}.actions{display:flex;gap:12px;flex-wrap:wrap}.btn{border:1px solid var(--gray-100);background:var(--white);padding:10px 16px;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px}.btn.primary{background:var(--red);color:var(--white);border-color:var(--red)}.btn.ghost{background:transparent;border-color:transparent;color:var(--red)}.form-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-top:14px}.full-width{grid-column:1 / -1}.card-header{display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap}.filter-row{display:flex;gap:12px;align-items:center}.badge-group{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:900px){.table-row{grid-template-columns:1fr}}label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--gray-500)}input,select{padding:10px 12px;border:1px solid var(--gray-100);border-radius:10px;font-size:14px}input[type=file]{padding:8px;background:var(--white)}.login-shell{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#f8f9ff,#eef2ff)}.login-card{width:min(420px,90vw);background:var(--white);padding:28px;border-radius:18px;box-shadow:var(--shadow)}.login-header{display:flex;gap:16px;align-items:center;margin-bottom:18px}.login-form{display:flex;flex-direction:column;gap:14px}.error{color:var(--red);font-size:13px;margin:0}.logo-image{border-radius:10px;background:var(--white);padding:4px;display:block;object-fit:contain}.logo-fallback{border-radius:10px;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;letter-spacing:.02em}.landing{padding:32px 40px 60px;display:flex;flex-direction:column;gap:28px}.landing-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;background:var(--white);padding:20px 24px;border-radius:20px;box-shadow:var(--shadow)}.landing-header h1{margin:0}.landing-actions{display:flex;gap:12px}.landing-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:20px;align-items:center}.landing-panel{display:grid;gap:12px}.panel-card{background:var(--gray-50);border-radius:14px;padding:16px;border:1px solid var(--gray-100)}.notification-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.warning-box{background:#fff7ed;border:1px solid #fed7aa;padding:12px 16px;border-radius:12px}.landing-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}@media(max-width:900px){.landing-header{grid-template-columns:1fr;text-align:left}.landing-actions{justify-content:flex-start;flex-wrap:wrap}.landing-hero{grid-template-columns:1fr}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap;align-items:center}.nav{flex-direction:row;flex-wrap:wrap}}@media print{.no-print{display:none!important}}
