*{box-sizing:border-box}body{font-family:Arial,sans-serif;margin:0;background:#f5f7fb;color:#111827}.wrap{max-width:1180px;margin:0 auto;padding:24px}.top{background:#111827;color:white;padding:18px 24px}.top h1{margin:0;font-size:24px}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.tabs button,.btn{border:0;background:#e5e7eb;padding:10px 14px;border-radius:10px;cursor:pointer}.tabs .active,.btn.primary{background:#2563eb;color:white}.btn.good{background:#16a34a;color:white}.btn.bad{background:#dc2626;color:white}.btn.warn{background:#f59e0b}.card{background:white;border:1px solid #e5e7eb;border-radius:14px;padding:18px;margin:14px 0;box-shadow:0 1px 2px #0000000a}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.summary-box{border:1px solid #dbe1ea;border-radius:12px;padding:18px;background:#f9fafb}.summary-box p{display:flex;justify-content:space-between;border-bottom:1px solid #e5e7eb;padding:8px 0;margin:0}.summary-box p:last-child{border-bottom:0}label{display:block;font-weight:700;margin-bottom:6px}input,select,textarea{width:100%;padding:10px;border:1px solid #cbd5e1;border-radius:8px}textarea{min-height:72px}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.small{color:#64748b;font-size:13px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid #e5e7eb;padding:10px;text-align:left}th{background:#f8fafc}.status{font-weight:700}.pending{color:#d97706}.approved{color:#16a34a}.rejected,.cancelled{color:#dc2626}.login{max-width:480px;margin:60px auto}.notice{padding:12px;background:#eff6ff;border-radius:10px}


.year-calendar{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:16px}
.calendar-month{border:1px solid #dbe1ea;border-radius:14px;background:#f9fafb;padding:12px}
.calendar-month h3{text-transform:capitalize;margin:0 0 10px}
.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.calendar-day-card{min-height:86px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:6px;font-size:12px}
.calendar-day-card.has-work{border-color:#93c5fd}
.calendar-day-card.has-leave{background:#f0fdf4;border-color:#86efac}
.calendar-day-card.has-cao{background:#f3f4f6;border-color:#d1d5db}
.calendar-day-head{display:flex;justify-content:space-between;gap:4px;border-bottom:1px solid #eef2f7;margin-bottom:4px;padding-bottom:3px}
.calendar-day-head span{color:#64748b}
.calendar-line{margin:3px 0}
.calendar-detail{border-top:1px solid #eef2f7;margin-top:4px;padding-top:4px;color:#334155}
.calendar-label{margin-top:4px;padding:4px;border-radius:7px;background:#dcfce7;color:#166534;font-weight:700}
.calendar-label.roster{background:#dbeafe;color:#1d4ed8}
.calendar-label.vacation{background:#dcfce7;color:#166534}
.calendar-label.time_for_time{background:#ede9fe;color:#6d28d9}
.calendar-label.cao{background:#e5e7eb;color:#374151}
.calendar-label span{font-weight:400}
