:root{color:#16211f;background:#f5f7f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--app-green: #0f766e;--app-green-dark: #115e59;--app-blue: #4a90df;--app-blue-dark: #2f76d2;--app-ink: #16211f;--app-muted: #64736f;--app-line: #dbe4df;--app-surface: #ffffff;--app-soft: #eef6f2;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{border:0}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;background:#f4f5f6}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;min-height:calc(64px + var(--safe-top));padding:calc(8px + var(--safe-top)) 8px 8px;border-bottom:1px solid #d8dde2;background:#fff}.brand-lockup{display:flex;align-items:center;min-width:0;flex:1;gap:8px}.brand-lockup img{width:36px;height:36px;border-radius:0;object-fit:contain;background:#fff}.brand-lockup strong,.page-title{display:block;overflow:hidden;color:var(--app-ink);font-size:1.05rem;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.brand-lockup span,.page-kicker{display:block;color:var(--app-muted);font-size:.78rem;line-height:1.2}.main-content{width:min(720px,100%);margin:0 auto;padding:0 0 calc(84px + var(--safe-bottom))}.form-content{padding-bottom:calc(76px + var(--safe-bottom))}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:30;display:grid;grid-template-columns:repeat(5,1fr);width:min(720px,100%);margin:0 auto;padding:0 0 var(--safe-bottom);border-top:1px solid #d8dde2;background:#fff}.bottom-nav a{display:flex;min-height:72px;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:0;color:var(--app-muted)}.bottom-nav a.active{background:var(--app-blue);color:#fff}.bottom-nav span{display:block;max-width:68px;font-size:.73rem;line-height:1.05;text-align:center}.section-stack{display:grid;gap:14px}.card{border:1px solid var(--app-line);border-radius:8px;background:var(--app-surface);box-shadow:0 12px 28px #115e590f}.card-pad{padding:16px}.hero-panel{display:grid;gap:16px;padding:18px;border-radius:8px;color:#fff;background:linear-gradient(135deg,#0f766ef5,#134e4af0),var(--app-green);box-shadow:0 20px 38px #0f766e2e}.hero-panel h1,.page-heading h1{margin:0;font-size:1.45rem;line-height:1.1;letter-spacing:0}.hero-panel p,.page-heading p,.muted{margin:0;color:var(--app-muted)}.hero-panel p{color:#ffffffc7}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric{display:grid;gap:4px;padding:12px;border-radius:8px;background:#ffffff1f}.metric strong{font-size:1.15rem}.metric span{color:#ffffffb8;font-size:.78rem}.page-heading{display:grid;gap:4px;margin-bottom:16px}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.list{display:grid;gap:10px}.list-item{display:grid;gap:8px;padding:14px}.list-item-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.list-item h2,.list-item h3,.card h2{margin:0;color:var(--app-ink);font-size:.98rem;line-height:1.2}.list-item p,.card p{margin:0;color:var(--app-muted);font-size:.9rem;line-height:1.45}.badge{display:inline-flex;width:fit-content;align-items:center;gap:6px;padding:5px 8px;border-radius:999px;color:#0f513f;background:#dff4ea;font-size:.76rem;font-weight:700;white-space:nowrap}.badge.warn{color:#7a4b00;background:#fff1cb}.badge.danger{color:#7f1d1d;background:#fee2e2}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;padding:0 14px;border-radius:8px;color:#fff;background:var(--app-green);font-weight:750;cursor:pointer}.button.secondary{color:var(--app-green-dark);background:var(--app-soft)}.icon-button{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border-radius:8px;color:var(--app-green-dark);background:var(--app-soft)}.top-actions{display:flex;align-items:center;gap:2px}.top-icon-button{display:inline-flex;width:40px;height:40px;flex:0 0 40px;align-items:center;justify-content:center;color:#1f2933;background:transparent;cursor:pointer}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;display:none;background:#0000006b}.drawer-scrim.visible{display:block}.side-menu{position:fixed;top:0;bottom:0;left:0;z-index:40;display:grid;grid-template-rows:auto 1fr auto;width:min(304px,84vw);background:#fff;box-shadow:0 18px 42px #0f172a33;transform:translate(-104%);transition:transform .18s ease}.side-menu.open{transform:translate(0)}.side-menu-brand{display:flex;align-items:center;gap:12px;padding:calc(14px + var(--safe-top)) 18px 16px;border-bottom:1px solid #e5e7eb}.side-menu-brand img{width:36px;height:36px;object-fit:contain}.side-menu nav{display:grid;align-content:start;padding:8px 0}.side-menu a{display:flex;align-items:center;gap:18px;min-height:48px;padding:0 20px;color:#17212b;font-size:.95rem}.side-menu a svg{color:#68727d}.side-menu-account{display:grid;gap:4px;padding:16px 20px calc(18px + var(--safe-bottom));border-top:1px solid #e5e7eb;color:#68727d}.side-menu-account strong{color:#5f6b77;font-size:.9rem;font-weight:500}.side-menu-logout{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 0;background:none;border:none;cursor:pointer;color:#b91c1c;font-size:.85rem;font-weight:500}.field{display:grid;gap:6px}.field label,.field span,.field legend{color:var(--app-muted);font-size:.82rem;font-weight:500}.field input,.field select,.field textarea{width:100%;min-height:46px;padding:10px 12px;border:1px solid #c8d0d8;border-radius:4px;color:var(--app-ink);background:#fff}.field textarea{min-height:92px;resize:vertical}.login-page{display:grid;min-height:100vh;align-items:center;padding:28px 18px;background:linear-gradient(180deg,#0f766e1f,#f5f7f400),#f5f7f4}.login-card{display:grid;width:min(420px,100%);gap:18px;margin:0 auto;padding:24px}.login-brand{display:grid;gap:10px;justify-items:start}.login-brand img{width:84px;height:84px;border-radius:12px;object-fit:contain;border:1px solid var(--app-line);background:#fff}@media(min-width:640px){.bottom-nav span{display:inline;font-size:.78rem;font-weight:700}.bottom-nav a{gap:8px}}.appsheet-screen{position:relative;min-height:calc(100vh - 140px);background:#fff}.section-title,.table-title{margin:0;padding:12px 14px 10px;color:#1f2933;font-size:1.25rem;font-weight:500;letter-spacing:0}.appsheet-group{border-top:1px solid #e2e6ea;border-bottom:1px solid #e2e6ea;background:#fff}.appsheet-group h2{margin:0;padding:12px 14px;border-bottom:1px solid #e8ebee;background:#f5f6f7;font-size:1rem;font-weight:650}.appsheet-group button,.grouped-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;width:100%;min-height:38px;padding:0 10px;border-bottom:1px solid #e8ebee;background:#fff;color:#1f2933;text-align:left}.appsheet-group small,.grouped-row small,.employee-group-heading small,.date-group small{padding:2px 6px;border-radius:5px;color:#6b7280;background:#e6eaee;font-size:.78rem}.chart-panel{margin-top:8px;padding:14px;border-top:1px solid #e2e6ea;border-bottom:1px solid #e2e6ea;background:#fff}.chart-panel h2{margin:0 0 12px;font-size:1.2rem;font-weight:500}.chart-legend{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#4b5563;font-size:.8rem}.chart-legend span{width:24px;height:14px;border-radius:3px;background:#2c7fb8}.bar-chart{display:grid;grid-template-columns:repeat(3,1fr);align-items:end;height:190px;padding:18px 40px 0;border-bottom:1px solid #d8dde2;background:repeating-linear-gradient(to bottom,transparent 0,transparent 35px,#dce3ea 36px)}.bar-chart i{width:34px;justify-self:center;background:#2c7fb8}.appsheet-list{gap:0;border-top:1px solid #e2e6ea;background:#fff}.appsheet-list .list-item{border-bottom:1px solid #e2e6ea;border-radius:0;box-shadow:none}.table-back-title{min-height:39px;padding:8px 14px;border-bottom:1px solid #e2e6ea;background:#fff;color:#1f2933;font-size:1rem;font-weight:600}.table-back-title:before{content:"<";margin-right:12px;color:#7b8794}.data-table{overflow-x:auto;background:#fff}.data-table-head,.data-table-row{display:grid;grid-template-columns:118px 112px 132px;min-width:430px}.data-table-head strong{padding:12px;border-right:1px solid #e2e6ea;border-bottom:1px solid #d8dde2;font-size:.82rem}.date-group,.employee-group-heading{display:flex;align-items:center;gap:10px;min-height:39px;padding:8px 14px;border-bottom:1px solid #e2e6ea;background:#f5f6f7}.data-table-row{position:relative;border-bottom:1px solid #e2e6ea}.data-table-row span{padding:11px 12px;font-size:.86rem}.data-table-row .badge,.data-table-row small{display:none}.vacation-row{min-height:92px}.row-actions{display:flex;justify-content:flex-end;gap:16px}.row-actions button{color:#5f6b77;background:transparent}.fab{position:fixed;right:max(18px,calc((100vw - 720px)/2 + 18px));bottom:calc(92px + var(--safe-bottom));z-index:25;display:flex;width:58px;height:58px;align-items:center;justify-content:center;border-radius:14px;color:#fff;background:var(--app-blue);box-shadow:0 8px 20px #2f76d25c}.detail-record{display:grid;gap:18px;padding:18px 22px;background:#fff}.detail-record div{position:relative;display:grid;gap:6px}.detail-record span{color:#6b7280;font-size:.82rem}.detail-record strong{color:#1f2933;font-size:1rem;font-weight:500}.detail-record svg{position:absolute;right:0;bottom:0;color:#68727d}.calendar-tabs{display:grid;grid-template-columns:repeat(4,auto);justify-content:start;gap:18px;padding:14px 18px 0;background:#fff}.calendar-tabs button{min-height:34px;color:#4b5563;background:transparent}.calendar-tabs .active{border-bottom:2px solid var(--app-blue-dark);color:#111827;font-weight:700}.calendar-tabs button:last-child{margin-left:58px;color:var(--app-blue-dark)}.calendar-range{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:14px 18px 10px;text-align:center}.week-grid{overflow-x:auto;background:#fff}.week-grid>div:first-child,.week-day{display:inline-grid;width:calc((100% - 44px) / 7);min-width:44px;min-height:46px;align-content:center;text-align:center}.week-grid>div:first-child{width:44px}.week-day strong{font-size:1.15rem;font-weight:500}.week-day span{font-size:.74rem}.week-row{display:grid;grid-template-columns:44px repeat(7,minmax(44px,1fr));min-height:40px}.week-row span,.week-row div{border-top:1px solid #dfe5eb;border-right:1px solid #e8edf2;color:#4b5563;font-size:.72rem}.mobile-form{min-height:calc(100vh - 64px);background:#fff}.form-back{display:flex;align-items:center;gap:8px;min-height:42px;padding:0 14px;color:#1f2933;background:#fff}.form-fields{display:grid;gap:22px;padding:10px 18px 96px}.form-action-bar{position:fixed;right:0;bottom:0;left:0;z-index:32;display:grid;grid-template-columns:1fr 1fr;width:min(720px,100%);min-height:calc(64px + var(--safe-bottom));margin:0 auto;padding-bottom:var(--safe-bottom);border-top:1px solid #d8dde2;background:#fff}.form-action-bar button{color:#1f2933;background:#fff;font-weight:600}.form-action-bar button:last-child{color:#1976d2}.stepper{display:grid;grid-template-columns:1fr 42px 42px;border:1px solid #c8d0d8;border-radius:4px;background:#fff}.stepper input{border:0}.stepper button{color:#5f6b77;background:transparent}.stepper.disabled{background:#f9fafb;opacity:.72}.photo-field{display:flex;min-height:66px;align-items:center;justify-content:center;border:1px solid #c8d0d8;border-radius:4px;color:#5f6b77;background:#fff}.segmented-field{margin:0;padding:0;border:0}.segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.segmented-control button{min-height:48px;border:1px solid #c8d0d8;color:#39424e;background:#f8fafc}.segmented-control button.active{border-color:var(--app-blue);color:#fff;background:var(--app-blue)}.mini-table{display:grid;grid-template-columns:1fr 112px;margin-top:12px;overflow-x:auto;border-top:1px solid #e2e6ea;border-left:1px solid #e2e6ea}.mini-table>*{padding:10px;border-right:1px solid #e2e6ea;border-bottom:1px solid #e2e6ea;font-size:.84rem}.app-shell{background:linear-gradient(180deg,#2f76d214,#f4f7fa00 210px),#f4f7fa}.app-header{width:min(720px,100%);margin:0 auto;border-right:1px solid rgba(216,221,226,.7);border-left:1px solid rgba(216,221,226,.7);box-shadow:0 8px 22px #1f29370f}.brand-lockup strong{color:#17212b;font-weight:650}.top-icon-button{border-radius:8px;transition:background .14s ease,color .14s ease}.top-icon-button:hover{color:var(--app-blue-dark);background:#edf5ff}.main-content{overflow:hidden;border-right:1px solid rgba(216,221,226,.7);border-left:1px solid rgba(216,221,226,.7)}.appsheet-screen{min-height:calc(100vh - 142px);padding:10px;background:linear-gradient(180deg,#fff,#fff) padding-box,#f4f7fa}.section-title,.table-title,.table-back-title{border-radius:8px 8px 0 0;color:#17212b;background:#fff}.appsheet-group,.chart-panel,.data-table,.appsheet-list,.detail-record{overflow:hidden;border:1px solid #dfe6ee;border-radius:8px;box-shadow:0 10px 24px #1f29370d}.appsheet-group{margin-bottom:12px}.appsheet-group h2{background:#f7f9fb}.appsheet-group button,.grouped-row{min-height:46px;padding:0 14px;transition:background .14s ease}.appsheet-group button:hover,.grouped-row:hover{background:#f6faff}.appsheet-group small,.grouped-row small,.employee-group-heading small,.date-group small{color:#516173;background:#e8eef5;font-weight:650}.chart-panel{margin-top:0;margin-bottom:12px}.bar-chart{border-radius:8px;background:linear-gradient(180deg,#ffffffd6,#ffffffd6),repeating-linear-gradient(to bottom,transparent 0,transparent 35px,#dce3ea 36px)}.bar-chart i{width:38px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,#3f9be5,#2f76d2)}.appsheet-list{background:#fff}.appsheet-list .list-item,.vacation-row{padding:15px;transition:background .14s ease}.appsheet-list .list-item:hover,.vacation-row:hover{background:#f8fbff}.list-item-title h2{color:#17212b;font-weight:700}.data-table{margin-top:0}.data-table-head{background:#f7f9fb}.data-table-head strong{color:#17212b;font-weight:750}.date-group,.employee-group-heading{background:#f4f7fa}.data-table-row{min-height:48px;background:#fff;transition:background .14s ease}.data-table-row:hover{background:#f8fbff}.data-table-row span{overflow:hidden;align-self:center;text-overflow:ellipsis;white-space:nowrap}.bottom-nav{overflow:hidden;border:1px solid rgba(216,221,226,.86);border-bottom:0;border-radius:14px 14px 0 0;box-shadow:0 -10px 28px #1f293714}.bottom-nav a{position:relative;min-height:70px}.bottom-nav a.active{background:linear-gradient(180deg,#5aa4eb,#3f8fdb)}.bottom-nav a.active:before{position:absolute;top:0;width:34px;height:3px;border-radius:0 0 4px 4px;background:#fff;content:""}.fab{bottom:calc(98px + var(--safe-bottom));border-radius:18px;background:linear-gradient(180deg,#5aa4eb,#3f8fdb);box-shadow:0 12px 28px #2f76d25c}.side-menu{border-radius:0 18px 18px 0}.side-menu-brand{background:linear-gradient(180deg,#fff,#f7faff)}.side-menu a:hover{background:#f2f7ff}.mobile-form{min-height:calc(100vh - 64px);padding:10px 10px 0;background:#f4f7fa}.form-back,.form-fields{background:#fff}.form-back{border:1px solid #dfe6ee;border-bottom:0;border-radius:8px 8px 0 0}.form-fields{gap:20px;border:1px solid #dfe6ee;border-radius:0 0 8px 8px;box-shadow:0 10px 24px #1f29370d}.field input,.field select,.field textarea,.stepper,.photo-field{border-color:#cfd8e3;box-shadow:inset 0 1px #1f293705}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--app-blue);box-shadow:0 0 0 3px #4a90df24;outline:none}.photo-field{background:linear-gradient(180deg,#fff,#f8fbff)}.photo-field img{width:100%;height:112px;object-fit:cover;border-radius:4px}.field-hint{color:#697789;font-size:.78rem}.field-hint.success{color:#0f766e}.field-hint.error{color:#b42318}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.form-action-bar{overflow:hidden;border:1px solid rgba(216,221,226,.86);border-bottom:0;border-radius:14px 14px 0 0;box-shadow:0 -10px 28px #1f293714}.form-action-bar button:last-child{background:#f5f9ff;font-weight:750}.detail-record{margin:10px}.mini-table{overflow:hidden;border-color:#dfe6ee;border-radius:8px}.expenses-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:10px;padding:18px;border-radius:12px;color:#fff;background:linear-gradient(135deg,#2f76d2f5,#0f766ee6),var(--app-blue);box-shadow:0 14px 28px #2f76d238}.expenses-hero div{display:grid;gap:4px}.expenses-hero span,.expenses-hero small{color:#ffffffc7;font-size:.82rem}.expenses-hero strong{font-size:1.8rem;line-height:1.05}.filter-panel{display:grid;gap:10px;margin-bottom:10px;padding:12px;border:1px solid #dfe6ee;border-radius:10px;background:#fff;box-shadow:0 10px 24px #1f29370d}.filter-title{display:flex;align-items:center;gap:8px;color:#516173}.filter-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.filter-scroll button{min-height:34px;flex:0 0 auto;padding:0 12px;border:1px solid #d4dee9;border-radius:999px;color:#516173;background:#f8fbff;font-weight:650}.filter-scroll button.active{border-color:#2f76d23d;color:#fff;background:linear-gradient(180deg,#5aa4eb,#3f8fdb)}.expenses-list{overflow:hidden;border:1px solid #dfe6ee;border-radius:10px;background:#fff;box-shadow:0 10px 24px #1f29370d}.date-group.polished{gap:8px;background:#f7f9fb}.expense-card{display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:center;padding:14px;border-bottom:1px solid #e7edf3;background:#fff}.expense-card:last-child{border-bottom:0}.expense-icon{display:flex;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;color:var(--app-blue-dark);background:#eef6ff}.expense-main{display:grid;min-width:0;gap:4px}.expense-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.expense-title strong{overflow:hidden;color:#17212b;text-overflow:ellipsis;white-space:nowrap}.expense-main span,.expense-main small{overflow:hidden;color:#697789;font-size:.82rem;text-overflow:ellipsis;white-space:nowrap}.expense-side{display:grid;justify-items:end;gap:7px;color:#607084}.expense-side strong{color:#17212b;font-size:.95rem;white-space:nowrap}.home-screen,.detail-screen{display:grid;gap:12px;min-height:calc(100vh - 142px);padding:12px;background:#f4f7fa}.home-hero,.detail-hero{display:grid;gap:14px;padding:18px;border-radius:14px;color:#fff;background:linear-gradient(135deg,#0f766ef5,#2f76d2eb),var(--app-green);box-shadow:0 14px 28px #115e5933}.home-hero h1,.home-hero p,.detail-hero h1,.detail-hero p{margin:0}.home-hero h1,.detail-hero h1{overflow:hidden;font-size:1.42rem;line-height:1.08;text-overflow:ellipsis;white-space:nowrap}.home-hero span,.home-hero p,.detail-hero span,.detail-hero p{color:#ffffffc7}.home-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.home-metrics div{display:grid;gap:4px;padding:12px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:#ffffff1f}.home-metrics strong{font-size:1.12rem}.home-metrics span{font-size:.78rem}.today-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.daily-card,.dashboard-panel,.detail-panel,.ticket-preview{border:1px solid #dfe6ee;border-radius:12px;background:#fff;box-shadow:0 10px 24px #1f29370d}.daily-card{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;min-width:0;min-height:104px;padding:14px;color:var(--app-blue-dark)}.daily-card.primary{grid-column:1 / -1}.daily-card div{display:grid;min-width:0;gap:4px}.daily-card span,.daily-card small,.dashboard-row span,.notice-row span{overflow:hidden;color:#697789;font-size:.78rem;text-overflow:ellipsis;white-space:nowrap}.daily-card strong,.dashboard-row strong,.notice-row strong{overflow:hidden;color:#17212b;font-size:.92rem;text-overflow:ellipsis;white-space:nowrap}.daily-card small{display:inline-flex;align-items:center;gap:4px}.dashboard-panel{display:grid;overflow:hidden}.panel-heading.compact{align-items:center;padding:14px;border-bottom:1px solid #e7edf3;color:var(--app-blue-dark)}.dashboard-row,.notice-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:13px 14px;border-bottom:1px solid #eef2f6}.dashboard-row:last-child,.notice-row:last-child{border-bottom:0}.dashboard-row div{display:grid;min-width:0;gap:3px}.dashboard-row small{color:var(--app-blue-dark);font-weight:800;white-space:nowrap}.notice-row{grid-template-columns:1fr;border-left:4px solid #4a90df}.notice-row.warn{border-left-color:#d97706}.notice-row.danger{border-left-color:#dc2626}.detail-back{display:inline-flex;width:fit-content;align-items:center;gap:8px;min-height:38px;color:#516173;font-weight:700}.detail-hero{grid-template-columns:1fr auto;align-items:start}.detail-hero.expenses{background:linear-gradient(135deg,#2f76d2f5,#0f766ee6),var(--app-blue)}.detail-hero.absence{background:linear-gradient(135deg,#52525bf5,#0f766ee6),#52525b}.detail-hero.work-site{background:linear-gradient(135deg,#0f766ef5,#52525be6),var(--app-green)}.detail-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-metric-grid article{display:grid;gap:5px;padding:14px;border:1px solid #dfe6ee;border-radius:12px;color:var(--app-blue-dark);background:#fff;box-shadow:0 10px 24px #1f29370d}.detail-metric-grid span,.detail-row span,.detail-panel.note span,.ticket-preview span{color:#697789;font-size:.78rem}.detail-metric-grid strong{color:#17212b;font-size:1.12rem}.detail-panel{display:grid;overflow:hidden}.detail-row{display:grid;grid-template-columns:28px 1fr auto;gap:10px;align-items:center;min-height:52px;padding:12px 14px;border-bottom:1px solid #eef2f6;color:var(--app-blue-dark)}.detail-row:last-child{border-bottom:0}.detail-row strong{overflow:hidden;max-width:190px;color:#17212b;font-size:.9rem;text-align:right;text-overflow:ellipsis;white-space:nowrap}.detail-panel.note{gap:12px;padding:14px}.detail-panel.note div{display:grid;gap:5px}.detail-panel.note strong{color:#17212b;font-size:.92rem;line-height:1.45}.ticket-preview{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:center;padding:14px;color:var(--app-blue-dark)}.ticket-preview div{display:grid;gap:3px;min-width:0}.ticket-preview strong{color:#17212b}.calendar-screen,.documents-screen{display:grid;gap:10px;min-height:calc(100vh - 142px);padding:10px;background:#f4f7fa}.calendar-screen .calendar-tabs{grid-template-columns:repeat(3,auto);gap:10px;padding:12px;border:1px solid #dfe6ee;border-radius:10px;box-shadow:0 10px 24px #1f29370d}.calendar-screen .calendar-tabs button:last-child{margin-left:0}.calendar-range.polished{border:1px solid #dfe6ee;border-radius:10px;background:#fff;box-shadow:0 10px 24px #1f29370d}.calendar-week-board{display:grid;grid-template-columns:repeat(7,minmax(118px,1fr));gap:8px;overflow-x:auto;padding-bottom:2px}.calendar-month-board{display:grid;grid-template-columns:repeat(7,minmax(82px,1fr));gap:8px;overflow-x:auto;padding-bottom:2px}.calendar-month-board .calendar-day-card{min-height:132px}.calendar-range.polished button{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:8px;color:var(--app-blue-dark);background:#eef6ff}.calendar-day-card{display:grid;align-content:start;gap:10px;min-height:184px;padding:12px;border:1px solid #dfe6ee;border-radius:12px;background:#fff;box-shadow:0 10px 24px #1f29370d}.calendar-day-card.today{border-color:#2f76d26b;background:#f7fbff}.calendar-day-card.muted{opacity:.58}.calendar-day-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.calendar-day-head div{display:grid;gap:1px}.calendar-day-head strong{color:#17212b;font-size:1.18rem}.calendar-day-head span,.calendar-day-head small,.calendar-more{color:#697789;font-size:.76rem}.calendar-day-head small{padding:3px 7px;border-radius:999px;background:#e8eef5;font-weight:800}.calendar-event-stack{display:grid;gap:7px}.calendar-day-add{display:inline-flex;min-height:30px;align-items:center;justify-content:center;align-self:end;border-radius:8px;color:var(--app-blue-dark);background:#eef6ff;font-size:.78rem;font-weight:800}.calendar-event{display:grid;grid-template-columns:18px 1fr;gap:7px;min-width:0;padding:8px;border-radius:8px;color:var(--app-blue-dark);background:#eef6ff}.calendar-event.expense{color:#0f766e;background:#eef8f2}.calendar-event.absence{color:#7a4b00;background:#fff4d8}.calendar-event.assignment{color:#52525b;background:#f0f2f5}.calendar-event.payroll{color:#6d28d9;background:#f3edff}.calendar-event div,.calendar-list-row div{display:grid;min-width:0;gap:2px}.calendar-event strong,.calendar-list-row strong{overflow:hidden;color:#17212b;font-size:.78rem;text-overflow:ellipsis;white-space:nowrap}.calendar-event span,.calendar-list-row span{overflow:hidden;color:#697789;font-size:.72rem;text-overflow:ellipsis;white-space:nowrap}.calendar-list-row{display:grid;grid-template-columns:28px 1fr auto;gap:10px;align-items:center;min-height:58px;padding:12px 14px;border-bottom:1px solid #eef2f6;color:var(--app-blue-dark)}.calendar-list-row:last-child{border-bottom:0}.documents-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:14px;color:#fff;background:linear-gradient(135deg,#2f76d2f5,#52525beb),var(--app-blue);box-shadow:0 14px 28px #2f76d233}.documents-hero div{display:grid;gap:4px;min-width:0}.documents-hero h1,.documents-hero p{margin:0}.documents-hero h1{font-size:1.42rem;line-height:1.08}.documents-hero span,.documents-hero p{color:#ffffffc7;font-size:.86rem}.document-search{display:grid;grid-template-columns:28px 1fr;align-items:center;min-height:46px;padding:0 12px;border:1px solid #dfe6ee;border-radius:10px;color:#697789;background:#fff;box-shadow:0 10px 24px #1f29370d}.document-search input{min-width:0;border:0;outline:none}.documents-list{display:grid;overflow:hidden;border:1px solid #dfe6ee;border-radius:12px;background:#fff;box-shadow:0 10px 24px #1f29370d}.documents-list.embedded{border-radius:10px;box-shadow:none}.document-card{display:grid;grid-template-columns:42px 1fr auto;gap:12px;align-items:center;min-width:0;padding:14px;border-bottom:1px solid #eef2f6}.document-card:last-child{border-bottom:0}.document-icon{display:flex;width:42px;height:42px;align-items:center;justify-content:center;border-radius:10px;color:var(--app-blue-dark);background:#eef6ff}.document-card div:nth-child(2){display:grid;min-width:0;gap:3px}.document-card strong,.document-card span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-card strong{color:#17212b;font-size:.92rem}.document-card span{color:#697789;font-size:.78rem}.document-actions{display:flex;gap:8px}.document-actions a{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:8px;color:var(--app-blue-dark);background:#eef6ff}.profile-screen{min-height:calc(100vh - 142px);padding:12px;background:#f4f7fa}.profile-hero{display:grid;grid-template-columns:58px 1fr;gap:14px;align-items:center;padding:18px;border-radius:12px;color:#fff;background:linear-gradient(135deg,#0f766ef5,#2f76d2eb),var(--app-green);box-shadow:0 14px 28px #115e5933}.profile-avatar{display:flex;width:58px;height:58px;align-items:center;justify-content:center;border-radius:16px;color:#0f513f;background:#fff;font-weight:800}.profile-identity{display:grid;min-width:0;gap:3px}.profile-identity h2,.profile-identity p{margin:0}.profile-identity h2{overflow:hidden;font-size:1.2rem;text-overflow:ellipsis;white-space:nowrap}.profile-identity p,.profile-identity span{color:#ffffffc7;font-size:.86rem}.profile-contact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.profile-contact-grid article,.profile-training-panel{border:1px solid #dfe6ee;border-radius:10px;background:#fff;box-shadow:0 10px 24px #1f29370d}.profile-contact-grid article{display:grid;gap:7px;min-width:0;padding:14px;color:var(--app-blue-dark)}.profile-contact-grid span{color:#697789;font-size:.78rem}.profile-contact-grid strong{overflow:hidden;color:#17212b;font-size:.84rem;text-overflow:ellipsis;white-space:nowrap}.profile-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));overflow:hidden;border:1px solid #dfe6ee;border-radius:10px;background:#fff;box-shadow:0 10px 24px #1f29370d}.profile-tabs button{min-height:42px;color:#516173;background:#fff;font-size:.82rem;font-weight:750}.profile-tabs button.active{color:#fff;background:linear-gradient(180deg,#5aa4eb,#3f8fdb)}.profile-panel{display:grid;gap:12px}.profile-info-row{display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center;padding:14px;border:1px solid #dfe6ee;border-radius:10px;color:var(--app-blue-dark);background:#fff;box-shadow:0 10px 24px #1f29370d}.profile-info-row div{display:grid;min-width:0;gap:3px}.profile-info-row strong{color:#17212b}.profile-info-row span{color:#697789;font-size:.84rem}.clothing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.clothing-grid article{display:grid;gap:6px;padding:14px;border:1px solid #dfe6ee;border-radius:10px;color:var(--app-blue-dark);background:#fff;box-shadow:0 10px 24px #1f29370d}.clothing-grid span{color:#697789;font-size:.78rem}.clothing-grid strong{color:#17212b;font-size:1rem}.equipment-list{display:grid;overflow:hidden;border:1px solid #dfe6ee;border-radius:10px;background:#fff}.equipment-list article{display:grid;grid-template-columns:28px 1fr auto;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid #eef2f6;color:var(--app-blue-dark)}.equipment-list article:last-child{border-bottom:0}.equipment-list div{display:grid;min-width:0;gap:3px}.equipment-list strong,.equipment-list span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.equipment-list strong{color:#17212b;font-size:.9rem}.equipment-list span{color:#697789;font-size:.78rem}.profile-training-panel{display:grid;gap:14px;padding:16px}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.panel-heading h2,.panel-heading p{margin:0}.panel-heading h2{color:#17212b;font-size:1.05rem}.panel-heading p{color:#697789;font-size:.86rem}.training-grid{display:grid;gap:8px}.training-grid article{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:11px;border:1px solid #e3eaf1;border-radius:8px;background:#f9fbfd}.training-grid div{display:grid;min-width:0;gap:3px}.training-grid strong{overflow:hidden;color:#17212b;font-size:.9rem;text-overflow:ellipsis;white-space:nowrap}.training-grid span{color:#697789;font-size:.78rem}.training-grid small{padding:4px 8px;border-radius:999px;color:#0f513f;background:#dff4ea;font-weight:750}.training-grid small.warn{color:#7a4b00;background:#fff1cb}.auth-loading,.empty-state{display:grid;min-height:180px;place-items:center;padding:24px;color:#607084;text-align:center}.empty-state.compact{min-height:74px;border-top:1px solid #e7edf3}.form-error{margin:0;padding:10px 12px;border-radius:8px;color:#7f1d1d;background:#fee2e2;font-size:.9rem}.login-hint{margin:-6px 0 0;color:#697789;font-size:.82rem}.checkbox-field{display:flex;min-height:48px;flex-direction:row;align-items:center;gap:10px;padding:0 12px;border:1px solid #cfd8e3;border-radius:4px;background:#fff}.checkbox-field input{width:18px;min-height:18px}.work-sites-screen,.work-hours-screen{display:grid;gap:12px;min-height:calc(100vh - 142px);padding:12px;background:#f4f7fa}.work-sites-hero,.work-hours-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:14px;color:#fff;background:linear-gradient(135deg,#2f76d2f5,#0f766eeb),var(--app-blue);box-shadow:0 14px 28px #2f76d233}.work-sites-hero div,.work-hours-hero div{display:grid;gap:4px;min-width:0}.work-sites-hero span,.work-sites-hero p,.work-hours-hero span,.work-hours-hero p{margin:0;color:#ffffffc7;font-size:.86rem}.work-sites-hero h1,.work-hours-hero h1{margin:0;overflow:hidden;font-size:1.45rem;line-height:1.05;text-overflow:ellipsis;white-space:nowrap}.assignment-summary-grid,.hours-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.assignment-summary-grid article,.hours-summary-grid article{display:grid;gap:6px;min-width:0;padding:14px;border:1px solid #dfe6ee;border-radius:12px;color:var(--app-blue-dark);background:#fff;box-shadow:0 10px 24px #1f29370d}.assignment-summary-grid span,.hours-summary-grid span{color:#697789;font-size:.78rem}.assignment-summary-grid strong,.hours-summary-grid strong{color:#17212b;font-size:1.2rem}.assignments-list,.hours-accordion{display:grid;gap:10px}.assignment-card,.hours-month-card{overflow:hidden;border:1px solid #dfe6ee;border-radius:12px;background:#fff;box-shadow:0 10px 24px #1f29370d}.assignment-card{display:grid;gap:13px;padding:15px}.assignment-card-top{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:center;min-width:0}.assignment-icon,.hours-detail-icon{display:flex;align-items:center;justify-content:center;color:var(--app-blue-dark);background:#eef6ff}.assignment-icon{width:44px;height:44px;border-radius:12px}.assignment-card h2{margin:0 0 5px;overflow:hidden;color:#17212b;font-size:1rem;text-overflow:ellipsis;white-space:nowrap}.assignment-status{display:inline-flex;width:fit-content;padding:4px 8px;border-radius:999px;color:#0f513f;background:#dff4ea;font-size:.74rem;font-weight:750}.assignment-status.muted{color:#516173;background:#e8eef5}.assignment-detail,.assignment-dates,.assignment-workers{display:grid;grid-template-columns:20px 1fr;gap:8px;align-items:start;color:#697789;font-size:.86rem}.assignment-actions{display:flex;flex-wrap:wrap;gap:8px}.assignment-actions.prominent{padding:0}.assignment-actions a{display:inline-flex;min-height:34px;align-items:center;gap:7px;padding:0 10px;border-radius:999px;color:var(--app-blue-dark);background:#eef6ff;font-size:.8rem;font-weight:800}.assignment-detail-button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;border-radius:10px;color:#fff;background:linear-gradient(180deg,#5aa4eb,#3f8fdb);font-size:.86rem;font-weight:800}.assignment-workers>div{display:flex;flex-wrap:wrap;gap:6px}.assignment-workers span,.assignment-workers small{display:inline-flex;min-height:26px;align-items:center;padding:0 8px;border-radius:999px;color:#516173;background:#e8eef5;font-size:.76rem;font-weight:700}.work-site-workers{display:flex;flex-wrap:wrap;gap:8px;padding:14px}.work-site-workers span{display:inline-flex;min-height:30px;align-items:center;padding:0 10px;border-radius:999px;color:#516173;background:#e8eef5;font-size:.8rem;font-weight:750}.work-site-log-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:13px 14px;border-bottom:1px solid #eef2f6}.work-site-log-row:last-child{border-bottom:0}.work-site-log-row div{display:grid;min-width:0;gap:3px}.work-site-log-row strong,.work-site-log-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-site-log-row strong{color:#17212b;font-size:.9rem}.work-site-log-row span{color:#697789;font-size:.78rem}.assignment-progress,.hours-meter{overflow:hidden;height:7px;border-radius:999px;background:#e8eef5}.assignment-progress span,.hours-meter span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#5aa4eb,#0f766e)}.hours-month-trigger{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;width:100%;min-height:68px;padding:14px;color:#17212b;background:#fff;text-align:left}.hours-month-trigger div{display:grid;min-width:0;gap:4px}.hours-month-trigger span{color:#697789;font-size:.78rem}.hours-month-trigger strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hours-month-trigger small{padding:6px 9px;border-radius:999px;color:var(--app-blue-dark);background:#eef6ff;font-weight:800;white-space:nowrap}.hours-month-trigger svg{color:#697789;transition:transform .14s ease}.hours-month-trigger svg.open{transform:rotate(180deg)}.hours-meter{margin:0 14px 12px}.hours-detail-list{display:grid;border-top:1px solid #e7edf3}.hours-detail-row{display:grid;grid-template-columns:38px 1fr auto;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid #eef2f6}.hours-detail-row:last-child{border-bottom:0}.hours-detail-icon{width:38px;height:38px;border-radius:10px}.hours-detail-row div:nth-child(2){display:grid;min-width:0;gap:3px}.hours-detail-row strong{overflow:hidden;color:#17212b;font-size:.9rem;text-overflow:ellipsis;white-space:nowrap}.hours-detail-row span{overflow:hidden;color:#697789;font-size:.78rem;text-overflow:ellipsis;white-space:nowrap}.hours-detail-side{display:grid;justify-items:end;gap:5px}.hours-detail-side strong{color:var(--app-blue-dark);white-space:nowrap}
