*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--bg:#f6f7f9;--ink:#17202a;--sub:#667085;--line:#d8dde6;--card:#fff;--orange:#f97316;--green:#15803d;--red:#b42318;--blue:#2563eb;--dark:#111827}
html,body{width:100%;overflow-x:hidden}
body{min-height:100vh;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",sans-serif}
.shell{width:100%;max-width:1080px;margin:0 auto;padding:22px 20px}
.top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;padding-top:4px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand>div:last-child{min-width:0}
.mark{width:42px;height:42px;border-radius:8px;background:var(--dark);color:#fff;display:grid;place-items:center;font-weight:900}
h1{font-size:28px;line-height:1.18;overflow-wrap:break-word}
.sub{font-size:14px;color:var(--sub);margin-top:4px}
.pill{border:1px solid var(--line);border-radius:999px;background:#fff;padding:9px 12px;color:var(--sub);font-size:13px}
.grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}
.panel{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:0 1px 2px rgba(16,24,40,.04);min-width:0;overflow:hidden}
.home-card{min-height:220px;display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;color:inherit;min-width:0}
.home-card strong{display:block;font-size:24px;overflow-wrap:break-word}
.home-card span{color:var(--sub);display:block;margin-top:8px;line-height:1.4;overflow-wrap:anywhere}
.home-card b{display:block;font-size:48px;color:var(--orange)}
.home-card .btn{display:block;width:100%;white-space:normal}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.field{min-width:0}
label{display:block;font-size:12px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;line-height:1.2}
select,input,textarea{width:100%;min-width:0;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);font-size:20px;padding:14px 16px;outline:none}
.static-field{width:100%;min-height:53px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;color:var(--ink);font-size:20px;font-weight:800;line-height:1.2;padding:14px 16px;display:block;white-space:normal;overflow-wrap:anywhere;word-break:break-word}
select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--sub) 50%),linear-gradient(135deg,var(--sub) 50%,transparent 50%);background-position:calc(100% - 18px) 52%,calc(100% - 12px) 52%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px;text-overflow:ellipsis}
textarea{min-height:86px;resize:vertical;font-size:16px}
select:focus,input:focus,textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(249,115,22,.14)}
.actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
button,.btn{border:0;border-radius:8px;padding:18px 20px;font-size:22px;font-weight:800;color:#fff;background:var(--orange);cursor:pointer;text-align:center;text-decoration:none}
button:active,.btn:active{transform:scale(.99)}
.btn-dark{background:var(--dark)}
.btn-green{background:var(--green)}
.btn-red{background:var(--red)}
.btn-blue{background:var(--blue)}
.btn-light{background:#eef2f7;color:var(--ink)}
.status{min-height:54px;margin:14px 0 0;padding:14px 16px;border-radius:8px;background:#f8fafc;border:1px solid var(--line);color:var(--sub);font-weight:700}
.status.ok{background:#ecfdf3;border-color:#abefc6;color:#067647}
.status.bad{background:#fef3f2;border-color:#fecdca;color:#b42318}
.list{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow:auto;padding-right:2px}
.item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;border:1px solid var(--line);border-radius:8px;padding:12px;background:#fff;min-width:0}
.item strong{display:block;font-size:17px}
.item span{display:block;color:var(--sub);font-size:13px;margin-top:3px;line-height:1.25}
.qty{font-size:28px;font-weight:900;color:var(--dark);text-align:right}
.low .qty{color:var(--red)}
.pin{position:fixed;inset:0;background:rgba(17,24,39,.92);display:none;align-items:center;justify-content:center;padding:20px;z-index:10}
.pin.open{display:flex}
.pin .panel{max-width:360px;width:100%}
.app-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:300px}
.app-switch a{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);font-size:14px;font-weight:800;text-decoration:none;text-align:center;padding:11px 10px;line-height:1.2}
.app-switch a.active{background:var(--dark);border-color:var(--dark);color:#fff}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.toolbar .btn,.toolbar button{font-size:16px;padding:12px 16px}
.view-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:320px}
.view-switch button{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);font-size:18px;padding:14px 16px}
.view-switch button.active{background:var(--dark);border-color:var(--dark);color:#fff}
.range-toolbar{display:grid;grid-template-columns:minmax(330px,.95fr) minmax(340px,1fr) minmax(210px,.55fr);gap:12px;align-items:end;margin-bottom:14px}
.range-switch{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.range-switch button{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);font-size:15px;padding:13px 10px}
.range-switch button.active{background:var(--blue);border-color:var(--blue);color:#fff}
.date-range{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.date-range input{font-size:16px;padding:12px}
.employee-range-filter select{font-size:16px;padding:12px 36px 12px 14px}
.dashboard-panel[hidden]{display:none}
.tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}
.tabs button{font-size:16px;padding:15px 12px;background:#eef2f7;color:var(--ink);min-height:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-align:center;line-height:1.15}
.tabs button strong{overflow-wrap:anywhere}
.tabs button span{display:block;font-size:13px;font-weight:700;color:var(--sub)}
.tabs button.active{background:var(--dark);color:#fff}
.tabs button.active span{color:#fff}
.action-tabs button:first-child.active{background:var(--blue)}
.action-tabs button:nth-child(2).active{background:var(--green)}
.hint{font-size:12px;color:var(--sub);margin:-4px 0 12px;line-height:1.35}
.material-form{display:flex;flex-direction:column;gap:12px}
.material-form .row,.material-form .tabs,.material-form .hint,.material-form .status{margin-bottom:0}
.material-form label{min-height:15px}
.material-row{grid-template-columns:minmax(0,1.45fr) minmax(140px,.75fr)}
.submit-btn{width:100%;margin-top:0}
.admin-shell{max-width:1180px}
.section-title{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:14px}
.section-title h2{font-size:22px;line-height:1.15}
.section-title span{color:var(--sub);font-size:13px;text-align:right}
.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.metric{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:14px;min-height:112px;display:flex;flex-direction:column;justify-content:space-between}
.metric span{color:var(--sub);font-size:12px;font-weight:800;text-transform:uppercase}
.metric strong{font-size:28px;line-height:1.05;color:var(--dark)}
.metric small{color:var(--sub);font-size:13px}
.admin-list{max-height:430px}
.checkin-title{margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}
.live-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:4px}
.live-card{border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px;min-height:112px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}
.live-card strong{display:block;font-size:18px;line-height:1.15}
.live-card span{display:block;color:var(--sub);font-size:13px;line-height:1.3;margin-top:4px}
.live-card .status-badge{align-self:flex-start}
.timesheet-head,.timesheet-row{display:grid;grid-template-columns:minmax(170px,1.25fr) repeat(4,minmax(92px,.75fr)) 74px;gap:10px;align-items:center}
.timesheet-head{position:sticky;top:0;z-index:1;border:1px solid var(--line);border-radius:8px 8px 0 0;background:#f8fafc;color:var(--sub);font-size:11px;font-weight:900;text-transform:uppercase;padding:10px 12px;margin-top:2px}
.timesheet-list{display:flex;flex-direction:column;gap:0;max-height:430px;overflow:auto;border:1px solid var(--line);border-top:0;border-radius:0 0 8px 8px}
.timesheet-row{border-top:1px solid var(--line);background:#fff;padding:13px 12px;min-width:0}
.timesheet-row:first-child{border-top:0}
.timesheet-row strong{font-size:17px;line-height:1.15}
.timesheet-row span{display:block;color:var(--sub);font-size:12px;font-weight:700;line-height:1.2;margin-bottom:3px}
.timesheet-row>div:not(.employee-cell) span{display:none}
.timesheet-row .employee-cell span{font-weight:500;margin-top:4px;margin-bottom:0}
.admin-row .qty{min-width:52px;font-size:24px}
.inventory-row{width:100%;color:var(--ink);font:inherit;text-align:left}
.inventory-row:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.manager-material-editor{margin-top:14px;border-top:1px solid var(--line);padding-top:16px}
.section-title.compact{margin-bottom:12px}
.section-title.compact h2{font-size:18px}
.manager-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.manager-actions button{font-size:18px;padding:15px 14px}
.admin-row.status-in{border-color:#86efac;background:#f0fdf4}
.admin-row.status-out{border-color:#fca5a5;background:#fef2f2}
.live-card.status-in,.timesheet-row.status-in{border-color:#86efac;background:#f0fdf4}
.live-card.status-out,.timesheet-row.status-out{border-color:#fecaca;background:#fff}
.timesheet-row.status-neutral{background:#f8fafc}
.admin-row.status-in strong,.admin-row.status-in .status-badge{color:var(--green)}
.admin-row.status-out strong,.admin-row.status-out .status-badge{color:var(--red)}
.live-card.status-in strong,.live-card.status-in .status-badge,.timesheet-row.status-in .employee-cell strong,.timesheet-row.status-in .status-badge{color:var(--green)}
.live-card.status-out .status-badge,.timesheet-row.status-out .status-badge{color:var(--red)}
.timesheet-row.status-neutral .status-badge{color:var(--blue)}
.status-badge{min-width:58px;align-self:center;border-radius:999px;padding:7px 10px;background:#fff;font-size:16px;font-weight:900;text-align:center;box-shadow:inset 0 0 0 1px currentColor}
@media(max-width:1100px){.live-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.timesheet-head,.timesheet-row{grid-template-columns:minmax(160px,1fr) repeat(3,minmax(88px,.7fr)) 68px}.timesheet-head span:nth-child(5),.timesheet-row>div:nth-child(5){display:none}}
@media(max-width:900px){.app-switch{min-width:0;width:100%;grid-template-columns:1fr}.metric-grid{grid-template-columns:1fr 1fr}.section-title{align-items:flex-start;flex-direction:column}.section-title span{text-align:left}.live-grid{grid-template-columns:1fr 1fr}.range-toolbar{grid-template-columns:1fr 1fr}.employee-range-filter{grid-column:1/-1}.timesheet-head{display:none}.timesheet-list{border-top:1px solid var(--line);border-radius:8px}.timesheet-row{grid-template-columns:1fr auto;gap:12px}.timesheet-row>div:not(.employee-cell):not(.status-badge){display:none}}
@media(max-width:820px){.grid{grid-template-columns:1fr}.list{max-height:360px}}
@media(max-width:760px){.shell{padding:16px 14px;overflow:hidden}.row,.actions,.tabs,.material-row,.manager-actions,.range-toolbar,.date-range{grid-template-columns:1fr}h1{font-size:22px}.top{align-items:flex-start;flex-direction:column}.pill{width:100%;text-align:center}button,.btn{font-size:20px}.static-field{font-size:18px}.metric-grid{grid-template-columns:1fr}.toolbar{align-items:stretch;flex-direction:column}.toolbar .btn,.toolbar button,.view-switch{width:100%}.view-switch{min-width:0}.range-switch{grid-template-columns:1fr 1fr}.live-grid{grid-template-columns:1fr}}
