:root{--bg:#f7f8f7;--panel:#ffffff;--panel-soft:#eef3f1;--text:#17201d;--muted:#68736f;--line:#d9e1de;--accent:#ff6600;--accent-dark:#cf4e00;--ok:#13795b;--warn:#a15c00;--danger:#b42318}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:#111815;color:#f5f7f6;padding:22px}.brand{display:flex;align-items:center;gap:12px;margin-bottom:30px}.brand-logo{background:#ffffff;border-radius:4px;display:block;height:auto;padding:6px;width:118px}.brand small{display:block;color:#aeb8b4;margin-top:3px}nav{grid-gap:6px;gap:6px}nav,nav a{display:grid}nav a{border-radius:6px;color:#dce3e0;grid-gap:2px;gap:2px;padding:10px 12px}nav a:hover{background:#26322e}nav a span{font-size:14px;font-weight:700;line-height:1.1}nav a small{color:#aeb8b4;font-size:12px;line-height:1.15}.sidebar-footer{border-top:1px solid #2b3834;display:grid;grid-gap:12px;gap:12px;margin-top:28px;padding-top:18px}.sidebar-footer small{color:#aeb8b4;display:block;margin-top:4px}.sidebar-logout{background:#ffffff;color:#111815;width:100%}.content{padding:28px;min-width:0}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}.page-header h1{font-size:28px;line-height:1.2;margin:0 0 6px}.page-header p{color:var(--muted);font-size:14px;line-height:1.35;margin:0}.grid{display:grid;grid-gap:16px;gap:16px}.metrics{grid-template-columns:repeat(4,minmax(0,1fr))}.two-col{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr)}.metric-card,.panel,.table-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px}.metric-card{padding:18px}.metric-card small,.metric-card span{color:var(--muted);display:block}.metric-card strong{display:block;font-size:30px;margin:8px 0}.project-overview{display:grid;grid-gap:16px;gap:16px;margin-bottom:16px}.project-kpis{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.project-kpis div{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px 16px}.project-kpis span{color:var(--muted);display:block;font-size:13px;margin-bottom:6px}.project-kpis strong{display:block;font-size:24px}.gantt-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:18px}.gantt-head{align-items:flex-start;display:flex;justify-content:space-between;gap:14px;margin-bottom:16px}.gantt-head h2{font-size:18px;margin:0 0 4px}.gantt-head p{color:var(--muted);margin:0}.today-pill{background:var(--panel-soft);border:1px solid var(--line);border-radius:999px;color:#35413d;font-size:13px;font-weight:700;padding:7px 10px;white-space:nowrap}.gantt-list{display:grid;grid-gap:12px;gap:12px}.gantt-row{display:grid;grid-gap:14px;gap:14px;grid-template-columns:minmax(180px,.8fr) minmax(260px,1.7fr) minmax(220px,1fr);align-items:center}.gantt-info small,.gantt-info span,.gantt-info strong{display:block}.gantt-info span{margin-top:3px}.gantt-info small{color:var(--muted);margin-top:4px}.gantt-track{background:#edf2f0;border:1px solid var(--line);height:18px;position:relative}.gantt-bar,.gantt-track{border-radius:999px;overflow:hidden}.gantt-bar{background:#26322e;height:100%;left:var(--gantt-offset);position:absolute;top:0;width:var(--gantt-width)}.gantt-progress{background:var(--accent);display:block;height:100%;width:var(--progress-width)}.gantt-stats{align-items:center;display:flex;flex-wrap:wrap;gap:7px}.gantt-stats span:not(.badge){background:#f5f7f6;border:1px solid var(--line);border-radius:999px;color:#35413d;font-size:12px;font-weight:700;padding:4px 8px}.panel{padding:18px}.panel h2{font-size:18px;margin:0 0 14px}.table-panel{overflow-x:auto;-webkit-overflow-scrolling:touch}table{border-collapse:collapse;min-width:720px;width:100%}td,th{border-bottom:1px solid var(--line);padding:12px 14px;text-align:left;vertical-align:top}th{background:var(--panel-soft);color:#35413d;font-size:13px}.badge{border-radius:999px;display:inline-block;font-size:12px;font-weight:700;padding:4px 8px}.badge.ok{background:#dff4ec;color:var(--ok)}.badge.warn{background:#fff0d7;color:var(--warn)}.badge.danger{background:#fde3df;color:var(--danger)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px}label{display:grid;grid-gap:6px;gap:6px;color:#394642;font-size:14px;font-weight:700}input,select,textarea{border:1px solid var(--line);border-radius:6px;color:var(--text);font:inherit;padding:10px 11px;width:100%}textarea{min-height:96px;resize:vertical}.span-2{grid-column:span 2}.button-row{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.user-config-form{display:grid;grid-gap:20px;gap:20px}.permissions-panel{border-top:1px solid var(--line);padding-top:18px}.permissions-panel h2{font-size:18px;margin:0 0 14px}.permissions-grid{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.check-row{align-items:center;border:1px solid var(--line);border-radius:6px;display:flex;flex-direction:row;font-weight:700;gap:9px;padding:10px 12px}.check-row input{width:auto}.form-note{color:var(--muted);font-size:13px;margin:12px 0 0}.button,button{background:var(--accent);border:0;border-radius:6px;color:white;cursor:pointer;font:inherit;font-weight:700;padding:10px 14px}.login-page{align-items:center;background:#ffffff;display:grid;min-height:100vh;padding:24px;place-items:center}.login-form{display:grid;grid-gap:22px;gap:22px;justify-items:stretch;max-width:360px;width:100%}.login-logo{display:block;height:auto;margin:0 auto 12px;width:min(320px,100%)}.login-fields{display:grid;grid-gap:14px;gap:14px}.login-error{color:var(--danger);font-size:14px;font-weight:700;margin:-4px 0 0;text-align:center}.button.secondary,button.secondary{background:#293632}.button.danger,button.danger{background:var(--danger)}button:disabled{cursor:not-allowed;opacity:.45}.danger-zone{align-items:center;display:flex;justify-content:space-between;gap:16px;margin-top:16px}.danger-zone h2{color:var(--danger)}.danger-zone p{color:var(--muted);margin:0}.unit-quick-grid{display:grid;grid-gap:16px;gap:16px;grid-template-columns:minmax(0,1fr) 280px}.unit-hero-panel{display:grid;grid-gap:18px;gap:18px}.unit-hero-panel h2{font-size:24px;margin-top:12px}.unit-hero-panel p{color:var(--muted);margin:0}.unit-stats{display:grid;grid-gap:10px;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.unit-stats div{background:var(--panel-soft);border-radius:6px;padding:12px}.unit-stats strong{display:block;font-size:24px}.unit-stats span{color:var(--muted);font-size:13px}.unit-actions{display:flex;flex-wrap:wrap;gap:10px}.qr-panel{display:grid;grid-gap:10px;gap:10px;justify-items:center;text-align:center}.qr-panel img{border:1px solid var(--line);border-radius:6px;max-width:220px;width:100%}.qr-panel small{color:var(--muted);overflow-wrap:anywhere}.attachments-fieldset,.consumables-fieldset{border:1px solid var(--line);border-radius:8px;margin:0;padding:14px}.attachments-fieldset legend,.consumables-fieldset legend{color:#394642;font-size:14px;font-weight:700;padding:0 6px}.consumable-row,.consumables-header{display:grid;grid-gap:10px;gap:10px;grid-template-columns:minmax(150px,.9fr) minmax(220px,1.4fr) minmax(90px,.45fr) 38px}.consumables-header{color:var(--muted);font-size:12px;font-weight:700;margin-bottom:8px}.consumable-row{align-items:end;margin-bottom:10px}.consumable-row label span{display:none}.icon-button{align-items:center;display:inline-flex;height:38px;justify-content:center;padding:0;width:38px}.icon-button.danger{background:#6f2a22}.icon-button:disabled{cursor:not-allowed;opacity:.45}.add-line{margin-top:2px}.attachment-row{align-items:end;display:grid;grid-gap:10px;gap:10px;grid-template-columns:minmax(220px,1fr) minmax(220px,1.1fr) 38px;margin-bottom:10px}@media (max-width:900px){.app-shell{display:block;grid-template-columns:1fr}.sidebar{box-shadow:0 8px 22px rgba(0,0,0,.16);position:-webkit-sticky;position:sticky;top:0;z-index:10;padding:max(10px,env(safe-area-inset-top)) 12px 10px}.brand{gap:10px;margin-bottom:10px}.brand-logo{padding:5px;width:88px}.brand strong{display:block;font-size:14px;line-height:1.1}.brand small{font-size:11px;line-height:1.15}nav{display:flex;gap:6px;margin:0 -12px;overflow-x:auto;padding:0 12px 8px;scroll-snap-type:x proximity;scrollbar-width:none}nav::-webkit-scrollbar{display:none}nav a{background:#1a2420;border:1px solid #293632;flex:0 0 auto;min-width:92px;padding:9px 10px;scroll-snap-align:start;white-space:nowrap}nav a span{font-size:11px;letter-spacing:0}nav a small{font-size:10px;max-width:96px;overflow:hidden;text-overflow:ellipsis}.sidebar-footer{align-items:center;border-top-color:#22302b;display:grid;grid-gap:10px;gap:10px;grid-template-columns:minmax(0,1fr) 112px;margin-top:8px;padding-top:10px}.sidebar-footer strong{display:block;font-size:15px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer small{font-size:12px;line-height:1.25;margin-top:2px}.sidebar-logout{min-height:40px;padding:9px 10px}.content{padding:18px 14px 28px}.page-header{align-items:stretch;display:grid;grid-gap:12px;gap:12px;margin-bottom:16px}.page-header h1{font-size:24px;line-height:1.15}.page-header p{font-size:13px}.page-header .button,.page-header button{justify-self:stretch;text-align:center;width:100%}.attachment-row,.consumable-row,.consumables-header,.form-grid,.gantt-row,.metrics,.project-kpis,.two-col,.unit-quick-grid,.unit-stats{grid-template-columns:1fr}.consumables-header{display:none}.consumable-row label span{display:inline}.span-2{grid-column:span 1}.grid{gap:12px}.gantt-panel,.metric-card,.panel,.project-kpis div,.table-panel{border-radius:7px}.metric-card{padding:16px 14px}.metric-card strong{font-size:28px;margin:6px 0}.panel{padding:16px 14px}.gantt-head h2,.panel h2{font-size:17px}.table-panel{margin-left:-2px;margin-right:-2px;max-width:calc(100vw - 24px);position:relative}.table-panel:after{background:linear-gradient(90deg,rgba(247,248,247,0),var(--bg));bottom:0;content:"";pointer-events:none;position:absolute;right:0;top:0;width:22px}table{min-width:640px}td,th{font-size:13px;padding:10px 11px}th{font-size:12px}.button-row,.danger-zone,.table-actions,.unit-actions{align-items:stretch;flex-direction:column}.button-row .button,.button-row button,.danger-zone .button,.danger-zone button,.table-actions .button,.table-actions button,.unit-actions .button,.unit-actions button{text-align:center;width:100%}.button,button,input,select,textarea{min-height:42px}.gantt-panel{padding:16px 14px}.gantt-head{display:grid;grid-gap:10px;gap:10px}.today-pill{justify-self:start}.gantt-row{border-top:1px solid var(--line);gap:10px;padding-top:12px}.gantt-row:first-child{border-top:0;padding-top:0}.gantt-track{height:22px}.gantt-stats{gap:6px}.permissions-grid{grid-template-columns:1fr}.unit-stats div{padding:12px 14px}.qr-panel img{max-width:180px}}@media (max-width:520px){.sidebar{padding-left:10px;padding-right:10px}.brand{align-items:center}.brand-logo{width:78px}nav{margin-left:-10px;margin-right:-10px;padding-left:10px;padding-right:10px}nav a{min-width:84px;padding:8px 9px}.sidebar-footer{grid-template-columns:1fr}.content{padding:16px 12px 24px}.page-header h1{font-size:23px}.project-kpis div{padding:13px 14px}.project-kpis strong{font-size:22px}.table-panel{max-width:calc(100vw - 20px)}table{min-width:600px}}