:root{--bg:#F3F3F3;--card:#fff;--text:#1b1b1b;--muted:#707070;--border:rgba(0,0,0,.08);--primary:#79BA56;--secondary:#ED671B;--danger:#dc2626;--warn:#d97706;--ok:#15803d;--shadow:0 14px 32px rgba(0,0,0,.10)}
*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial}.wrap{max-width:1640px;margin:0 auto;padding:18px}.top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}.title{display:flex;align-items:center;gap:12px}.logo{width:42px;height:42px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-weight:1000;font-size:22px;box-shadow:var(--shadow);cursor:pointer}h1{font-size:20px;margin:0}.subline{margin-top:2px;color:var(--muted);display:flex;gap:8px;align-items:center;flex-wrap:wrap}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.mini{font-size:12px;color:var(--muted)}.muted{color:var(--muted)}.btn{background:var(--primary);color:#fff;border:none;border-radius:14px;padding:10px 12px;font-weight:900;cursor:pointer;box-shadow:0 10px 18px rgba(121,186,86,.22)}.btn.secondary{background:#fff;color:var(--text);border:1px solid var(--border);box-shadow:none}.btn:active,.pageTab:active,.companyOption:active{transform:translateY(1px)}.sel,input{border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);padding:10px 12px;font-weight:800;outline:none}.search{min-width:260px}.pill{background:#fff;border:1px solid var(--border);border-radius:999px;padding:6px 10px;color:var(--muted);font-size:12px}.meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:6px 0 14px}.hidden{display:none!important}.card{background:var(--card);border-radius:22px;padding:16px;border:1px solid var(--border);box-shadow:var(--shadow)}.k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.10em}.kk{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.10em}.v{font-size:34px;font-weight:1000;margin-top:4px}.sub{margin-top:4px;color:var(--muted);font-weight:750}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-top:12px}.wide{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}.wideHead{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.wideHead h2{margin:6px 0 0;font-size:16px}.wideHint{color:var(--muted);font-size:12px}.pageTabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}.pageTab{appearance:none;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:999px;padding:9px 13px;font-weight:950;cursor:pointer}.pageTab.isActive{background:var(--primary);color:#fff;border-color:rgba(121,186,86,.35);box-shadow:0 10px 18px rgba(121,186,86,.18)}.metric{cursor:pointer;position:relative;overflow:hidden}.metric:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--primary)}.metric.warn:before{background:var(--warn)}.metric.danger:before{background:var(--danger)}.metric:hover{transform:translateY(-1px)}.helpLine{display:flex;align-items:center;gap:6px}.help{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:#fff;color:var(--muted);font-size:12px;font-weight:1000;cursor:pointer}.help:hover{color:#fff;background:var(--primary);border-color:var(--primary)}.tableWrap{margin-top:12px;overflow:auto;width:100%;border-radius:18px;border:1px solid rgba(0,0,0,.06);background:rgba(255,255,255,.65)}table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}thead th{position:sticky;top:0;z-index:2;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08);text-align:left;white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.06);white-space:nowrap;vertical-align:middle}tbody tr:hover td{background:rgba(0,0,0,.035)}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.linkBtn{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:#111;font-weight:950}.openBtn{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:999px;background:rgba(0,0,0,.05);color:#111;text-decoration:none;font-weight:950}.status{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-weight:950;font-size:12px;border:1px solid transparent}.status.ok{background:rgba(21,128,61,.12);color:#166534;border-color:rgba(21,128,61,.20)}.status.warn{background:rgba(217,119,6,.14);color:#a16207;border-color:rgba(217,119,6,.22)}.status.bad{background:rgba(220,38,38,.12);color:#b91c1c;border-color:rgba(220,38,38,.22)}.status.neutral{background:rgba(0,0,0,.05);color:#333;border-color:rgba(0,0,0,.08)}.tag{display:inline-flex;margin:0 4px 4px 0;padding:4px 8px;border-radius:999px;background:rgba(0,0,0,.06);font-size:11px;font-weight:900}.tag.sk{background:rgba(121,186,86,.16);color:#2f641d}.tag.cz{background:rgba(237,103,27,.16);color:#9a3412}.tag.b2b{background:rgba(59,130,246,.14);color:#1d4ed8}.tag.kdd{background:rgba(168,85,247,.14);color:#7e22ce}.deadline{font-weight:950}.deadline.late{color:var(--danger)}.deadline.soon{color:var(--warn)}.cfg{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}.cfg input{min-width:220px}.cfg #odooUrl{min-width:360px}.err{color:#b91c1c;font-size:12px;margin-left:6px}.companyModePill{background:linear-gradient(90deg,#79BA56,#ED671B);color:#fff;border:none;font-weight:900}.companyChooser{margin:6px 0 14px;padding:14px;border:1px solid var(--border);border-radius:22px;background:rgba(255,255,255,.92);box-shadow:var(--shadow)}.companyChooserHead{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.companyOptions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}.companyOption{appearance:none;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:18px;padding:12px;display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer}.companyOption b{display:block;font-size:13px}.companyOption small{display:block;color:var(--muted);font-size:11px;margin-top:2px}.companyOption.isActive{box-shadow:0 0 0 4px rgba(121,186,86,.12)}.companyDot{width:14px;height:14px;border-radius:999px;flex:0 0 14px}.companyDotHbt{background:#79BA56}.companyDotGld{background:#ED671B;box-shadow:inset 0 0 0 4px #651317}.companyDotAll{background:linear-gradient(90deg,#79BA56,#ED671B)}body.company-1{--bg:#F3F3F3;--primary:#79BA56;--secondary:#DFB655}body.company-2{--bg:#DAD1C1;--primary:#ED671B;--secondary:#651317;--shadow:0 12px 26px rgba(101,19,23,.12)}body.company-all{--primary:#79BA56;--secondary:#ED671B;background:radial-gradient(circle at 8% 4%,rgba(121,186,86,.24),transparent 36%),radial-gradient(circle at 92% 8%,rgba(237,103,27,.22),transparent 38%),linear-gradient(135deg,rgba(121,186,86,.075),rgba(237,103,27,.085)),#F3F3F3!important;background-attachment:fixed}.chart{margin-top:12px}.chart svg{width:100%;height:260px;display:block}.chart .axis{stroke:rgba(0,0,0,.12)}.chart .label{fill:rgba(0,0,0,.58);font-size:11px;font-weight:800}.chart .bar{fill:var(--primary);opacity:.72}.chart .bar.alt{fill:var(--secondary)}.chart .bar:hover{opacity:1}.chart .barVal{fill:#111;font-size:11px;font-weight:950}.statsGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.loader{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.70);backdrop-filter:blur(8px)}.loaderCard{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:#fff;border:1px solid var(--border);box-shadow:0 18px 40px rgba(0,0,0,.15)}.spinner{width:26px;height:26px;border-radius:999px;border:3px solid rgba(0,0,0,.10);border-top-color:var(--primary);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loaderTitle{font-weight:950;font-size:20px}.loaderSub{color:var(--muted);font-size:12px}.modal{position:fixed;inset:0;z-index:100000;display:flex;align-items:center;justify-content:center;padding:20px}.modalBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.28);backdrop-filter:blur(4px)}.modalCard{position:relative;z-index:1;width:min(720px,100%);background:#fff;border:1px solid var(--border);border-radius:24px;box-shadow:0 24px 60px rgba(0,0,0,.18);padding:20px}.modalHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.modalHead h2{margin:6px 0 0;font-size:24px}.modalBody{margin-top:16px;color:#333;line-height:1.65}.modalBody ul{margin:8px 0 0;padding-left:20px}.emptyNote{padding:14px;border-radius:16px;border:1px dashed rgba(0,0,0,.16);background:rgba(255,255,255,.65);color:var(--muted)}@media(max-width:900px){.statsGrid{grid-template-columns:1fr}.companyOptions{grid-template-columns:1fr}.search,.cfg #odooUrl{min-width:100%}.wrap{padding:14px}.v{font-size:28px}.chart svg{height:220px}} 

/* --- Production cockpit v1.1 additions --- */
.logo{display:inline-flex;align-items:center;justify-content:center;padding:0;overflow:hidden}
.logo img{width:100%;height:100%;display:block;object-fit:cover}
.iconBtn{appearance:none;border:none;display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:32px;padding:0 9px;border-radius:999px;background:rgba(0,0,0,.055);color:#111;text-decoration:none;font-weight:1000;cursor:pointer;font-size:16px;line-height:1}
.iconBtn:hover{background:rgba(0,0,0,.10)}
.clickableStatus{appearance:none;border:1px solid transparent;cursor:pointer;font-family:inherit}
.clickableStatus:hover{filter:brightness(.97);transform:translateY(-1px)}
.modalTable{max-height:60vh;overflow:auto;margin-top:8px}
.modalTable table{font-size:13px}
.footer{max-width:1640px;margin:16px auto 22px;padding:0 18px;color:var(--muted);font-size:12px;text-align:center}
.status.neutral.clickableStatus{background:rgba(0,0,0,.045)}
@media(max-width:900px){.modalTable{max-height:58vh}.iconBtn{min-width:32px;height:30px}}

/* --- Production cockpit v1.2 usability fixes --- */
html,body{min-height:100%;}
body{min-height:100vh;}
body.company-all::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(circle at 18% 85%,rgba(121,186,86,.12),transparent 32%),radial-gradient(circle at 82% 78%,rgba(237,103,27,.11),transparent 34%)}
.meta{display:none}
.prodTable{table-layout:fixed;min-width:1180px}
.prodTable th,.prodTable td{padding:9px 10px;overflow:hidden;text-overflow:ellipsis}
.prodTable .c-deadline{width:110px}.prodTable .c-order{width:140px}.prodTable .c-customer{width:150px}.prodTable .c-company{width:64px}.prodTable .c-type{width:115px}.prodTable .c-ral{width:82px}.prodTable .c-tags{width:100px}.prodTable .c-proj{width:145px}.prodTable .c-mrp{width:150px}.prodTable .c-mat{width:70px}.prodTable .c-status{width:116px}.prodTable .c-icon{width:48px}
.truncate{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.orderMainRow{cursor:pointer}
.orderMainRow:hover td{background:rgba(121,186,86,.045)!important}
.orderDetailRow td{background:rgba(255,255,255,.72)!important;padding:0 12px 12px!important;white-space:normal;overflow:visible}
.orderDetailBox{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:12px;background:rgba(0,0,0,.018)}
.detailHead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.innerTable{width:100%;table-layout:fixed;background:#fff;border-radius:12px;overflow:hidden}
.innerTable th,.innerTable td{white-space:normal;padding:8px 10px}
.clickableRow{cursor:pointer}.clickableRow:hover td{background:rgba(121,186,86,.06)!important}
.weekBarGroup{cursor:pointer}.weekBarGroup.isCurrent .bar{stroke:#111;stroke-width:3;opacity:.95}.weekNow{fill:#111;font-size:10px;font-weight:1000;text-transform:uppercase;letter-spacing:.08em}.weekBarGroup:hover .bar{opacity:1;filter:brightness(.96)}
.chart .barVal{font-size:10px}.statsGrid .chart .barVal{font-size:11px}
.modalCard{width:min(1120px,96vw)}
.modalTable{max-height:70vh}.attachmentTable table{min-width:920px;table-layout:auto}.attachmentTable th:first-child,.attachmentTable td:first-child{width:80px;text-align:center}
@media(max-width:1300px){.prodTable{min-width:1120px}.prodTable .c-customer{width:135px}.prodTable .c-proj{width:132px}.prodTable .c-mrp{width:140px}}
@media(max-width:900px){.modalCard{width:min(98vw,1120px)}.prodTable{min-width:1080px}}

/* --- Production cockpit v1.3 final day fixes --- */
.prodTable{table-layout:fixed;min-width:0;width:100%}
.prodTable th,.prodTable td{padding:8px 8px;font-size:12.5px}
.prodTable .c-deadline{width:96px}.prodTable .c-order{width:118px}.prodTable .c-customer{width:142px}.prodTable .c-company{width:56px}.prodTable .c-type{width:92px}.prodTable .c-product{width:168px}.prodTable .c-ral{width:76px}.prodTable .c-tags{width:72px}.prodTable .c-proj{width:130px}.prodTable .c-mrp{width:138px}.prodTable .c-mat{width:54px}.prodTable .c-status{width:98px}.prodTable .c-icon{width:42px}
.prodTable .status{font-size:11.5px;padding:5px 8px}.prodTable .iconBtn{min-width:32px;height:30px}.prodTable .mini{font-size:11px}.tag{padding:4px 7px}
.orderMainRow.isDoneRow td{background:rgba(21,128,61,.055)!important}.orderMainRow.isDoneRow:hover td{background:rgba(21,128,61,.095)!important}.orderMainRow.isDoneRow td:first-child{box-shadow:inset 4px 0 0 rgba(21,128,61,.55)}
.innerTable .isDoneRow td{background:rgba(21,128,61,.045)!important}
.detailBadges{margin-top:7px;display:flex;gap:6px;flex-wrap:wrap}.orderDetailBox{background:linear-gradient(180deg,rgba(21,128,61,.035),rgba(255,255,255,.72))}.innerTable{table-layout:fixed}.innerTable th:nth-child(1){width:150px}.innerTable th:nth-child(2){width:auto}.innerTable th:nth-child(3){width:190px}.innerTable th:nth-child(4){width:90px;text-align:center}.innerTable th:nth-child(5){width:150px}.innerTable th:nth-child(6){width:70px}.innerTable td.num,.innerTable th.num{text-align:center}

.modalCard{width:min(1380px,98vw);max-height:90vh;display:flex;flex-direction:column}.modalBody{overflow:auto;max-height:calc(90vh - 112px);padding-right:4px}.modalTable{max-height:68vh;overflow:auto}.weekDetailScroll{max-height:68vh;overflow:auto;border-radius:18px}.weekDetailScroll .prodTable{min-width:1280px}.weekDetailScroll .tableWrap{margin-top:0}
.attachmentTable table{min-width:1060px}.attachmentTable th,.attachmentTable td{white-space:nowrap}.attachmentTable th:nth-child(3),.attachmentTable td:nth-child(3){min-width:420px}

.weekPlanTable{table-layout:fixed;width:100%}.weekPlanTable th,.weekPlanTable td{text-align:center;padding:11px 10px}.weekPlanTable th:first-child,.weekPlanTable td:first-child{text-align:left;width:220px}.weekPlanTable td{font-variant-numeric:tabular-nums}.weekPlanTable tr.isCurrentWeek td{background:rgba(121,186,86,.13)!important}.weekPlanTable tr.isCurrentWeek td:first-child{box-shadow:inset 4px 0 0 var(--primary)}.weekPlanTable tr.hasLateWeek td{background:rgba(220,38,38,.045)}.weekPlanTable tr.hasLateWeek:hover td{background:rgba(220,38,38,.075)!important}.lateBadge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 9px;border-radius:999px;background:rgba(220,38,38,.14);color:#b91c1c;border:1px solid rgba(220,38,38,.22);font-weight:1000}
.weekBarGroup.isCurrent .bar{stroke:#111;stroke-width:3.5;opacity:1}.currentWeekBg{fill:rgba(121,186,86,.13);stroke:rgba(121,186,86,.34);stroke-width:1}.weekBarGroup.hasLate .bar{fill:#dc2626;opacity:.58}.weekBarGroup.hasLate .bar.alt{fill:#dc2626}.weekLate{fill:#b91c1c;font-size:10px;font-weight:1000}.weekNow{fill:#111;font-size:10px;font-weight:1000;text-transform:uppercase;letter-spacing:.08em}.chart .label{font-size:10.5px}
@media(max-width:1250px){.prodTable{min-width:1240px}.tableWrap{overflow:auto}.prodTable th,.prodTable td{font-size:12px}.prodTable .c-product{width:150px}.prodTable .c-customer{width:130px}}
