:root{--navy:#173a63;--navy2:#0e2744;--line:#d7e2ef;--bg:#f3f7fc;--muted:#667792;--green:#0f8a60;--orange:#c77500;--red:#b23b3b}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Noto Sans TC',Arial,sans-serif;background:var(--bg);color:#0b2542}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px}.login-card{width:min(520px,100%);background:white;border-radius:26px;padding:34px;box-shadow:0 24px 70px rgba(20,50,90,.12)}.logo{width:58px;height:58px;border-radius:16px;background:#1f416e;color:#fff;display:grid;place-items:center;font-weight:800;font-size:24px}.login-card h1{font-size:32px;margin:24px 0 6px}.hint{color:var(--muted);margin:0 0 22px}.field{margin:14px 0}.field label{display:block;font-weight:700;margin-bottom:7px}.input,select,textarea{width:100%;border:1px solid #cfdcec;border-radius:12px;padding:12px 14px;font-size:15px;background:#fff}textarea{min-height:82px;resize:vertical}.btn{border:0;border-radius:13px;background:#1f416e;color:white;padding:12px 18px;font-weight:800;cursor:pointer}.btn.secondary{background:#eef3fa;color:#18385f}.btn.danger{background:#fff0f0;color:var(--red);border:1px solid #e8b6b6}.btn.small{padding:7px 10px;border-radius:9px;font-size:13px}.login-btn{width:100%;margin-top:10px}.test-box{margin-top:20px;border:1px dashed #ced9e8;border-radius:16px;background:#f8fbff;padding:14px;color:#667792;line-height:1.7}.topbar{height:88px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 30px}.brand{display:flex;gap:14px;align-items:center}.brand .logo{width:42px;height:42px;border-radius:13px;font-size:18px}.brand h2{margin:0;font-size:20px}.brand p{margin:4px 0 0;color:var(--muted)}.main{padding:28px 30px 42px}.notice{background:#fff8eb;border:1px solid #f3c979;color:#8a5600;border-radius:14px;padding:13px 17px;margin-bottom:18px}.toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px;flex-wrap:wrap}.toolbar-left,.toolbar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.tabs{display:flex;gap:8px;margin:0 0 16px}.tab{background:#eaf1fa;color:#1a3b63}.tab.active{background:#1f416e;color:white}.calendar{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:0 16px 50px rgba(20,50,90,.08)}.weekday,.grid{display:grid;grid-template-columns:repeat(7,1fr)}.weekday div{background:#e8eef7;padding:12px;text-align:center;font-weight:900;color:#0b2542}.day{min-height:96px;border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:9px 8px;display:grid;grid-template-columns:30px 1fr;gap:6px;cursor:pointer;background:#fff}.day:nth-child(7n){border-right:0}.day.empty{background:#f8fbff;cursor:default}.date-num{font-weight:900;color:#111;font-size:15px;line-height:1.7}.day-items{min-width:0;display:flex;flex-direction:column;gap:5px}.event{border:1px solid #bfe7d7;background:#eefaF4;color:#08734f;border-radius:9px;padding:5px 8px;font-size:12px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.event.company{border-color:#f4d9ad;background:#fff5e4;color:#b66a00}.more{border:0;background:#edf3fa;color:#1b426d;border-radius:8px;padding:4px 7px;font-size:12px;text-align:left;font-weight:800;cursor:pointer}.add-hint{color:#a2adbd;font-size:12px;margin-top:3px}.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;padding:24px;z-index:20}.modal{background:#fff;border-radius:22px;width:min(650px,96vw);max-height:90vh;overflow:auto;padding:26px;box-shadow:0 26px 90px rgba(0,0,0,.25)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.modal h3{margin:0;font-size:24px}.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap}.detail p{margin:9px 0;font-weight:700}.detail span{font-weight:500}.upload-box{border:1px solid #d7e2ef;border-radius:16px;padding:16px;margin-top:14px;background:#f8fbff}.employee-panel{background:#fff;border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:0 16px 50px rgba(20,50,90,.08)}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;border-bottom:1px solid #e4ecf5;padding:12px}th{color:#5b6d87;font-size:13px}.status{font-weight:900}.status.on{color:var(--green)}.status.off{color:#8996a8}.img-preview{max-width:100%;border-radius:12px;border:1px solid #d7e2ef;margin-top:12px}.empty-note{color:#94a0b2;font-size:13px}.hidden{display:none!important}@media(max-width:820px){.main{padding:16px}.topbar{padding:0 16px}.calendar{overflow-x:auto}.weekday,.grid{min-width:760px}.row{grid-template-columns:1fr}.day{min-height:90px}.login-card{padding:26px}}
.review{font-weight:900}.review.none{color:#8996a8}.review.pending{color:#c77500}.review.approved{color:#0f8a60}.review.rejected{color:#b23b3b}tfoot th{background:#f8fbff}.employee-panel h3{margin:0}.payroll-total{font-size:18px;font-weight:900}

.review-tabs{display:flex;gap:8px;margin:10px 0 12px}.table-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

.form-thumb{width:112px;height:72px;object-fit:cover;border-radius:10px;border:1px solid #d7e2ef;background:#f8fbff;cursor:pointer;display:block}.form-thumb:hover{box-shadow:0 0 0 3px rgba(31,65,110,.12)}
.section-title-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.compact-actions{justify-content:flex-start;margin-top:12px}
