@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=Space+Grotesk:wght@400;500;600;700&display=swap";.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;background:#0f1218b3;color:#f4f2ff;border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-brand{font-weight:600;letter-spacing:.04em;color:inherit;text-decoration:none}.topbar-actions{display:flex;gap:12px;align-items:center}.topbar-actions button{background:transparent;color:#f4f2ff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:6px 14px}.page{flex:1;padding:32px 32px 60px;display:flex;flex-direction:column;gap:28px}.login-page{align-items:center;justify-content:center}.login-card{max-width:520px;width:100%;padding:42px;background:#fffffff5;border-radius:24px;box-shadow:0 25px 60px #10122233;animation:floatIn .8s ease}.login-brand{display:flex;justify-content:space-between;align-items:baseline;font-size:18px;text-transform:uppercase;letter-spacing:.1em;color:#3c2b4a;margin-bottom:16px}.login-card h1{font-family:"DM Serif Display",serif;margin:0 0 12px;font-size:34px;color:#1d1824}.muted{color:#22232b99;font-size:14px}.form-grid{margin-top:24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid input,.entry-form input,.selector-row select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.12);font-size:14px;background:#fff}.form-grid label,.entry-form label{display:flex;flex-direction:column;gap:8px;font-weight:500;color:#2b2433}.primary-btn{border:none;background:#2f2057;color:#fff;padding:12px 18px;border-radius:999px;font-weight:600;cursor:pointer;box-shadow:0 10px 24px #2f20574d}.form-grid .primary-btn{grid-column:span 2;width:100%}.form-grid .error{grid-column:span 2;min-height:18px}.secondary-btn{border:1px solid rgba(47,32,87,.3);background:#fff;color:#2f2057;padding:8px 14px;border-radius:999px;font-weight:600;cursor:pointer}.app-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.app-header h2{margin:0;font-size:26px;color:#f5f2ff}.nav-links{display:flex;gap:14px}.nav-links a{color:#f5f2ff;text-decoration:none;font-weight:500;padding:6px 12px;border-radius:999px;background:#ffffff1f}.main-grid{display:grid;grid-template-rows:auto 1fr;gap:24px;flex:1}.calendar-panel{align-self:start}.calendar-panel,.entry-panel{background:#fffffff2;border-radius:24px;padding:22px;box-shadow:0 20px 50px #0f121e26}.calendar-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}.selector-row{display:flex;gap:10px}.year-select{min-width:110px}.month-select{min-width:72px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.calendar-footer{grid-column:1 / -1;display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:10px}.footer-date{grid-column:1 / -1;font-size:12px;font-weight:600;color:#2f2057;text-align:left}.footer-cell{border:1px solid rgba(0,0,0,.06);background:#fff;border-radius:12px;min-height:0;padding:8px 10px;display:grid;align-content:start;gap:6px}.footer-name{font-weight:600;font-size:12px;color:#2f2057;text-align:left}.footer-list{font-size:11px;color:#2f2057;display:grid;gap:2px}.footer-item{display:grid;grid-template-columns:auto 1fr;gap:6px;align-items:center;line-height:1.2}.footer-reason{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#2f2057b3}.footer-empty{display:flex;align-items:center;justify-content:center;font-size:12px;color:#2f205780}.weekday{text-align:center;font-weight:600;color:#685a80;font-size:12px;display:flex;align-items:center;justify-content:center}.day-cell{border:1px solid rgba(0,0,0,.06);background:#fff;border-radius:12px;padding:5px 0;min-height:150px;text-align:center;position:relative;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px}.day-cell.selected{border:2px solid #2f2057;background:#2f205714}.day-cell.empty{border:none;background:transparent;cursor:default}.date-number{font-weight:600}.dot-list{display:grid;gap:4px;font-size:11px;line-height:1.4;color:#2f2057}.dot-row{display:flex;align-items:center;gap:6px;justify-content:center}.dot{width:6px;height:6px;background:#2f2057;border-radius:999px;flex:0 0 auto}.entry-panel{display:flex;flex-direction:column;gap:18px}.entry-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.entry-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:end}.entry-form .reason{grid-column:span 2}.entry-form .primary-btn{align-self:end;height:44px}.entry-list{background:#f7f4ff;padding:16px;border-radius:18px;flex:1;overflow:auto}.entry-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.entry-list ul{list-style:none;padding:0;margin:0;display:grid;gap:12px}.entry-list li{background:#fff;padding:12px 16px;border-radius:14px;display:flex;justify-content:space-between;align-items:center;gap:16px}.entry-list li strong{display:block}.entry-meta{display:grid;gap:6px;justify-items:end}.entry-meta button{border:none;background:transparent;color:#a73333;cursor:pointer}.error{color:#a73333;font-size:13px;grid-column:span 4}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.stat-section-title{grid-column:1 / -1;font-size:13px;font-weight:600;color:#22232bb3;text-transform:uppercase;letter-spacing:.08em}.stats-filter{grid-column:1 / -1;display:flex;justify-content:flex-end}.stats-filter label{display:flex;align-items:center;gap:8px;font-size:12px;color:#22232bb3}.stats-filter select{padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:#fff;font-size:12px}.stat-card{background:#fffffff5;padding:24px;border-radius:20px;box-shadow:0 20px 50px #0f121e1f}.stat-card.wide{grid-column:span 2}.stat-number{font-size:38px;font-weight:700;margin:6px 0}.stat-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:end}.stat-sub{display:flex;gap:12px;margin-top:6px;flex-wrap:wrap}.stat-sub span+span:before{content:"·";margin:0 6px 0 2px;color:#22232b80}.summary-list{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:10px}.summary-list li{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:10px 12px;background:#f7f4ff;border-radius:12px}.rank-list{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:10px}.rank-list li{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;padding:10px 12px;background:#f7f4ff;border-radius:12px}.rank-badge{width:26px;height:26px;border-radius:999px;background:#2f2057;color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px}.rank-name{font-weight:600}.bar-chart{display:grid;gap:10px;margin-top:16px}.bar-item{display:grid;grid-template-columns:52px 1fr 50px;align-items:center;gap:10px;font-size:12px}.bar-label{color:#22232bb3}.bar-track{height:10px;background:#2f20571f;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:#2f2057;border-radius:999px}.bar-value{text-align:right;font-weight:600}.detail-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.detail-list li{display:grid;grid-template-columns:90px 120px 1fr auto;gap:12px;align-items:center;padding:10px 12px;background:#f7f4ff;border-radius:12px;font-size:12px}.detail-list.admin li{grid-template-columns:90px 90px 120px 1fr auto}.detail-user{font-weight:600}.detail-reason{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-hours{font-weight:600}@keyframes floatIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 900px){.main-grid{grid-template-rows:auto}.entry-form{grid-template-columns:1fr 1fr}.entry-form .reason,.entry-form .primary-btn,.error{grid-column:span 2}.stats-grid{grid-template-columns:1fr}.stat-card.wide{grid-column:span 1}.detail-list li,.detail-list.admin li{grid-template-columns:1fr;align-items:start}}@media (max-width: 600px){.page{padding:24px 16px 40px}.login-card{padding:28px}.app-header{flex-direction:column;align-items:flex-start}.nav-links{flex-wrap:wrap}.entry-form{grid-template-columns:1fr}.entry-form .reason,.entry-form .primary-btn,.error{grid-column:span 1}.calendar-header{flex-direction:column;align-items:flex-start}}.form-grid{grid-template-columns:1fr}.form-grid .primary-btn,.form-grid .error{grid-column:span 1}:root{font-family:Space Grotesk,system-ui,sans-serif;color:#1f1c2b;background-color:#101018;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:radial-gradient(circle at top,rgba(136,113,208,.25),transparent 50%),radial-gradient(circle at 20% 20%,rgba(221,125,98,.2),transparent 45%),#0f1118}#root{min-height:100vh}a{color:inherit}button,input,select{font-family:inherit}
