:root{color:#1b1c1c;background:#fbf9f8;font-family:Inter,Segoe UI,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.sidebar{background:#0b3060;color:#fff;display:flex;flex-direction:column;gap:20px;padding:12px 14px 24px}.brand{padding:0 2px 4px}.sidebar-brand-image{border:1px solid rgba(153,204,255,.55);border-radius:10px;display:block;height:auto;width:100%}.nav-list{display:grid;gap:4px}.nav-item{align-items:center;background:transparent;border:0;border-left:3px solid transparent;border-radius:4px;color:#eaf3ff;display:flex;gap:10px;min-height:42px;padding:10px 12px;text-align:left}.nav-item.active,.nav-item:hover{background:#99ccff24;border-left-color:#9cf}.main-content{padding:32px}.mobile-bottom-nav{display:none}.topbar,.section-header{align-items:center;display:flex;justify-content:space-between;gap:16px}.topbar-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.dev-user-pill{align-items:center;border:1px solid #dcd9d9;border-radius:999px;display:flex;gap:10px;padding:6px 8px 6px 12px}.dev-user-pill span{color:#001b3f;font-size:13px;font-weight:800}.dev-user-pill button{background:#fff;border:0;color:#0b3060;font-size:12px;font-weight:800;padding:4px 6px}.login-screen{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:32px}.login-panel{background:#fff;border:1px solid #dcd9d9;border-radius:8px;display:grid;gap:18px;max-width:760px;padding:28px;width:100%}.login-copy{color:#43474f;margin:0}.login-form{display:grid;gap:14px}.inline-form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.login-form label{color:#2f3848;display:grid;font-size:14px;font-weight:800;gap:8px}.login-form input{border:1px solid #c8d4e3;border-radius:6px;color:#152036;font:inherit;min-height:46px;padding:0 14px}.profile-password-form{border-top:1px solid #e1e8f2;display:grid;gap:12px;margin-top:18px;padding-top:18px}.profile-password-form h3{font-size:16px;margin:0}.profile-password-form label{color:#2f3848;display:grid;font-size:13px;font-weight:800;gap:6px}.profile-password-form input{border:1px solid #c8d4e3;border-radius:6px;font:inherit;min-height:40px;padding:0 12px}.registration-request-grid{display:grid;gap:12px}.app-user-card>strong,.registration-request-card>strong{color:#132238;font-size:16px}.registration-group-card{border-color:var(--border)}.registration-group-card:hover,.permission-card:hover,.export-check-row:hover{background:#fbfdff;border-color:#b7c7da}.permission-grid,.member-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.note-drawer{border-color:var(--border);box-shadow:0 22px 44px #1018282e}.mobile-data-card{box-shadow:var(--shadow-sm)}@media(max-width:760px){.main-content{padding:16px 14px 104px}.topbar{margin:-16px -14px 16px;padding:12px 14px}.topbar h1{font-family:Inter,Segoe UI,Arial,sans-serif;font-size:24px}.topbar .eyebrow{display:none}.login-screen{align-items:start;padding:18px}.login-panel{box-shadow:var(--shadow-sm);padding:22px}.login-panel h1{font-size:34px}.card-grid,.entity-form,.expense-line-form,.export-controls,.action-row{grid-template-columns:1fr}.mobile-bottom-nav{grid-template-columns:repeat(5,minmax(0,1fr))}}.app-user-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.app-user-card{border:1px solid #d7e1ed;border-radius:8px;display:grid;gap:12px;padding:14px}.app-user-card label{color:#2f3848;display:grid;font-size:13px;font-weight:800;gap:6px}.app-user-card input,.app-user-card select{border:1px solid #c8d4e3;border-radius:6px;font:inherit;min-height:40px;padding:0 12px}.inline-feedback{background:#e7f7ed;border:1px solid #94d2a2;border-radius:6px;color:#155f2f;font-weight:800;margin:0;padding:10px 12px}.registration-request-card{border:1px solid #d7e1ed;border-radius:8px;display:grid;gap:12px;padding:14px}.registration-request-card label{color:#2f3848;display:grid;font-size:13px;font-weight:800;gap:6px}.registration-request-card input,.registration-request-card select{border:1px solid #c8d4e3;border-radius:6px;font:inherit;min-height:40px;padding:0 12px}.compact-picker{margin:0}.registration-group-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.registration-group-card{align-items:center;border:1px solid #d7e1ed;border-radius:6px;display:grid;gap:10px;grid-template-columns:20px 1fr;min-height:54px;padding:10px}.registration-group-card input{height:18px;min-height:0;padding:0;width:18px}.registration-group-card span{display:grid;gap:2px}.registration-group-card small{color:#667085;font-weight:800}.login-submit-button{background:#0b3060;border:1px solid #0b3060;border-radius:6px;color:#fff;font-weight:800;min-height:48px;padding:0 18px;text-align:center}.login-submit-button:disabled{background:#dcd9d9;border-color:#dcd9d9;color:#747780;cursor:not-allowed}.login-runtime-note{color:#6d5e00;font-size:13px;font-weight:700;margin:-6px 0 0}.login-divider{align-items:center;color:#747780;display:grid;font-size:12px;font-weight:800;grid-template-columns:1fr auto 1fr;gap:12px;text-transform:uppercase}.login-divider:before,.login-divider:after{background:#e4e2e1;content:"";height:1px}.login-user-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.login-user-card{background:#fff;border:1px solid #c4c6d0;border-radius:6px;display:grid;gap:4px;min-height:96px;padding:14px;text-align:left}.login-user-card:hover{border-color:#0b3060}.login-user-card strong{color:#001b3f;font-size:16px}.login-user-card span,.login-user-card small{color:#747780;font-weight:700}.eyebrow{color:#2b628f;font-size:12px;font-weight:700;letter-spacing:0;margin:0 0 6px;text-transform:uppercase}h1,h2{color:#001b3f;font-family:Work Sans,Segoe UI,Arial,sans-serif;letter-spacing:0;margin:0}h1{font-size:32px;line-height:40px}h2{font-size:22px;line-height:30px}.api-pill{border:1px solid #c4c6d0;border-radius:999px;color:#43474f;font-size:13px;font-weight:700;padding:8px 12px}.api-pill.ready{background:#e5f6e8;border-color:#a8d8b1;color:#17642a}.api-pill.error{background:#ffdad6;border-color:#f5aaa3;color:#93000a}.hero-grid{display:grid;gap:16px;grid-template-columns:minmax(280px,.9fr) minmax(340px,1.4fr);margin-top:28px}.time-panel,.module-panel,.metric-card,.work-table{background:#fff;border:1px solid #dcd9d9;border-radius:8px}.time-panel,.module-panel{padding:24px}.location-map-panel{grid-column:1 / -1;overflow:hidden;padding:0}.map-header{align-items:center;border-bottom:1px solid #e4e2e1;display:flex;justify-content:space-between;gap:16px;padding:18px 20px}.map-header h2{margin:4px 0 0}.location-map-panel iframe{border:0;display:block;height:260px;width:100%}.map-content{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(360px,1.15fr);min-height:260px}.map-details{background:#fbf9f8;border-right:1px solid #e4e2e1;padding:4px 20px 20px}.meta-list.compact{gap:8px;margin-top:12px}.meta-list.compact div{align-items:flex-start}.meta-list.compact dd{line-height:1.35;max-width:360px;text-align:right}.map-placeholder{align-content:center;color:#43474f;display:grid;gap:8px;min-height:260px;padding:28px 20px}.map-placeholder strong{color:#001b3f}.map-refresh-action{margin-top:14px;width:100%}.clock-row,.action-row,.meta-list div{align-items:center;display:flex;justify-content:space-between;gap:12px}.clock-row{border-top:1px solid #e4e2e1;margin-top:22px;padding-top:18px}.clock-row strong{color:#001b3f;font-size:24px}.action-row{justify-content:flex-start;margin-top:20px}.primary-action,.secondary-action{border-radius:4px;font-weight:800;min-height:44px;padding:0 18px}.compact-action{min-height:38px;padding:0 14px}.primary-action{background:#0b3060;border:1px solid #0b3060;color:#fff}.secondary-action{background:#fff;border:1px solid #747780;color:#43474f}.secondary-action:disabled{cursor:not-allowed;opacity:.45}.module-panel p{color:#43474f;line-height:1.55;max-width:720px}.meta-list{border-top:1px solid #e4e2e1;display:grid;gap:10px;margin:20px 0 0;padding-top:16px}.meta-list dt{color:#747780;font-size:13px}.meta-list dd{color:#001b3f;font-weight:800;margin:0}.card-grid{display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr));margin-top:16px}.metric-card{padding:18px}.metric-card span{color:#43474f;display:block;font-size:13px;font-weight:700}.metric-card strong{color:#001b3f;display:block;font-size:28px;margin-top:8px}.metric-card p{color:#747780;font-size:13px;line-height:18px;margin:8px 0 0}.work-table{margin-top:16px;overflow:hidden}.mobile-card-list{display:none}.work-table .section-header{padding:18px 20px}table{border-collapse:collapse;width:100%}th,td{border-top:1px solid #e4e2e1;padding:12px 20px;text-align:left}th{background:#f6f3f2;color:#43474f;font-size:12px;text-transform:uppercase}td{color:#1b1c1c;font-size:14px}.status{border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;padding:5px 9px}.status.planned{background:#e8f2ff;color:#034a76}.status.active{background:#e5f6e8;color:#17642a}.status.inactive{background:#f0eded;color:#747780}.status.attendance-ok{background:#e5f6e8;color:#17642a}.status.attendance-anomaly{background:#fff1d6;color:#7a4d00}.status.attendance-missing{background:#ffdad6;color:#93000a}.status.attendance-rest{background:#e8f2ff;color:#034a76}.status.status-pending-manager{background:#fff1d6;color:#7a4d00}.status.status-pending-hr{background:#ede7ff;color:#4d2c91}.status.status-approved{background:#e5f6e8;color:#17642a}.status.status-rejected{background:#ffdad6;color:#93000a}.status.status-draft{background:#f0eded;color:#43474f}.status.status-site{background:#e5f6e8;color:#17642a}.status.status-smart,.status.status-smart-working{background:#e8f2ff;color:#034a76}.status.status-ip-geolocation{background:#fff1d6;color:#7a4d00}.manual-row{font-weight:800}.row-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;min-width:150px}.calendar-action{border-radius:4px;font-size:12px;font-weight:850;min-height:30px;padding:6px 10px;white-space:nowrap}.note-action{background:#fff;border:1px solid #0b3060;color:#0b3060}.edit-action{background:#fff1d6;border:1px solid #b26a00;color:#7a4d00}.management-layout{align-items:start;display:grid;gap:16px;grid-template-columns:minmax(320px,420px) minmax(0,1fr);margin-top:28px}.absence-layout{grid-template-columns:minmax(560px,640px) minmax(0,1fr)}.entity-form{background:#fff;border:1px solid #dcd9d9;border-radius:8px;display:grid;gap:14px;grid-template-columns:1fr 1fr;padding:20px}.filter-row{align-items:end;border-top:1px solid #e4e2e1;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(160px,1fr));padding:14px 20px}.filter-row label{color:#43474f;display:grid;font-size:12px;font-weight:800;gap:6px;text-transform:uppercase}.filter-row input,.filter-row select{background:#fff;border:1px solid #c4c6d0;border-radius:4px;min-height:38px;padding:8px 10px;text-transform:none}.split-table-title{align-items:center;background:#fbf9f8;border-top:1px solid #e4e2e1;display:flex;justify-content:space-between;padding:12px 20px}.split-table-title h3{color:#001b3f;font-size:16px;margin:0}.split-table-title span{background:#e8f2ff;border-radius:999px;color:#034a76;font-size:12px;font-weight:800;padding:4px 9px}.entity-form>*{min-width:0}.absence-form{grid-template-columns:repeat(2,minmax(0,1fr))}.entity-form .section-header,.entity-form .full{grid-column:1 / -1}.section-header.compact{align-items:start;padding:0}.entity-form label{color:#43474f;display:grid;font-size:12px;font-weight:800;gap:6px;text-transform:uppercase}.entity-form input,.entity-form select,.entity-form textarea{border:1px solid #c4c6d0;border-radius:4px;box-sizing:border-box;color:#1b1c1c;max-width:100%;min-height:40px;min-width:0;padding:8px 10px;width:100%}.entity-form textarea{min-height:96px;resize:vertical}.entity-form input:focus,.entity-form select:focus,.entity-form textarea:focus{border-color:#0b3060;outline:1px solid #0b3060}.check-row{align-content:center;align-items:center;display:flex!important;gap:8px!important;text-transform:none!important}.check-row input{flex:0 0 18px;min-height:18px;width:18px}.check-row.compact{align-items:center;color:#1b1c1c;font-size:13px;font-weight:700;line-height:1.25}.check-row.compact span{min-width:0;overflow-wrap:anywhere}.form-message{color:#17642a;font-size:13px;font-weight:700;grid-column:1 / -1;margin:0}.form-message.error{color:#93000a}.field-hint{color:#5f6f86;display:block;font-size:.86rem;line-height:1.35;margin-top:.35rem}.filter-row{display:flex;gap:8px}.filter-row input,.filter-row select{border:1px solid #c4c6d0;border-radius:4px;min-height:40px;padding:8px 10px}.filter-row input{max-width:100px}.filter-row select{min-width:140px}.export-panel{background:#fff;border:1px solid #dcd9d9;border-radius:8px;display:grid;gap:16px;margin-top:28px;max-width:920px;padding:20px}.export-controls{display:grid;gap:14px;grid-template-columns:minmax(180px,240px) minmax(120px,160px)}.export-controls label,.export-picker-header{color:#43474f;font-size:12px;font-weight:800;text-transform:uppercase}.export-controls label{display:grid;gap:6px}.export-controls input,.export-controls select{border:1px solid #c4c6d0;border-radius:4px;box-sizing:border-box;color:#1b1c1c;min-height:40px;padding:8px 10px;width:100%}.export-picker{border-top:1px solid #e4e2e1;display:grid;gap:10px;padding-top:14px}.export-picker-header{align-items:center;display:flex;justify-content:space-between}.export-picker-header div{display:flex;gap:12px}.export-employee-list{border:1px solid #dcd9d9;border-radius:6px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));max-height:300px;overflow:auto;padding:10px}.export-check-row{align-items:flex-start;background:#fafafa;border:1px solid #eeeeee;border-radius:6px;margin:0;padding:10px 12px}.export-check-row input{flex:0 0 auto;height:16px;margin-top:2px;width:16px}.export-check-row span{color:#001b3f;display:grid;font-size:13px;font-weight:800;gap:2px}.export-check-row small{color:#747780;font-size:12px;font-weight:700}.export-actions{display:flex;flex-wrap:wrap;gap:10px}.expenses-layout{display:grid;gap:16px;grid-template-columns:minmax(320px,420px) minmax(360px,1fr);margin-top:28px}.expenses-detail{grid-column:1 / -1}.note-drawer.expense-detail-drawer{display:block;max-height:calc(100vh - 56px);padding-bottom:14px;width:min(920px,calc(100vw - 56px))}.note-drawer.expense-detail-drawer .section-header{background:#fff;position:sticky;top:0;z-index:2}.expense-detail-drawer .expense-line-form{grid-template-columns:minmax(0,1.2fr) 150px 130px minmax(0,1fr)}.expense-detail-drawer .receipt-picker{grid-column:span 2}.expense-detail-drawer .expense-gps-action,.expense-detail-drawer .expense-line-form .primary-action{min-height:40px}.expense-drawer-message{margin:14px 20px 0}.expense-line-form{display:grid;gap:10px;grid-template-columns:1.2fr 140px 120px 1fr 1fr minmax(220px,1.1fr) auto;padding:14px 20px}.expense-line-form input,.expense-line-form select{border:1px solid #c4c6d0;border-radius:4px;min-height:40px;padding:8px 10px}.visually-hidden-file{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}.receipt-picker{align-items:center;display:grid;gap:6px;grid-template-columns:repeat(2,minmax(0,1fr));min-width:0}.receipt-picker-button{align-items:center;cursor:pointer;display:inline-flex;justify-content:center;min-height:40px;padding:0 10px;text-align:center}.receipt-picker span{color:#747780;font-size:12px;font-weight:700;grid-column:1 / -1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-gps-action{min-width:0;padding:0 10px}.expense-lines-mobile{padding:12px}.link-button{align-items:center;display:inline-flex;text-decoration:none}.station-shell{align-items:center;background:radial-gradient(circle at 50% 0%,rgba(19,78,126,.16),transparent 36%),#f3f7fb;display:flex;min-height:100dvh;padding:24px}.station-card{background:#fff;border:1px solid #d9e4f2;border-radius:10px;box-shadow:0 24px 70px #001b3f29;display:grid;gap:26px;margin:0 auto;max-width:760px;padding:34px;width:min(100%,760px)}.station-header{align-items:start;border-bottom:1px solid #e4eaf2;display:flex;gap:16px;justify-content:space-between;padding-bottom:22px}.station-header h1{color:#001b3f;font-size:44px;line-height:1;margin:4px 0 8px}.station-header span,.station-footer,.station-employee>span{color:#5f6c80;font-weight:700}.station-location{align-items:center;background:#eef8f2;border:1px solid #b8e3c5;border-radius:999px;display:inline-flex;justify-content:center;justify-self:center;min-height:46px;min-width:min(100%,320px);padding:0 28px;width:fit-content}.station-location strong{color:#073c1b;font-size:22px;font-weight:900;line-height:1;text-align:center;white-space:nowrap}.station-login,.station-employee{display:grid;gap:20px}.station-login label{color:#2f3b4f;display:grid;font-size:18px;font-weight:900;gap:10px}.station-login input{border:2px solid #c7d4e5;border-radius:8px;color:#001b3f;font-size:38px;font-weight:900;height:78px;letter-spacing:2px;padding:0 18px;text-align:center}.station-keypad{display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.station-keypad button,.station-ok,.station-punch,.station-cancel{border-radius:8px;font-size:28px;font-weight:900;min-height:72px}.station-keypad button{background:#f8fbff;border:1px solid #c7d4e5;color:#001b3f;cursor:pointer;touch-action:manipulation;transition:background-color 90ms ease,border-color 90ms ease,box-shadow 90ms ease,color 90ms ease,transform 90ms ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.station-keypad button:active,.station-keypad button.is-pressed{background:#124b82;border-color:#0c3862;box-shadow:inset 0 4px 12px #00000038;color:#fff;transform:scale(.975)}.station-keypad button:focus-visible,.station-ok:focus-visible,.station-punch:focus-visible,.station-cancel:focus-visible{outline:4px solid #7fb4e6;outline-offset:3px}.station-ok:active,.station-punch:active,.station-cancel:active{filter:brightness(.9);transform:scale(.985)}.station-ok,.station-punch{font-size:32px;min-height:82px}.station-employee h2{color:#001b3f;font-size:46px;line-height:1.05;margin:0}.station-status{background:#f8fbff;border:1px solid #d9e4f2;border-radius:8px;display:grid;gap:12px;padding:22px}.station-status strong{color:#001b3f;font-size:30px}.station-status p{color:#33415a;font-size:20px;margin:0}.station-status dl{display:grid;gap:10px;margin:0}.station-status dl div{align-items:center;border-top:1px solid #e4eaf2;display:flex;justify-content:space-between;padding-top:10px}.station-status dt{color:#5f6c80;font-weight:800}.station-status dd{color:#001b3f;font-size:20px;font-weight:900;margin:0;text-align:right}.station-footer{border-top:1px solid #e4eaf2;display:flex;flex-wrap:wrap;font-size:13px;gap:10px;justify-content:space-between;padding-top:16px}.manager-stack{display:grid;gap:16px;margin-top:16px}.admin-stack{display:grid;gap:16px;margin-top:28px}.permissions-panel,.member-picker{display:grid;gap:14px}.absence-permission-panel{border:1px solid #e4e2e1;border-radius:6px;display:grid;gap:12px;padding:14px}.absence-permission-panel h3{color:#001b3f;font-size:17px;margin:0}.absence-permission-category{border-top:1px solid #ebe8e7;display:grid;gap:8px;padding-top:10px}.absence-permission-category strong{color:#43474f;font-size:13px}.permission-toggle-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.inline-actions{align-items:center;display:flex;gap:8px}.permission-category{border:1px solid #e4e2e1;border-radius:6px;padding:12px}.permission-category h3,.member-picker h3{color:#001b3f;font-size:15px;margin:0 0 10px}.permission-grid,.member-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.permission-card{align-items:flex-start;border:1px solid #dcd9d9;border-radius:6px;display:flex;gap:10px;padding:10px}.permission-card input{flex:0 0 auto;margin-top:4px}.permission-card span{display:grid;gap:3px}.permission-card strong{color:#001b3f;font-size:13px}.permission-card small{color:#5b6270;font-size:12px;line-height:16px}.permission-card.compact{padding:8px}.request-estimate{background:#eef6ff;border:1px solid #c7dff8;border-radius:6px;color:#001b3f;display:grid;gap:4px;padding:12px 14px}.request-estimate span,.request-estimate small{color:#5b6270;font-size:12px;font-weight:700}.request-estimate strong{font-size:20px}.schedules-layout{align-items:start}.schedule-form,.assignment-form{grid-template-columns:1fr 1fr}.schedule-check{align-self:end;min-height:40px}.schedule-rule-panel{border:1px solid #e4e2e1;border-radius:6px;display:grid;gap:10px;padding:12px}.schedule-rule-panel strong{color:#43474f;font-size:12px;text-transform:uppercase}.schedule-rule-grid{display:grid;gap:8px 14px;grid-template-columns:repeat(2,minmax(0,1fr))}.schedule-days{border:1px solid #e4e2e1;border-radius:6px;overflow-x:auto}.schedule-day-head,.schedule-day-row{align-items:center;display:grid;gap:8px;grid-template-columns:70px 64px repeat(5,minmax(96px,1fr));min-width:780px;padding:8px 10px}.schedule-day-head{background:#f6f3f2;color:#43474f;font-size:12px;font-weight:800;text-transform:uppercase}.schedule-day-row+.schedule-day-row{border-top:1px solid #e4e2e1}.schedule-day-row input{border:1px solid #c4c6d0;border-radius:4px;min-height:36px;padding:6px 8px}.schedule-day-row input[type=checkbox]{min-height:18px;width:18px}.profile-workspace{align-items:start;display:grid;gap:16px;grid-template-columns:minmax(0,1fr)}.profile-panel,.profile-attendance{margin-top:16px}.profile-panel,.profile-attendance{grid-column:1}.profile-attendance{overflow:visible}.profile-attendance .section-header{background:#fff;border-bottom:1px solid #e4e2e1}.attendance-table-scroll{overflow-x:auto}.attendance-table-scroll table{border-collapse:separate;border-spacing:0;table-layout:fixed;min-width:1480px}.attendance-table-scroll thead,.attendance-table-scroll tbody tr{display:table;table-layout:fixed;width:100%}.attendance-table-scroll tbody{display:block;max-height:calc(100vh - 260px);overflow-y:auto}.profile-attendance th:nth-child(1),.profile-attendance td:nth-child(1){background:#fff;left:0;width:130px;position:sticky;z-index:6}.profile-attendance th:nth-child(2),.profile-attendance td:nth-child(2){background:#fff;left:130px;width:110px;position:sticky;z-index:6}.profile-attendance th:nth-child(3),.profile-attendance td:nth-child(3){background:#fff;left:240px;width:120px;position:sticky;z-index:6}.profile-attendance thead th:nth-child(-n+3){background:#f6f3f2;top:0;z-index:9}.time-cell{font-variant-numeric:tabular-nums;white-space:nowrap}.manual-time{background:#fff2cc;font-weight:900;position:relative}.note-drawer{box-shadow:0 10px 28px #001b3f1f;grid-template-columns:1fr 1fr;max-height:calc(100vh - 48px);overflow-y:auto;position:fixed;right:24px;top:24px;width:min(420px,calc(100vw - 48px));z-index:30}.manual-drawer{width:min(520px,calc(100vw - 48px))}.note-drawer:before{background:#fbf9f8b8;content:"";top:0;right:0;bottom:0;left:0;position:fixed;z-index:-1}.sites-table{margin-top:0}.muted-line{color:#747780;display:block;font-size:12px;margin-top:3px}.compact-audit-note{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.ghost-action{background:transparent;border:0;color:#0b3060;font-weight:800;padding:0}.ghost-action.small{min-height:30px;padding:5px 9px}.ghost-action.muted{color:#747780}.ghost-action.danger{color:#93000a}@media(max-width:980px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.nav-list{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-grid,.card-grid,.management-layout,.map-content,.expenses-layout,.expense-line-form{grid-template-columns:1fr}.map-details{border-right:0;border-bottom:1px solid #e4e2e1}.absence-form,.login-user-grid,.schedule-form,.assignment-form,.filter-row,.permission-grid,.member-grid{grid-template-columns:1fr}.note-drawer{bottom:16px;left:16px;max-height:calc(100vh - 32px);right:16px;top:16px;width:auto}.expense-detail-drawer .expense-line-form{grid-template-columns:1fr}.expense-detail-drawer .receipt-picker{grid-column:auto}.main-content{padding:20px}}@media(max-width:760px){body{background:#f7f9fb}.app-shell{display:block;min-height:100dvh}.station-shell{align-items:stretch;padding:12px}.station-card{border-radius:8px;padding:22px}.station-header{display:grid}.station-header h1{font-size:36px}.station-location{min-width:min(100%,260px);padding:0 20px}.station-location strong{font-size:20px;text-align:center;white-space:normal}.station-login input{font-size:32px;height:68px}.station-keypad button,.station-ok,.station-punch,.station-cancel{min-height:64px}.sidebar{display:none}.main-content{padding:18px 16px 104px}.topbar{align-items:flex-start;background:#f7f9fbf5;border-bottom:1px solid #e0e3e5;gap:10px;margin:-18px -16px 18px;padding:14px 16px 12px;position:sticky;top:0;z-index:20}.topbar h1{font-family:"Noto Serif",Segoe UI,serif;font-size:24px;line-height:30px}.topbar-actions{gap:6px}.dev-user-pill{border-radius:6px;max-width:180px;padding:5px 7px}.dev-user-pill span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.api-pill{border-radius:6px;font-size:11px;padding:6px 8px}.hero-grid,.card-grid,.management-layout,.expenses-layout,.map-content,.expense-line-form{gap:12px;margin-top:16px}.time-panel,.module-panel,.metric-card,.work-table,.entity-form,.export-panel{border-radius:8px;box-shadow:0 4px 10px #0b33650a}.time-panel,.module-panel{padding:18px}.clock-row{margin-top:16px;padding-top:14px}.clock-row strong{font-size:22px}.action-row{display:grid;grid-template-columns:1fr 1fr}.primary-action,.secondary-action{min-height:48px}.location-map-panel iframe,.map-placeholder,.map-content{min-height:220px}.map-header{align-items:flex-start;padding:16px}.map-details{padding:2px 16px 16px}.meta-list div{align-items:flex-start}.meta-list dd{overflow-wrap:anywhere;text-align:right}.work-table{overflow-x:hidden}table{min-width:720px}.responsive-table{display:none}.mobile-card-list{display:grid;gap:10px;padding:12px}.mobile-data-card{background:#fff;border:1px solid #dfe3e9;border-radius:8px;display:grid;gap:8px;padding:12px}.mobile-data-card.tappable{cursor:pointer}.mobile-data-card>div:first-child{align-items:flex-start;display:flex;gap:10px;justify-content:space-between}.mobile-data-card strong{color:#001b3f;min-width:0}.mobile-data-card p{color:#43474f;font-size:13px;margin:0}.mobile-data-card dl{display:grid;gap:6px;margin:0}.mobile-data-card dl div{align-items:baseline;display:flex;gap:8px;justify-content:space-between}.mobile-data-card dt{color:#747780;font-size:12px;font-weight:800}.mobile-data-card dd{color:#1b1c1c;font-size:13px;font-weight:700;margin:0;text-align:right}.mobile-empty-state{color:#747780;font-size:13px;font-weight:700;margin:0;padding:4px 0}.expense-line-form{background:#fbf9f8;padding:14px}.receipt-picker{grid-template-columns:1fr 1fr}.approval-actions{display:grid;gap:8px;grid-template-columns:1fr 1fr}.approval-card textarea{border:1px solid #c4c6d0;border-radius:4px;min-height:74px;padding:8px 10px;resize:vertical;width:100%}.month-day-list{padding:12px}.month-day-card>div:first-child strong{display:grid;gap:2px}.attendance-table-scroll{overflow:visible}.attendance-table-scroll table.responsive-table,.manager-stack table.responsive-table{display:none}.profile-attendance .section-header{align-items:stretch;display:grid}.profile-attendance .filter-row{padding:0}.mobile-bottom-nav{align-items:center;background:#fffffffa;border-top:1px solid #dfe3e9;bottom:0;box-shadow:0 -8px 24px #001e4314;display:grid;gap:4px;grid-template-columns:repeat(6,minmax(0,1fr));left:0;padding:8px 8px calc(8px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:60}.mobile-nav-item{align-items:center;background:transparent;border:0;border-radius:999px;color:#43474f;display:grid;gap:3px;justify-items:center;min-height:58px;min-width:0;padding:6px 4px}.mobile-nav-item svg{color:inherit}.mobile-nav-item span{font-size:11px;font-weight:800;line-height:13px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-item.active{background:#cee5ff;color:#034a76}}:root{background:#f4f7fb;color:#182230;--surface: #ffffff;--border: #d8e0ea;--border-strong: #bcc9d8;--text: #182230;--muted: #667085;--muted-strong: #475467;--brand: #123d6f;--brand-strong: #0b3060;--brand-soft: #e8f2ff;--green: #17642a;--amber: #a15c00;--red: #a50f15;--violet: #5b3db1;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .05);--shadow-md: 0 10px 24px rgba(16, 24, 40, .08);--radius: 8px;--radius-control: 6px}body{background:linear-gradient(180deg,#f8fafc,#f3f6fa 260px,#f4f7fb);color:var(--text)}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:#1d70b8!important;box-shadow:0 0 0 3px #1d70b82e;outline:0}.app-shell{background:transparent;grid-template-columns:248px minmax(0,1fr)}.sidebar{background:linear-gradient(180deg,#0b3060,#0a2b55);border-right:1px solid rgba(255,255,255,.08);box-shadow:8px 0 28px #0b30601f;gap:18px;height:100vh;overflow:auto;padding:16px 12px 24px;position:sticky;top:0}.sidebar-brand-image{background:#fff;border-color:#ffffff42;border-radius:var(--radius);box-shadow:var(--shadow-sm)}.nav-list{gap:6px}.nav-item{border:1px solid transparent;border-left:0;border-radius:var(--radius-control);color:#ffffffe0;font-weight:650;min-height:44px;padding:10px 12px}.nav-item:hover{background:#ffffff1a;border-color:#ffffff1f}.nav-item.active{background:#fff;border-color:#fff;color:var(--brand-strong);box-shadow:var(--shadow-sm)}.main-content{max-width:none;min-width:0;padding:28px 32px 48px;width:100%}.topbar{background:#f4f7fbeb;border-bottom:1px solid rgba(216,224,234,.85);margin:-28px -32px 24px;padding:22px 32px 18px;position:sticky;top:0;z-index:25;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-workspace{max-width:none;min-width:0;width:100%}.profile-attendance{min-width:0;overflow:hidden;width:100%}.profile-attendance .section-header{align-items:start;display:grid;gap:14px;grid-template-columns:1fr}.profile-attendance .filter-row{border-top:0;grid-template-columns:minmax(240px,1.2fr) minmax(150px,.8fr) minmax(160px,.8fr) minmax(96px,.45fr);min-width:0;padding:0;width:100%}.attendance-table-scroll{display:block;max-width:100%;overflow-x:auto;overflow-y:hidden;scrollbar-gutter:stable}.attendance-table-scroll table{min-width:1900px}.profile-attendance th:nth-child(1),.profile-attendance td:nth-child(1){left:auto;position:static;width:150px}.profile-attendance th:nth-child(2),.profile-attendance td:nth-child(2){left:auto;position:static;width:125px}.profile-attendance th:nth-child(3),.profile-attendance td:nth-child(3){left:auto;position:static;width:150px}.profile-attendance thead th:nth-child(-n+3){left:auto;position:static}.profile-attendance th:last-child,.profile-attendance td:last-child{width:190px}.profile-attendance .row-actions{min-width:170px}.page-heading{min-width:0}.topbar .eyebrow{color:#0f766e;margin-bottom:4px}h1{color:#0b1f3a;font-size:clamp(28px,2.4vw,38px);line-height:1.12}h2{color:#132238;font-size:23px;line-height:1.22}.dev-user-pill,.api-pill,.time-panel,.module-panel,.metric-card,.work-table,.entity-form,.export-panel,.profile-panel,.profile-attendance,.app-user-card,.registration-request-card,.absence-permission-panel,.permission-category,.schedule-rule-panel{background:var(--surface);border-color:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.dev-user-pill,.api-pill{min-height:40px}.dev-user-pill button:hover,.ghost-action:hover{background:var(--brand-soft)}.login-screen{align-items:start;background:linear-gradient(180deg,#f4f7fbdb,#f4f7fb),radial-gradient(circle at 10% 10%,rgba(18,61,111,.08),transparent 32%);padding-top:7vh}.login-panel{border-color:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-width:720px;padding:32px}.login-panel h1{font-size:40px}.login-copy,.module-panel p,.metric-card p{color:var(--muted-strong)}.login-form input,.profile-password-form input,.registration-request-card input,.registration-request-card select,.app-user-card input,.app-user-card select,.entity-form input,.entity-form select,.entity-form textarea,.filter-row input,.filter-row select,.export-controls input,.export-controls select,.expense-line-form input,.expense-line-form select,.schedule-day-row input{background:#fff;border:1px solid var(--border-strong);border-radius:var(--radius-control);color:var(--text)}.primary-action,.secondary-action,.login-submit-button,.calendar-action,.receipt-picker-button{border-radius:var(--radius-control);min-height:42px}.primary-action,.login-submit-button{background:linear-gradient(180deg,#164a82,#0b3568);border-color:#0b3568;box-shadow:0 1px #ffffff24 inset,0 8px 16px #0b306024}.primary-action:hover,.login-submit-button:hover{background:linear-gradient(180deg,#1b5795,#0d3d76)}.primary-action:disabled,.login-submit-button:disabled{background:#edf1f5;border-color:#c8d4e3;box-shadow:none;color:#7c8796;cursor:not-allowed;opacity:1}.secondary-action{background:#fff;border-color:var(--border-strong);color:#163b63}.secondary-action:hover{background:var(--brand-soft);border-color:#9bc4ed}.hero-grid,.management-layout,.expenses-layout,.admin-stack,.manager-stack,.profile-workspace{gap:18px}.expenses-layout,.management-layout,.schedules-layout{align-items:start}.time-panel,.module-panel,.entity-form,.export-panel{padding:22px}.section-header{min-height:72px;padding:18px 20px}.section-header.compact{min-height:0;padding:0}.metric-card strong,.clock-row strong,.meta-list dd{color:#102a43;font-variant-numeric:tabular-nums}.filter-row{align-items:end;background:#fbfcfe;border-top:1px solid #e7edf4;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(130px,1fr));padding:14px 20px}.filter-row input{max-width:none}th{background:#f7f9fc;border-top-color:#e7edf4;color:#475467;font-size:11px}td{border-top-color:#e7edf4;color:#243447;vertical-align:middle}tbody tr:hover td{background:#fbfdff}.split-table-title{background:#fbfcfe;border-top-color:#e7edf4}.status.status-pending-manager{background:#fff4dc;color:var(--amber)}.status.status-pending-hr{background:#eee9ff;color:var(--violet)}.status.status-approved,.status.attendance-ok,.status.active{background:#e8f7ee;color:var(--green)}.status.status-rejected,.status.attendance-missing{background:#fde7e7;color:var(--red)}.status.attendance-anomaly{background:#fff4dc;color:var(--amber)}.form-message{background:#e9f8ef;border:1px solid #b7e3c3;border-radius:var(--radius-control);color:var(--green);padding:10px 12px}.form-message.error{background:#fde7e7;border-color:#f3b7b7;color:var(--red)}.expense-line-form{background:#fbfcfe;border-top:1px solid #e7edf4}.app-user-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.app-user-card,.registration-request-card{padding:16px}@media(max-width:1180px){.card-grid,.expense-line-form{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:980px){.sidebar{height:auto;position:static}.topbar{margin:-20px -20px 20px;padding:18px 20px}.filter-row{grid-template-columns:1fr}}@media(max-width:760px){.main-content{padding:16px 14px 104px}.topbar{margin:-16px -14px 16px;padding:12px 14px}.topbar h1{font-family:Inter,Segoe UI,Arial,sans-serif;font-size:24px}.topbar .eyebrow{display:none}.login-screen{padding:18px}.login-panel{box-shadow:var(--shadow-sm);padding:22px}.login-panel h1{font-size:34px}.card-grid,.entity-form,.expense-line-form,.export-controls{grid-template-columns:1fr}}.mobile-app-shell{background:#f4f7fb;color:#182230;display:grid;gap:14px;margin:0 auto;max-width:560px;min-height:100dvh;padding:16px 14px calc(24px + env(safe-area-inset-bottom))}.mobile-header{align-items:center;display:flex;gap:14px;justify-content:space-between;padding:8px 2px 4px}.mobile-header h1,.mobile-login-card h1{color:#0b1f3a;font-family:Inter,Segoe UI,Arial,sans-serif;font-size:28px;line-height:34px;margin:0}.mobile-header span,.mobile-status-panel span,.mobile-list-row span,.mobile-login-card p{color:#667085;font-size:13px;font-weight:700}.mobile-kicker{color:#0f766e;font-size:12px;font-weight:900;letter-spacing:0;margin:0 0 3px;text-transform:uppercase}.mobile-icon-button,.mobile-refresh-button{align-items:center;background:#fff;border:1px solid #d8e0ea;border-radius:8px;color:#123d6f;display:inline-flex;font-weight:850;gap:8px;justify-content:center;min-height:42px;padding:0 12px}.mobile-icon-button{aspect-ratio:1;padding:0;width:42px}.mobile-login-card,.mobile-status-panel,.mobile-card{background:#fff;border:1px solid #d8e0ea;border-radius:8px;box-shadow:0 1px 2px #1018280d}.mobile-login-card{align-self:start;display:grid;gap:16px;margin-top:8vh;padding:22px}.mobile-status-panel{align-items:center;display:flex;gap:14px;justify-content:space-between;padding:16px}.mobile-status-panel p{color:#667085;font-size:12px;font-weight:900;margin:0 0 4px;text-transform:uppercase}.mobile-status-panel strong{color:#0b1f3a;display:block;font-size:24px;line-height:30px}.mobile-card{display:grid;gap:14px;padding:16px}.mobile-section-title{align-items:center;display:flex;gap:8px}.mobile-section-title svg{color:#0f766e}.mobile-section-title h2{font-family:Inter,Segoe UI,Arial,sans-serif;font-size:18px;line-height:24px}.mobile-punch-actions{display:grid;gap:10px;grid-template-columns:1fr 1fr}.mobile-primary-action,.mobile-secondary-action{align-items:center;border-radius:8px;display:inline-flex;font-weight:900;gap:8px;justify-content:center;min-height:52px;padding:0 16px}.mobile-primary-action{background:#0f766e;border:1px solid #0f766e;color:#fff}.mobile-secondary-action{background:#fff;border:1px solid #bcc9d8;color:#123d6f}.mobile-primary-action:disabled,.mobile-secondary-action:disabled,.mobile-refresh-button:disabled{background:#edf1f5;border-color:#d8e0ea;color:#7c8796;cursor:not-allowed}.mobile-form{display:grid;gap:12px}.mobile-form.compact{gap:10px}.mobile-form label{color:#475467;display:grid;font-size:12px;font-weight:900;gap:6px;text-transform:uppercase}.mobile-form input,.mobile-form select,.mobile-form textarea{background:#fff;border:1px solid #bcc9d8;border-radius:8px;color:#182230;min-height:44px;padding:9px 11px;width:100%}.mobile-form textarea{min-height:76px;resize:vertical}.mobile-list{border-top:1px solid #e7edf4;display:grid}.mobile-list-row{align-items:center;border-bottom:1px solid #e7edf4;display:flex;gap:12px;justify-content:space-between;min-height:66px;padding:10px 0}.mobile-list-row>div{display:grid;gap:3px;min-width:0}.mobile-list-row>div:last-child{text-align:right}.mobile-list-row strong{color:#132238;font-size:14px}.mobile-empty{color:#667085;font-size:13px;font-weight:800;margin:0;padding:14px 0 0}.mobile-message{background:#e8f7ee;border:1px solid #b7e3c3;border-radius:8px;color:#17642a;font-size:13px;font-weight:850;margin:0;padding:12px 14px}.mobile-message.error{background:#fde7e7;border-color:#f3b7b7;color:#a50f15}.icon-action{width:100%}
