:root{--bg:#eef7ff;--card:rgba(255,255,255,.94);--text:#071833;--muted:#7a8596;--blue:#0a8dff;--blue2:#e6f4ff;--green:#22c55e;--red:#ff3b45;--orange:#ff941a;--line:#dce7f3;--shadow:0 18px 45px rgba(15,43,80,.10);--radius:28px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:linear-gradient(135deg,#f8fcff,#e6f3ff 60%,#dbeeff);color:var(--text)}button,input,select,textarea{font:inherit}button{border:0;border-radius:18px;padding:14px 18px;background:var(--blue);color:white;font-weight:900;cursor:pointer;box-shadow:0 8px 18px rgba(10,141,255,.22)}button.secondary{background:var(--blue2);color:var(--blue);box-shadow:none}button.danger{background:#ffe8ea;color:var(--red);box-shadow:none}button.good{background:#e9fbf0;color:#0b8b43;box-shadow:none}.shell{display:grid;grid-template-columns:286px 1fr;min-height:100vh}.side{background:linear-gradient(180deg,#08142a,#0b1120);color:white;padding:28px 20px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:14px;align-items:center;margin-bottom:34px}.logo{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,#0a8dff,#1160ff);display:grid;place-items:center;font-weight:1000;color:white}.brand h1{font-size:22px;margin:0}.brand p{margin:4px 0 0;color:#b6c6d8;font-size:13px}.nav{display:grid;gap:10px}.nav button{background:transparent;color:#dce8f7;text-align:left;border:1px solid transparent;display:flex;justify-content:space-between;align-items:center;box-shadow:none;padding:16px 18px;border-radius:18px}.nav button.active,.nav button:hover{background:rgba(255,255,255,.08)}.pill{background:var(--red);color:white;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:900}.main{padding:34px;max-width:1420px;width:100%;margin:0 auto}.top{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:24px}.top h2{margin:0;font-size:38px;letter-spacing:-.8px}.top p{margin:6px 0 0;color:var(--muted);font-size:16px}.card{background:var(--card);border:1px solid rgba(255,255,255,.85);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:20px;backdrop-filter:blur(12px)}.card h3{font-size:22px;margin:0 0 14px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.form{display:grid;gap:16px}.field{display:grid;gap:8px}.field label{font-size:14px;font-weight:900;color:#5a6678}.field input,.field select,.field textarea,.field-input{width:100%;border:1px solid #d9e4ef;border-radius:20px;padding:16px;background:#f8fafc;outline:none}.field textarea,textarea.field-input{min-height:160px;resize:vertical}.list{display:grid;gap:14px}.item{display:grid;grid-template-columns:78px minmax(250px,1fr) auto;gap:20px;align-items:center;border:1px solid var(--line);border-radius:24px;background:white;padding:18px}.thumb{width:78px;height:70px;border-radius:18px;object-fit:cover;background:#eef6ff}.meta h3{margin:0 0 6px;font-size:22px}.meta p{margin:0;color:var(--muted)}.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.badge{font-size:13px;border-radius:999px;padding:6px 11px;background:#eef2f7;color:#344054;font-weight:900}.badge.red,.badge.below,.badge.callout{background:#ffe8ec;color:#d61f3c}.badge.completed,.badge.active{background:#e9fbf0;color:#0b8b43}.badge.pending{background:#fff3e6;color:#d47100}.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.actions button{min-width:120px}.employee-avatar,.icon-avatar{width:70px;height:70px;border-radius:22px;background:#e6f4ff;display:grid;place-items:center;font-size:30px}.empty{text-align:center;color:var(--muted);padding:28px}.muted{color:var(--muted)}.toast{position:fixed;bottom:22px;right:22px;background:#101828;color:white;padding:15px 18px;border-radius:18px;box-shadow:var(--shadow);z-index:90}.login{min-height:100vh;display:grid;place-items:center;padding:24px}.login .card{width:min(490px,100%)}.hero{text-align:center}.hero .logo{margin:0 auto 14px}.emp-tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}.emp-tabs button{background:transparent;color:#0b65c9;box-shadow:none;border:1px solid transparent}.emp-tabs button.active{background:var(--blue);color:white}.mini-dashboard{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}.dash-box,.staff-box{background:white;border:1px solid var(--line);border-radius:22px;padding:18px;text-align:center;cursor:pointer}.dash-box small,.staff-box small{display:block;color:var(--muted);font-weight:900}.dash-box strong,.staff-box strong{display:block;font-size:34px;margin-top:8px}.section-row-title{display:flex;justify-content:space-between;align-items:center;margin:18px 0 12px}.section-row-title h3{margin:0}.quick{background:#e6f4ff;color:#0a8dff;display:flex;align-items:center;justify-content:space-between;border-radius:20px;padding:16px 18px;font-weight:900;cursor:pointer}.hr-profile-hero{display:flex;align-items:center;gap:22px}.profile-avatar.big{width:96px;height:96px;border-radius:26px;background:#e6f4ff;display:grid;place-items:center;font-size:44px}.row{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line);padding:14px 0}.row span{color:var(--muted);font-weight:800}.modal{position:fixed;inset:0;background:rgba(3,12,28,.60);z-index:20;display:grid;place-items:center;padding:18px}.modal-card{background:var(--card);border-radius:30px;box-shadow:0 25px 80px rgba(0,0,0,.25);padding:26px;width:min(1050px,97vw);max-height:92vh;overflow:auto}.floating-close{position:sticky;top:12px;float:right;z-index:30}.lightbox{position:fixed;inset:0;z-index:99999;background:rgba(2,6,23,.86);display:flex;align-items:center;justify-content:center;padding:24px}.lb-main{max-width:92vw;max-height:82vh;object-fit:contain;border-radius:22px}.lb-close{position:fixed;top:18px;right:22px}.lb-title{position:fixed;top:22px;left:50%;transform:translateX(-50%);color:white;font-weight:900}.lb-arrow{position:fixed;top:50%;transform:translateY(-50%);width:58px;height:58px;border-radius:50%;font-size:38px}.lb-left{left:28px}.lb-right{right:28px}.lb-controls{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);display:flex;gap:14px;align-items:center;background:rgba(15,23,42,.72);padding:12px 16px;border-radius:999px}.lb-counter{color:white;font-weight:900}.print-wrap{width:100%;overflow:auto;padding:18px 0}.schedule-sheet{background:#fff;color:#111;border:2px solid #111;box-shadow:0 18px 55px rgba(15,43,80,.18);padding:.28in;font-family:Arial,Helvetica,sans-serif;margin:0 auto}.schedule-sheet.legal{width:14in;min-height:8.5in}.sheet-top{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:end;border-bottom:2px solid #111;padding-bottom:5px;font-size:12px}.sheet-shift{text-align:center;font-weight:900;border:1px solid #111;padding:4px;text-transform:uppercase}.sheet-meta{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;font-size:12px;padding:8px 0}.schedule-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:9px}.schedule-table th,.schedule-table td{border:1px solid #222;height:16px;padding:0;vertical-align:middle;overflow:hidden}.schedule-table th{background:#f5f5f5;text-align:center;font-weight:900}.schedule-table input,.schedule-table select{width:100%;height:15px;border:0!important;border-radius:0!important;background:transparent;padding:0 3px;font-size:9px;font-weight:700;outline:none}.schedule-table th:nth-child(1){width:30px}.schedule-table th:nth-child(2){width:210px}.schedule-table th:nth-child(3){width:150px}.schedule-table th:nth-child(4){width:65px}.schedule-table th:nth-child(5){width:130px}.schedule-table th:nth-child(6){width:70px}.schedule-table th:nth-child(7){width:70px}.schedule-table th:nth-child(8){width:50px}.schedule-table th:nth-child(9){width:50px}.lead-line td{background:#005ba0!important;color:#fff!important;font-weight:900}.lead-line input,.lead-line select{color:#fff!important}.relief-line .employee-cell,.relief-line .employee-cell select{background:#fff200!important;color:#111!important}.overtime-line .employee-cell,.overtime-line .employee-cell select{background:#d92d20!important;color:#fff!important}.shift-break td{height:19px!important;background:#111827!important;color:#fff!important;text-align:center!important;font-weight:1000!important}.row-num{text-align:center;background:#f8fafc;font-weight:900}.sheet-legend{font-size:10px;margin-top:8px;color:#333}.history-table{width:100%;border-collapse:collapse;background:white;border-radius:18px;overflow:hidden}.history-table th,.history-table td{border-bottom:1px solid var(--line);padding:14px;text-align:left}.history-table th{background:#f8fafc;color:#5a6678}.filter-bar{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;gap:14px;align-items:end}.action-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.action-card{background:white;border:1px solid var(--line);border-radius:24px;padding:24px;cursor:pointer;box-shadow:var(--shadow)}.action-card h3{margin:0 0 8px}.hidden{display:none!important}@media(max-width:1200px){.mini-dashboard{grid-template-columns:repeat(3,1fr)}.filter-bar{grid-template-columns:1fr 1fr}.action-list{grid-template-columns:1fr 1fr}}@media(max-width:920px){.shell{grid-template-columns:1fr}.side{position:relative;height:auto}.main{padding:20px}.grid,.grid3,.grid4{grid-template-columns:1fr}.top{align-items:flex-start;flex-direction:column}.mini-dashboard{grid-template-columns:1fr 1fr}.item{grid-template-columns:1fr}.actions{justify-content:flex-start}.schedule-sheet.legal{width:1400px}}@media(max-width:560px){.mini-dashboard,.action-list,.filter-bar{grid-template-columns:1fr}.emp-tabs{display:grid;grid-template-columns:1fr}.emp-tabs button{width:100%}}@media print{body{background:#fff}.side,.top,.emp-tabs,.card:not(:has(#schedulePreview)),button,.toast{display:none!important}.main{padding:0!important;margin:0!important;max-width:none!important}.print-wrap{padding:0!important;overflow:visible!important}.schedule-sheet.legal{width:14in;min-height:8.5in;box-shadow:none;margin:0;border:1px solid #000}@page{size:legal landscape;margin:.15in}}

.check-grid{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px}.check-line{font-weight:800;color:#344054}.check-line input{width:auto;margin-right:8px}.history-table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}.history-table th,.history-table td{border-bottom:1px solid var(--line);padding:13px 12px;text-align:left}.history-table th{color:#475467;font-weight:1000;background:#f8fafc}.filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;align-items:end}.section-row-title{display:flex;justify-content:space-between;gap:16px;align-items:center}.badge.active{background:#e9fbf0;color:#0b8b43}.mini-dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.dash-box{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;text-align:center;cursor:pointer}.dash-box strong{font-size:34px;display:block;margin-top:8px}.dash-box small{font-weight:900;color:#667085}@media(max-width:760px){.check-grid{grid-template-columns:1fr}.section-row-title{display:block}.history-table{font-size:13px}}
