@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{color:#14213d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--ink:#14213d;--muted:#56647a;--line:#14213d1f;--panel:#ffffffd1;--panel-strong:#fffffff0;--accent:#0f766e;--accent-soft:#d8f3ec;--gold:#f4b942;--danger:#bb3e03;--shadow:0 24px 80px #14213d1f;background:radial-gradient(circle at 0 0,#ffd1664d,#0000 25%),radial-gradient(circle at 100%,#2a9d8f40,#0000 30%),linear-gradient(160deg,#f7f3e9 0%,#edf6f3 48%,#f3f7fb 100%);font-family:Manrope,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#f9fbfd;background:#14213deb;padding:28px}.brand{margin-bottom:24px}.brand-mark{color:#10213d;background:linear-gradient(135deg,#f4b942,#2a9d8f);border-radius:16px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:12px;font-family:Space Grotesk,sans-serif;font-weight:700;display:inline-flex}.brand h1,.screen-center h1,.login-hero h1,.section-title,.panel-title{letter-spacing:-.04em;font-family:Space Grotesk,sans-serif}.brand h1{margin:0;font-size:1.45rem}.brand p,.muted,.eyebrow{color:#f9fbfdb8}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.8rem}.user-card,.nav-link,.panel,.stat-card,.list-row,.request-grid article,.login-card,.screen-center .panel{border:1px solid var(--line);box-shadow:var(--shadow)}.user-card{background:#ffffff14;border-radius:22px;margin:24px 0;padding:18px}.user-role{color:#ffd166;background:#f4b9422e;border-radius:999px;margin-top:10px;padding:6px 10px;font-size:.82rem;display:inline-flex}.sidebar-nav{gap:10px;display:grid}.nav-link{color:#f9fbfde6;background:#ffffff0a;border-radius:18px;padding:14px 16px;transition:transform .2s,background .2s}.nav-link.active{background:linear-gradient(135deg,#f4b94238,#2a9d8f2e);transform:translate(4px)}.sidebar-footer{margin-top:24px}.ghost-button,.primary-button,.outline-button{border:none;border-radius:14px;padding:12px 16px}.primary-button{background:linear-gradient(135deg, var(--accent), #1d8f84);color:#fff;font-weight:700}.outline-button{border:1px solid var(--line);color:var(--ink);background:0 0}.ghost-button{color:#fff;background:#ffffff14;width:100%}.content{padding:28px}.topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.topbar h2{margin:6px 0 0;font-size:clamp(1.9rem,3vw,2.8rem)}.topbar p{color:var(--muted);max-width:62ch;margin:8px 0 0}.panel,.stat-card,.list-row,.request-grid article,.login-card{background:var(--panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:24px}.glass{background:#ffffffb3}.stats-grid,.two-column,.request-grid{gap:18px;display:grid}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-stats{grid-template-columns:repeat(6,minmax(0,1fr))}.two-column{grid-template-columns:1.1fr .9fr;margin-top:20px}.request-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card,.panel,.request-grid article{padding:20px}.stat-card span{color:var(--muted);margin-bottom:24px;display:block}.stat-card strong{font-size:2.4rem;line-height:1}.stat-card .meta{margin-top:10px}.section-title,.panel-title{margin:0 0 6px;font-size:1.2rem}.section-copy{color:var(--muted);margin:0 0 20px}.list{gap:12px;display:grid}.list-row{background:var(--panel-strong);padding:16px 18px}.list-row strong,.request-grid strong{margin-bottom:6px;display:block}.meta{color:var(--muted);font-size:.92rem}.badge{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:700;display:inline-flex}.badge.pending{color:#9a6700;background:#f4b94233}.badge.approved,.badge.present{color:#0f766e;background:#2a9d8f2e}.badge.rejected,.badge.absent{color:var(--danger);background:#bb3e0324}.toolbar{justify-content:space-between;gap:16px;margin-bottom:18px;display:flex}.search-input,.form-grid input,.form-grid select,.form-grid textarea{background:#ffffffe6;border:1px solid #14213d1f;border-radius:14px;width:100%;padding:12px 14px}textarea{resize:vertical}.table-wrap{overflow:auto}.wide-table{min-width:1240px}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #14213d14;padding:14px 12px}th{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.84rem;font-weight:700}.screen-center,.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-page{grid-template-columns:1.1fr .9fr;gap:28px}.login-hero{padding:40px}.login-hero h1{margin:10px 0 14px;font-size:clamp(2.4rem,5vw,4.4rem);line-height:.95}.login-hero p{max-width:56ch;color:var(--muted)}.feature-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:28px;display:grid}.feature-strip article{background:#ffffff9e;border:1px solid #14213d1a;border-radius:22px;padding:18px}.login-card{width:min(100%,460px);padding:28px}.form-grid{gap:14px;display:grid}.form-grid.compact{margin-top:12px}.inline-form{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start}.employee-form,.attendance-filters{grid-template-columns:repeat(4,minmax(0,1fr))}.helper-row{color:var(--muted);justify-content:space-between;gap:12px;font-size:.92rem;display:flex}.error-text{color:var(--danger);font-size:.92rem}.flash-message{border:1px solid var(--line);background:#ffffffe6;border-radius:16px;margin-bottom:18px;padding:14px 16px}.flash-message.success{color:var(--accent);background:#d8f3ecb8;border-color:#0f766e2e}.flash-message.error{color:var(--danger);background:#ffe8e2e6;border-color:#bb3e032e}.action-row{gap:8px;margin-top:12px;display:flex}.checkbox-field{background:#ffffffe6;border:1px solid #14213d1f;border-radius:14px;align-items:center;gap:10px;min-height:48px;padding:10px 12px;display:flex}.checkbox-field input{width:auto}.small-button{border-radius:12px;padding:8px 12px}.danger-outline{color:var(--danger);border-color:#bb3e0340}.section-filter{background:#ffffffe6;border:1px solid #14213d1f;border-radius:14px;width:100%;margin:0 0 12px;padding:10px 12px}.pagination{justify-content:flex-end;align-items:center;gap:10px;margin-top:18px;display:flex}.pagination-label{color:var(--muted);font-size:.92rem}.profile-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.profile-card{border:1px solid var(--line);background:var(--panel-strong);border-radius:18px;padding:18px}.meta-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:.82rem;display:block}.review-box{border-top:1px dashed #14213d1f;margin-top:10px;padding-top:10px}.approval-hint{gap:8px;margin-top:10px;display:grid}.soft-badge{color:var(--ink);background:#14213d14}.analytics-bar{background:#14213d14;border-radius:999px;width:100%;height:10px;margin:10px 0 6px;overflow:hidden}.analytics-fill{background:linear-gradient(135deg,#0f766e,#f4b942);border-radius:999px;height:100%;display:block}.activity-filters{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:18px}.reports-filters{grid-template-columns:repeat(6,minmax(0,1fr))}.reports-stats{grid-template-columns:repeat(4,minmax(0,1fr))}@media print{body{background:#fff}.sidebar,.toolbar .action-row,.sidebar-footer,.sidebar-nav,.user-card{display:none!important}.app-shell{display:block}.content{padding:0}.panel,.stat-card,.list-row,.profile-card{box-shadow:none;background:#fff;border:1px solid #ddd}.report-print-area{border:none;padding:0}}.login-demo{border-top:1px solid #14213d14;margin-top:18px;padding-top:18px}.login-demo code{background:#0f766e14;border-radius:14px;margin-top:6px;padding:12px;display:block}@media (width<=1100px){.app-shell,.login-page,.two-column,.request-grid,.stats-grid{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #ffffff14;border-right:none}}@media (width<=720px){.content,.sidebar,.login-card,.login-hero{padding:20px}.feature-strip{grid-template-columns:1fr}.topbar,.toolbar,.helper-row,.inline-form{flex-direction:column}.inline-form,.employee-form,.attendance-filters,.dashboard-stats,.profile-grid,.activity-filters,.reports-filters,.reports-stats{grid-template-columns:1fr}.pagination{justify-content:flex-start}}
