*{box-sizing:border-box}
:root{
  --navy:#0D3B66;
  --blue:#1565C0;
  --teal:#00796B;
  --green:#2E7D32;
  --orange:#E65100;
  --amber:#E65100;
  --red:#C62828;
  --purple:#6A1B9A;
  --violet:#6A1B9A;
  --cyan:#00796B;
  --gold:#F57F17;
  --bg:#F4F6F9;
  --card:#fff;
  --border:#E0E6ED;
  --ink:#1C2B40;
  --muted:#6B7A90;
  --line:#E0E6ED;
  --soft:#F4F6F9;
  --panel:#fff;
  --shadow:none;
}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}
button,input,select,textarea{font:inherit}
.shell{min-height:100vh;display:flex;align-items:stretch}
.sidebar{width:240px;height:100vh;position:sticky;top:0;background:linear-gradient(180deg,#0B2F55 0%,#0D3B66 100%);color:#fff;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.brand{padding:18px 16px 14px;border-bottom:1px solid rgba(255,255,255,.1)}
.brand strong{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;letter-spacing:0}
.brand strong:before{content:"⛺"}
.brand span{display:block;color:rgba(255,255,255,.4);font-size:10px;margin-top:2px}
nav{padding:8px 0;overflow:auto}
.nav-group{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.3);font-weight:700;padding:14px 16px 4px}
.nav-item{width:calc(100% - 6px);border:0;background:transparent;color:rgba(255,255,255,.62);display:flex;align-items:center;gap:10px;text-align:left;padding:8px 16px;cursor:pointer;border-left:3px solid transparent;border-radius:0 6px 6px 0;margin-right:6px;font-size:13px;transition:all .15s}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:rgba(255,255,255,.14);color:#fff;border-left-color:#4FC3F7}
.nav-icon{width:17px;text-align:center;font-size:14px;flex-shrink:0}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:46px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:8px 22px;position:sticky;top:0;z-index:50;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.topbar h1{font-size:15px;margin:0;font-weight:700}
.topbar p{display:none}
.top-actions{display:flex;gap:7px;align-items:center}
.view{padding:18px 22px 34px;display:flex;flex-direction:column;gap:14px;min-height:calc(100vh - 46px)}
.page-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.page-head h2{font-size:19px;margin:0;font-weight:700}
.page-head p{margin:1px 0 0;color:var(--muted);font-size:12px}
.actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.btn{border:0;border-radius:7px;padding:6px 13px;font-weight:500;cursor:pointer;display:inline-flex;gap:5px;align-items:center;justify-content:center;min-height:0;font-size:13px;white-space:nowrap;transition:all .14s}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn.primary{background:var(--navy);color:#fff}
.btn.success{background:var(--green);color:#fff}
.btn.warn{background:var(--orange);color:#fff}
.btn.danger{background:var(--red);color:#fff}
.btn.secondary{background:transparent;color:#374151;border:1px solid #CBD5E0}
.btn.ghost{background:transparent;color:var(--muted)}
.btn.ghost:hover{color:var(--ink);background:#F1F5F9}
.btn.small{font-size:12px;padding:5px 10px;min-height:0}
.btn.icon{width:30px;padding:0}
.pill{display:inline-flex;align-items:center;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;background:var(--bg);color:var(--muted)}
.badge{display:inline-flex;align-items:center;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;background:#F3F4F6;color:#6B7280}
.badge.ok{background:#DCFCE7;color:#166534}.badge.wait{background:#FEF3C7;color:#92400E}.badge.bad{background:#FEE2E2;color:#991B1B}.badge.info{background:#DBEAFE;color:#1E40AF}.badge.neutral{background:#F3F4F6;color:#6B7280}
.grid{display:grid;gap:12px}
.kpis{grid-template-columns:repeat(5,1fr);gap:11px}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{background:#fff;border:1px solid var(--border);border-radius:11px;box-shadow:none;overflow:hidden}
.card-head{padding:11px 15px;border-bottom:1px solid #F1F5F9;display:flex;justify-content:space-between;align-items:center;gap:10px;background:#FAFBFC}
.card-head h3{font-size:13px;margin:0;font-weight:600}
.card-body{padding:14px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:11px;padding:13px 15px;box-shadow:none;position:relative;overflow:hidden}
.ki{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:7px;flex-shrink:0}
.ki-b{background:#DBEAFE}.ki-g{background:#DCFCE7}.ki-r{background:#FEE2E2}.ki-o{background:#FFEDD5}.ki-p{background:#EDE9FE}.ki-t{background:#CCFBF1}.ki-y{background:#FEF9C3}
.kpi label{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi strong{display:block;margin-top:2px;font-size:19px;font-weight:800;line-height:1.2}
.kpi span{display:block;margin-top:3px;font-size:10px;color:var(--muted)}
.toolbar{background:#fff;border:1px solid var(--border);border-radius:11px;padding:10px 11px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.toolbar input,.toolbar select{width:195px}
input,select,textarea{border:1px solid #D1D5DB;border-radius:7px;padding:7px 10px;background:#fff;color:var(--ink);min-width:0;font-size:13px}
input:focus,select:focus,textarea:focus{outline:none;box-shadow:0 0 0 3px rgba(13,59,102,.1);border-color:var(--navy)}
textarea{resize:vertical;min-height:70px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;background:#fff}
th{font-size:11px;text-align:left;text-transform:none;letter-spacing:0;color:#4A5568;background:#F8FAFC;border-bottom:1px solid var(--border);padding:8px 10px;white-space:nowrap;font-weight:600}
th.sortable{padding:0}
th.sortable button{width:100%;height:100%;border:0;background:transparent;color:inherit;font:inherit;font-weight:700;text-align:left;padding:8px 10px;display:inline-flex;align-items:center;gap:5px;cursor:pointer;white-space:nowrap}
th.sortable button:hover{background:#EEF4FB;color:var(--navy)}
th.sortable.active button{color:var(--navy)}
th.sortable button span{font-size:10px;color:var(--muted)}
th.num.sortable button{justify-content:flex-end;text-align:right}
td{border-bottom:1px solid #F1F5F9;padding:8px 10px;vertical-align:middle}
tr:hover td{background:#FAFCFF}
.num{text-align:right;font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}
.money-ok{color:var(--green);font-weight:750}.money-bad{color:var(--red);font-weight:750}.money-warn{color:var(--amber);font-weight:750}
.payment-debt-cell span{display:block;margin-top:2px;font-size:10px;font-weight:700;text-transform:uppercase}
.payment-debt-cell.is-paid{color:var(--green)}
.payment-debt-cell.is-debt{color:var(--red)}
.payment-row.is-paid td{background:#F7FCF8}
.payment-row.is-debt td{background:#FFF8F8}
.payment-row:hover td{filter:brightness(.985)}
.payment-contract-picker{gap:8px}
.payment-selected{border:1px solid #D1D5DB;border-radius:8px;padding:9px 11px;background:#F8FAFC;color:var(--muted);font-weight:700}
.payment-selected.is-paid{border-color:#A7D7AE;background:#EFFAF1;color:var(--green)}
.payment-selected.is-debt{border-color:#F1AAA7;background:#FFF1F1;color:var(--red)}
.payment-contract-list{display:grid;gap:7px;max-height:260px;overflow:auto;padding-right:3px}
.payment-contract-option{width:100%;border:1px solid #E5E7EB;border-left-width:5px;border-radius:8px;background:#fff;color:var(--ink);display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;text-align:left;padding:9px 10px;cursor:pointer}
.payment-contract-option span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.payment-contract-option strong{font-variant-numeric:tabular-nums}
.payment-contract-option em{font-style:normal;font-size:10px;font-weight:800;text-transform:uppercase;border-radius:20px;padding:3px 8px}
.payment-contract-option.is-paid{border-left-color:var(--green)}
.payment-contract-option.is-paid strong{color:var(--green)}
.payment-contract-option.is-paid em{background:#DCFCE7;color:#166534}
.payment-contract-option.is-debt{border-left-color:var(--red)}
.payment-contract-option.is-debt strong{color:var(--red)}
.payment-contract-option.is-debt em{background:#FEE2E2;color:#991B1B}
.payment-contract-option:hover,.payment-contract-option.selected{border-color:#94A3B8;box-shadow:0 0 0 3px rgba(13,59,102,.08)}
.access-card .table-wrap{max-height:calc(100vh - 240px)}
.access-card table{min-width:2100px}
.access-card th:first-child,.access-card td:first-child{position:sticky;left:0;z-index:2;background:#fff;min-width:220px}
.access-card th:first-child{z-index:3;background:#F8FAFC}
.access-cell{min-width:92px;text-align:center;white-space:nowrap}
.access-cell label{display:inline-flex;align-items:center;gap:3px;margin:0 3px;color:var(--muted);font-size:11px;font-weight:700}
.access-cell input{width:15px;height:15px;padding:0;accent-color:var(--navy)}
.progress{height:6px;border-radius:20px;background:#E5E7EB;overflow:hidden;min-width:60px}
.progress span{display:block;height:100%;background:var(--green);border-radius:99px}
.progress span.mid{background:#D97706}.progress span.low{background:#DC2626}
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:130px 1fr 105px;gap:10px;align-items:center}
.bar-track{height:6px;background:#E5E7EB;border-radius:20px;overflow:hidden}
.bar-fill{height:100%;background:var(--blue);border-radius:99px}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.day-name{font-size:10px;color:var(--muted);font-weight:600;text-align:center;padding:4px}
.day{min-height:72px;background:#fff;border:1px solid var(--border);border-radius:6px;padding:4px 6px;font-size:11px}
.day.today{outline:0;border-color:var(--navy);background:#EFF6FF}
.event{display:block;margin-top:1px;border-radius:3px;padding:1px 4px;background:#DCFCE7;color:#166534;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line)}
.tab{background:transparent;border:0;padding:8px 15px;cursor:pointer;color:var(--muted);font-weight:500;border-bottom:2px solid transparent;font-size:13px}
.tab.active{color:var(--navy);border-bottom-color:var(--navy)}
.overlay{display:none;position:fixed;inset:0;background:rgba(12,20,30,.48);z-index:1000;align-items:center;justify-content:center;padding:18px}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:13px;box-shadow:0 24px 64px rgba(0,0,0,.22);width:min(660px,95vw);max-height:90vh;display:flex;flex-direction:column}
.modal-head,.modal-foot{padding:15px 20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;gap:10px}
.modal-foot{padding:11px 20px;border-top:1px solid #eee;border-bottom:0;justify-content:flex-end;background:#FAFAFA}
.modal-head h3{margin:0;font-size:16px;font-weight:700}
.modal-body{padding:18px;overflow:auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:5px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;font-weight:700;color:#374151}
.section-label{grid-column:1/-1;color:#9CA3AF;font-size:10px;text-transform:uppercase;letter-spacing:.9px;font-weight:700;border-bottom:1px solid #EEE;padding:9px 0 4px}
.toast{position:fixed;right:18px;bottom:18px;background:#12263a;color:#fff;padding:10px 13px;border-radius:8px;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);transition:.18s;z-index:1200}
.toast.show{opacity:1;transform:translateY(0)}
.empty{padding:34px;text-align:center;color:var(--muted)}
.user-pill{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.auth-screen{min-height:calc(100vh - 100px);display:grid;place-items:center;padding:24px}
.auth-panel{width:min(520px,100%);background:#fff;border:1px solid var(--border);border-radius:11px;padding:28px;box-shadow:0 18px 48px rgba(13,59,102,.08);text-align:center}
.auth-mark{width:46px;height:46px;margin:0 auto 14px;border-radius:10px;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:800;letter-spacing:0}
.auth-panel h2{margin:0 0 8px;font-size:24px}
.auth-panel p{margin:0 auto 18px;color:var(--muted);line-height:1.5;max-width:410px}
.auth-login{min-width:210px}
.auth-error{margin:0 auto 16px;padding:10px 12px;border-radius:8px;background:#FEE2E2;color:#991B1B;text-align:left}
.auth-config{display:flex;flex-direction:column;gap:8px;text-align:left}
.auth-config div{border:1px solid var(--border);border-radius:8px;padding:9px 11px;background:#F8FAFC}
.auth-config strong{display:block;font-size:11px;color:#374151;margin-bottom:3px}
.auth-config span{display:block;color:var(--muted);font-size:12px;overflow-wrap:anywhere}
.production-flow{display:grid;grid-template-columns:repeat(7,minmax(118px,1fr));gap:8px;overflow:auto}
.flow-step{border:1px solid var(--border);border-radius:8px;padding:10px;background:#fff;display:flex;flex-direction:column;justify-content:space-between;gap:10px;min-height:94px}
.flow-step strong{display:block;font-size:12px}
.flow-step span{display:block;color:var(--muted);font-size:11px;margin-top:3px}
.production-board{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px}
.production-column{border:1px solid var(--border);border-radius:8px;background:#fff;padding:10px;display:flex;flex-direction:column;gap:9px;min-width:0}
.production-column-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.production-column-head strong{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.production-column-head span{font-size:11px;color:var(--muted);font-weight:700}
.production-stage-list{display:flex;flex-direction:column;gap:5px}
.stage-chip{border:1px solid #E5E7EB;background:#F8FAFC;color:#374151;border-radius:6px;padding:5px 7px;display:flex;justify-content:space-between;gap:8px;cursor:pointer;text-align:left;font-size:11px}
.stage-chip:hover{border-color:#CBD5E0;background:#EFF6FF}
.gantt{min-width:980px;display:flex;flex-direction:column;gap:5px}
.gantt-scale{height:20px;position:relative;margin-left:230px;border-bottom:1px solid var(--border);color:var(--muted);font-size:10px}
.gantt-scale span{position:absolute;top:0;transform:translateX(-1px);text-transform:uppercase}
.gantt-row{display:grid;grid-template-columns:220px 1fr;gap:10px;align-items:center;min-height:30px}
.gantt-label{min-width:0}
.gantt-label strong{display:block;font-size:11px}
.gantt-label span{display:block;color:var(--muted);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gantt-track{height:24px;position:relative;background:repeating-linear-gradient(90deg,#F8FAFC 0,#F8FAFC 56px,#EEF2F7 57px);border:1px solid #E5E7EB;border-radius:6px;overflow:hidden}
.gantt-segment{position:absolute;top:3px;height:16px;border-radius:4px;color:#fff;font-size:9px;line-height:16px;padding:0 5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gantt-segment.design{background:var(--blue)}
.gantt-segment.procurement{background:var(--orange)}
.gantt-segment.production{background:var(--green)}
.gantt-segment.logistics{background:var(--teal)}
.gantt-segment.installation{background:var(--purple)}
.production-app{display:flex;flex-direction:column;gap:14px}
.production-notice{border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-weight:600}
.production-notice.ok{background:#ECFDF5;color:#166534;border-color:#BBF7D0}
.production-notice.bad,.production-warning{background:#FEF2F2;color:#991B1B;border:1px solid #FECACA;border-radius:8px;padding:9px 12px}
.production-warning.full{grid-column:1/-1}
.production-filters input,.production-filters select{width:190px}
.link-button{border:0;background:transparent;color:var(--blue);font-weight:700;cursor:pointer;padding:0;text-align:left}
.link-button:hover{text-decoration:underline}
.actions.compact{gap:5px;flex-wrap:nowrap}
.production-row-overdue td{background:#FFF7F7}
.production-form-card{overflow:visible}
.production-header{overflow:visible}
.production-header h2{margin:2px 0 3px;font-size:21px}
.production-header p{margin:0;color:var(--muted)}
.production-header-grid{display:grid;grid-template-columns:minmax(260px,1.6fr) auto minmax(160px,1fr) auto auto auto auto;gap:14px;align-items:center}
.production-header-grid strong{display:block;margin-top:3px}
.production-tabs{display:flex;gap:4px;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:9px;padding:0 8px}
.production-tab-panel{display:block}
.production-checklist{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.production-check-row{display:grid;grid-template-columns:minmax(230px,1fr) auto minmax(260px,1.2fr);gap:10px;align-items:center;border:1px solid #EEF2F7;border-radius:8px;padding:8px 10px;background:#fff}
.production-check-row label,.check-field{display:flex;align-items:center;gap:8px;font-weight:600;color:#374151}
.check-field{border:1px solid #EEF2F7;border-radius:8px;padding:9px 10px;background:#fff}
.production-inline-form{display:grid;grid-template-columns:1.3fr 1fr 1fr repeat(4,150px) 150px 94px 1fr auto;gap:8px;align-items:end;margin-bottom:12px}
.production-inline-form input,.production-inline-form select{width:100%}
.production-comment-form{display:grid;grid-template-columns:230px 1fr auto;gap:8px;align-items:start;margin-bottom:12px}
.production-comment-form textarea{min-height:42px}
.production-comments{display:flex;flex-direction:column;gap:8px}
.production-comment{border:1px solid #EEF2F7;border-radius:8px;padding:10px 12px;background:#fff}
.production-comment div{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.production-comment span{color:var(--muted);font-size:12px}
.production-comment p{margin:7px 0 0;line-height:1.45}
.production-local-modal{position:fixed;inset:0;background:rgba(12,20,30,.48);z-index:1100;display:flex;align-items:center;justify-content:center;padding:18px}
.production-pill-danger{background:#FEE2E2;color:#991B1B}
.production-kanban-head{align-items:center}
.production-kanban-filters input,.production-kanban-filters select{width:180px}
.production-kanban-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:6px}
.production-kanban-board{display:flex;gap:12px;align-items:flex-start;min-width:max-content}
.production-kanban-skeleton{display:flex;gap:12px;overflow:hidden}
.production-kanban-column{width:310px;min-width:310px;max-height:calc(100vh - 230px);background:#F8FAFC;border:1px solid var(--border);border-radius:9px;display:flex;flex-direction:column;overflow:hidden}
.production-kanban-column.skeleton{height:520px;background:linear-gradient(90deg,#F3F4F6,#E5E7EB,#F3F4F6);background-size:220% 100%}
.production-kanban-column-head{padding:10px 11px 8px;border-bottom:1px solid #E5E7EB;background:#fff;display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.production-kanban-column-head strong{display:block;font-size:13px;line-height:1.25}
.production-kanban-column-head span{display:block;margin-top:4px;color:var(--muted);font-size:11px}
.production-kanban-column-progress{padding:8px 11px;background:#fff;border-bottom:1px solid #EEF2F7}
.production-drop-zone{display:flex;flex-direction:column;gap:8px;padding:10px;overflow-y:auto;min-height:210px}
.production-drop-zone.drag-over{background:#EFF6FF;box-shadow:inset 0 0 0 2px #93C5FD}
.production-kanban-card{background:#fff;border:1px solid #E1E8F0;border-left:4px solid var(--blue);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px;cursor:grab;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.production-kanban-card:hover{border-color:#B6C5D6;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.production-kanban-card.dragging{opacity:.58;cursor:grabbing}
.production-kanban-card.overdue{border-left-color:var(--red);background:#FFF7F7}
.production-kanban-card.due-soon{border-left-color:#D97706}
.production-kanban-card-top{display:flex;justify-content:space-between;gap:8px;align-items:center}
.production-kanban-card-top strong{font-size:13px;color:var(--navy)}
.production-kanban-card-sub,.production-kanban-card-desc{color:var(--muted);font-size:11px;line-height:1.35}
.production-kanban-card-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.production-kanban-client{font-weight:700;line-height:1.3}
.production-kanban-meta{display:flex;justify-content:space-between;gap:8px;color:#374151;font-size:11px}
.production-kanban-meta span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.production-kanban-card-money{font-weight:800;color:#111827}
.production-kanban-card-flags{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.production-kanban-empty{border:1px dashed #CBD5E1;border-radius:8px;background:#fff;color:var(--muted);padding:18px 10px;text-align:center;font-size:12px}
.production-gantt-head{align-items:center}
.production-gantt-head select{width:132px}
.production-gantt-summary{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:9px}
.production-gantt-summary div{background:#fff;border:1px solid var(--border);border-radius:9px;padding:10px 12px}
.production-gantt-summary span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;font-weight:700}
.production-gantt-summary strong{display:block;margin-top:4px;font-size:18px}
.production-gantt-filters input,.production-gantt-filters select{width:180px}
.production-gantt-legend{display:flex;gap:12px;flex-wrap:wrap;align-items:center;color:#4B5563;font-size:12px}
.production-gantt-legend span{display:inline-flex;align-items:center;gap:6px}
.gantt-dot{width:10px;height:10px;border-radius:3px;display:inline-block}
.gantt-dot.green,.production-gantt-bar.green{background:#16A34A}
.gantt-dot.blue,.production-gantt-bar.blue{background:#2563EB}
.gantt-dot.yellow,.production-gantt-bar.yellow{background:#D97706}
.gantt-dot.red,.production-gantt-bar.red{background:#DC2626}
.gantt-dot.gray,.production-gantt-bar.gray{background:#6B7280}
.gantt-dot.light,.production-gantt-bar.light{background:#CBD5E1;color:#334155}
.production-gantt-skeleton{height:560px;border:1px solid var(--border);border-radius:10px;background:linear-gradient(90deg,#F3F4F6,#E5E7EB,#F3F4F6);background-size:220% 100%}
.production-gantt-chart{display:grid;grid-template-columns:560px 1fr;background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;min-height:420px}
.production-gantt-sidebar{border-right:1px solid var(--border);background:#fff;position:sticky;left:0;z-index:2}
.production-gantt-sidebar-head,.production-gantt-side-row{display:grid;grid-template-columns:100px 92px 1.4fr 112px 48px 108px 84px;gap:8px;align-items:center;min-height:34px;padding:0 10px;border-bottom:1px solid #EEF2F7;font-size:11px}
.production-gantt-sidebar-head{height:40px;background:#F8FAFC;color:#4A5568;font-weight:700;text-transform:none}
.production-gantt-side-row{cursor:pointer}
.production-gantt-side-row:hover{background:#FAFCFF}
.production-gantt-side-row.group{grid-template-columns:1fr;background:#EFF6FF;color:#1E40AF;font-weight:800;min-height:32px}
.production-gantt-side-row.order{background:#F8FAFC;font-weight:600}
.production-gantt-side-row.task{background:#fff}
.production-gantt-side-row span,.production-gantt-side-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.production-gantt-timeline{overflow:auto;position:relative;background:#fff}
.production-gantt-scale{height:40px;display:flex;position:sticky;top:0;z-index:1;background:#F8FAFC;border-bottom:1px solid var(--border)}
.production-gantt-scale span{display:flex;align-items:center;justify-content:center;border-right:1px solid #E5E7EB;font-size:11px;color:#4A5568;font-weight:700}
.production-gantt-tracks{position:relative}
.production-gantt-track-row{height:34px;border-bottom:1px solid #EEF2F7;position:relative;background:repeating-linear-gradient(90deg,#fff 0,#fff 95px,#F8FAFC 96px)}
.production-gantt-track-row.group{height:32px;background:#EFF6FF}
.production-gantt-track-row.order{background:#F8FAFC}
.production-gantt-bar{position:absolute;top:7px;height:20px;border:0;border-radius:5px;color:#fff;overflow:hidden;text-align:left;padding:0 7px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.16)}
.production-gantt-bar span{position:absolute;inset:0 auto 0 0;background:rgba(255,255,255,.24);pointer-events:none}
.production-gantt-bar b{position:relative;font-size:10px;line-height:20px;white-space:nowrap}
.production-gantt-actual{position:absolute;top:27px;height:3px;background:#111827;border-radius:10px;opacity:.55}
.production-gantt-today{position:absolute;top:0;bottom:0;width:2px;background:#EF4444;z-index:3}
.production-gantt-modal{width:min(760px,95vw)}
.production-dashboard-head{align-items:center}
.production-dashboard-filters input,.production-dashboard-filters select{width:178px}
.production-dashboard-skeleton{height:620px;border:1px solid var(--border);border-radius:10px;background:linear-gradient(90deg,#F3F4F6,#E5E7EB,#F3F4F6);background-size:220% 100%}
.production-dashboard-kpis{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:9px}
.production-dashboard-kpi{background:#fff;border:1px solid var(--border);border-radius:9px;padding:11px 12px;border-left:4px solid #CBD5E1}
.production-dashboard-kpi.ok{border-left-color:var(--green)}
.production-dashboard-kpi.wait{border-left-color:#D97706}
.production-dashboard-kpi.bad{border-left-color:var(--red);background:#FFF7F7}
.production-dashboard-kpi span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;font-weight:800;line-height:1.25}
.production-dashboard-kpi strong{display:block;margin-top:5px;font-size:20px}
.production-dashboard-kpi small{display:block;margin-top:2px;color:var(--muted)}
.production-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.production-dashboard-section.wide{grid-column:1/-1}
.production-app fieldset{border:0;margin:0;padding:0;min-width:0}
.production-app fieldset.form-grid,.production-app fieldset.card-body{display:grid}
.production-inline-form fieldset{display:contents}
.production-no-access{max-width:620px;margin:24px auto}
.production-stage-distribution{display:flex;flex-direction:column;gap:8px}
.production-stage-bar-row{display:grid;grid-template-columns:minmax(220px,.9fr) minmax(160px,1fr) auto;gap:10px;align-items:center}
.production-stage-bar-row strong{display:block;font-size:12px}
.production-stage-bar-row span{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.production-stage-bar{height:8px;background:#E5E7EB;border-radius:20px;overflow:hidden}
.production-stage-bar i{display:block;height:100%;background:var(--blue);border-radius:20px}
.invoice-app{display:flex;flex-direction:column;gap:14px}
.invoice-tabs{display:flex;gap:4px;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:9px;padding:0 8px}
.invoice-notice{display:none;border-radius:8px;padding:9px 12px;font-weight:600}
.invoice-notice.ok{display:block;background:#ECFDF5;color:#166534;border:1px solid #BBF7D0}
.invoice-notice.bad{display:block;background:#FEF2F2;color:#991B1B;border:1px solid #FECACA}
.invoice-filters input,.invoice-filters select{width:185px}
.invoice-upload-grid{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(420px,1.4fr);gap:14px;align-items:start}
.invoice-drop-card{min-height:320px}
.invoice-drop-zone{height:320px;border:2px dashed #CBD5E0;border-radius:10px;background:#F8FAFC;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;text-align:center;padding:24px;cursor:pointer}
.invoice-drop-zone.drag{border-color:var(--blue);background:#EFF6FF}
.invoice-drop-zone strong{font-size:16px}
.invoice-drop-zone span{color:var(--muted)}
.invoice-drop-zone input{max-width:260px}
.invoice-hint{background:#F1F5F9;border:1px solid #D8E1EA;border-radius:8px;padding:10px 12px;color:#52627A;font-size:13px;line-height:1.4}
.needs-review input,.needs-review select,.needs-review textarea{border-color:#D97706;background:#FFFBEB}
.needs-review label:after{content:" требует проверки";color:#B45309;font-weight:700}
.invoice-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.invoice-info-item{border:1px solid #EEF2F7;border-radius:8px;background:#F8FAFC;padding:9px 10px;min-width:0}
.payment-invoice-list{display:flex;flex-direction:column;gap:8px}
.payment-invoice-setting-row{border:1px solid var(--border);border-radius:8px;background:#F8FAFC;padding:9px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.payment-invoice-setting-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.invoice-info-item span{display:block;color:var(--muted);font-size:11px;margin-bottom:4px}
.invoice-info-item strong{display:block;overflow-wrap:anywhere}
.invoice-preview-img{display:block;max-width:100%;max-height:460px;border:1px solid var(--border);border-radius:8px;object-fit:contain}
.invoice-preview-frame{width:100%;height:460px;border:1px solid var(--border);border-radius:8px;background:#fff}
.invoice-file-box{border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;align-items:flex-start;gap:9px;flex-direction:column}
.invoice-file-box span{color:var(--muted)}
.invoice-log-list{display:flex;flex-direction:column;gap:8px}
.invoice-log{border:1px solid #EEF2F7;border-radius:8px;padding:10px 12px;background:#fff}
.invoice-log b{display:inline-block;margin-right:8px}
.invoice-log span{color:var(--muted);font-size:12px}
.invoice-log p{margin:7px 0 0;line-height:1.4}
.invoice-local-modal{position:fixed;inset:0;background:rgba(12,20,30,.48);z-index:1100;display:flex;align-items:center;justify-content:center;padding:18px}
@media(max-width:1200px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1300px){
  .production-header-grid{grid-template-columns:1fr 1fr 1fr;align-items:start}
  .production-inline-form{grid-template-columns:repeat(3,minmax(160px,1fr))}
  .production-comment-form{grid-template-columns:1fr}
  .production-gantt-summary{grid-template-columns:repeat(4,minmax(120px,1fr))}
  .production-gantt-chart{grid-template-columns:500px 1fr}
  .production-gantt-sidebar-head,.production-gantt-side-row{grid-template-columns:88px 76px 1.2fr 94px 42px 92px 76px}
  .production-dashboard-kpis{grid-template-columns:repeat(4,minmax(120px,1fr))}
  .production-dashboard-grid{grid-template-columns:1fr}
  .invoice-upload-grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  .kpis,.cols-2,.cols-3{grid-template-columns:1fr 1fr}
  .production-board{grid-template-columns:1fr 1fr}
  .production-flow{grid-template-columns:repeat(4,minmax(118px,1fr))}
  .production-header-grid,.production-check-row{grid-template-columns:1fr}
  .production-filters input,.production-filters select{width:100%}
  .production-kanban-column{width:285px;min-width:285px;max-height:calc(100vh - 260px)}
  .production-inline-form{grid-template-columns:1fr}
  .production-gantt-summary{grid-template-columns:1fr 1fr}
  .production-gantt-chart{grid-template-columns:420px 1fr}
  .production-gantt-filters input,.production-gantt-filters select{width:100%}
  .production-dashboard-kpis{grid-template-columns:1fr 1fr}
  .production-dashboard-filters input,.production-dashboard-filters select{width:100%}
  .production-stage-bar-row{grid-template-columns:1fr}
  .invoice-info-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .sidebar{width:52px}
  .brand{padding:18px 10px 14px}
  .brand strong{font-size:0}
  .brand strong:before{font-size:14px}
  .brand span,.nav-group,.nav-label{display:none}
  .nav-item{justify-content:center;padding:8px 0;width:46px}
}
