@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Source+Sans+3:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0B1120;--bg-warm:#111827;--surface:#1E293B;--gold:#D4A843;--gold-light:#F5C842;--gold-shimmer:linear-gradient(110deg,#D4A843 0%,#F5C842 45%,#D4A843 55%,#F5C842 100%);--charcoal:#F1F5F9;--success:#10B981;--warning:#F59E0B;--danger:#EF4444;--info:#3B82F6;--border:#334155;--muted:#94A3B8;--text-dim:#64748B;--font-display:"Playfair Display",Georgia,serif;--font-body:"Source Sans 3","Segoe UI",sans-serif;--font-mono:"DM Mono","Consolas",monospace;--shadow-sm:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15);--shadow-md:0 4px 12px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-lg:0 12px 40px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.25);--shadow-xl:0 20px 60px rgba(0,0,0,.5),0 8px 20px rgba(0,0,0,.3);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--transition:.2s cubic-bezier(.4,0,.2,1)}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg);color:var(--charcoal);overflow:hidden;height:100vh;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;flex:1;min-height:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#64748b}.topnav{display:flex;align-items:center;padding:0 24px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:100;flex-shrink:0}.topnav-brand{display:flex;align-items:center;gap:10px;margin-right:32px;cursor:default}.topnav-logo-frame{width:42px;height:42px;display:grid;place-items:center;padding:4px;border-radius:14px;background:#ffffff0f;border:1px solid rgba(212,168,67,.18);overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff08}.topnav-logo{width:100%;height:100%;display:block;object-fit:cover;object-position:center;border-radius:10px;filter:drop-shadow(0 6px 12px rgba(212,168,67,.18))}.topnav-brand .wordmark{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--charcoal);letter-spacing:.5px}.topnav-tabs{display:flex;gap:4px;flex:1}.topnav-tab{padding:8px 16px;border:none;background:none;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);position:relative}.topnav-tab:hover{color:var(--charcoal);background:var(--bg-warm)}.topnav-tab.active{color:var(--gold);font-weight:600}.topnav-tab.active:after{content:"";position:absolute;bottom:-1px;left:16px;right:16px;height:2px;background:var(--gold);border-radius:1px}.topnav-right{display:flex;align-items:center;gap:16px;margin-left:auto;position:relative}.topnav-search{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--muted);cursor:pointer;transition:all var(--transition)}.topnav-search:hover{border-color:var(--gold-light)}.topnav-search svg{width:14px;height:14px}.topnav-notif{position:relative;background:none;border:none;cursor:pointer;padding:4px;color:var(--muted);transition:color var(--transition)}.topnav-notif:hover{color:var(--charcoal)}.topnav-notif.open{color:var(--gold)}.topnav-notif svg{width:20px;height:20px}.topnav-notif .badge{position:absolute;top:0;right:0;width:16px;height:16px;border-radius:50%;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.topnav-notification-panel{position:absolute;top:52px;right:52px;width:min(360px,calc(100vw - 32px));max-height:min(70vh,560px);overflow:auto;padding:14px;border:1px solid var(--border);border-radius:18px;background:#0f172afa;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:14px;z-index:20}.topnav-notification-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.topnav-notification-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--charcoal)}.topnav-notification-subtitle{font-size:.72rem;font-family:var(--font-mono);color:var(--muted);margin-top:3px}.topnav-notification-section{display:flex;flex-direction:column;gap:8px}.topnav-notification-section-title{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}.topnav-notification-item{padding:11px 12px;border-radius:14px;border:1px solid rgba(71,85,105,.75);background:#02061752;display:flex;flex-direction:column;gap:5px}.topnav-notification-item.tone-warning{border-color:#f59e0b47;background:#f59e0b14}.topnav-notification-item.tone-danger{border-color:#ef444447;background:#ef444414}.topnav-notification-item.tone-info{border-color:#3b82f647;background:#3b82f614}.topnav-notification-item-title{font-size:.82rem;font-weight:700;color:var(--charcoal)}.topnav-notification-item-text{font-size:.78rem;line-height:1.5;color:#cbd5e1}.topnav-notification-item-meta{font-size:.68rem;font-family:var(--font-mono);color:var(--muted)}.topnav-notification-empty{padding:10px 12px;border-radius:12px;border:1px dashed rgba(71,85,105,.8);color:var(--muted);font-size:.78rem}.topnav-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-light));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;cursor:pointer;border:2px solid transparent;transition:border-color var(--transition)}.topnav-avatar:hover{border-color:var(--gold)}.topnav-profile-menu{position:absolute;top:52px;right:0;min-width:220px;padding:12px;border:1px solid var(--border);border-radius:16px;background:#0f172afa;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:8px}.topnav-profile-name{font-weight:700;color:var(--charcoal)}.topnav-profile-email{font-size:.78rem;color:var(--muted);font-family:var(--font-mono)}.topnav-profile-action{padding:9px 12px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--gold-light),var(--gold));color:#0f172a;font-weight:700;cursor:pointer;text-align:left}.topnav-profile-action.muted{background:#94a3b814;color:var(--charcoal);border:1px solid rgba(148,163,184,.14)}.app-loading,.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(212,168,67,.18),transparent 28%),radial-gradient(circle at bottom right,rgba(30,41,59,.9),transparent 32%),#07111f}.app-loading{color:var(--charcoal);font-family:var(--font-mono)}.login-card{width:min(440px,92vw);padding:32px;border:1px solid rgba(212,168,67,.18);border-radius:28px;background:#0f172aeb;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:14px}.login-logo-frame{width:124px;height:152px;align-self:center;display:grid;place-items:center;padding:8px;border-radius:28px;background:#ffffff0f;border:1px solid rgba(212,168,67,.18);overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff08}.login-logo{width:100%;height:100%;display:block;object-fit:cover;object-position:center;border-radius:20px}.login-kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);text-align:center}.login-title{font-family:var(--font-display);font-size:2rem;color:var(--charcoal);text-align:center}.login-copy{color:#cbd5e1;line-height:1.6;text-align:center}.login-error{padding:10px 12px;border-radius:12px;background:#ef44441f;border:1px solid rgba(239,68,68,.25);color:#fca5a5}.login-form{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px;font-size:.8rem;color:#cbd5e1}.login-field input{padding:12px 14px;border:1px solid #334155;border-radius:14px;background:#0b1120;color:var(--charcoal);font:inherit}.login-field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #d4a84329}.login-submit{padding:12px 16px;border:none;border-radius:14px;background:linear-gradient(135deg,var(--gold-light),var(--gold));color:#0f172a;font-weight:800;cursor:pointer}.login-submit:disabled{opacity:.7;cursor:not-allowed}.machine-ribbon{display:flex;align-items:center;gap:8px;padding:8px 24px;height:52px;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.machine-ribbon::-webkit-scrollbar{height:4px}.ribbon-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;white-space:nowrap;margin-right:8px;flex-shrink:0}.ribbon-chip{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.72rem;color:var(--charcoal);white-space:nowrap;cursor:pointer;transition:all var(--transition);flex-shrink:0}.ribbon-chip:hover{border-color:var(--gold-light);background:#d4a8431a}.ribbon-chip.active{border-color:var(--gold);background:#d4a8431a;color:var(--gold);font-weight:600}.ribbon-chip .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ribbon-chip .dot.running{background:var(--success);box-shadow:0 0 4px var(--success)}.ribbon-chip .dot.idle{background:var(--muted)}.ribbon-chip .dot.maintenance{background:var(--danger);box-shadow:0 0 4px var(--danger)}.ribbon-chip .dot.setup{background:var(--warning);box-shadow:0 0 4px var(--warning)}.ribbon-chip .oee-val{font-size:.65rem;color:var(--muted)}.view-container{flex:1;overflow:hidden;position:relative}.view-panel{position:absolute;inset:0;overflow:hidden;display:none;opacity:0;transition:opacity .3s ease}.view-panel.active{display:flex;flex-direction:column;opacity:1}.machine-inventory{padding:24px;gap:18px;overflow:auto}.machine-inventory-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.machine-inventory-title{font-family:var(--font-display);font-size:1.6rem;color:var(--charcoal)}.machine-inventory-subtitle{max-width:560px;color:var(--muted);line-height:1.6}.machine-inventory-summary{display:flex;gap:10px;flex-wrap:wrap}.machine-inventory-summary span{padding:8px 12px;border-radius:999px;border:1px solid rgba(71,85,105,.8);background:#0f172ae6;font-family:var(--font-mono);font-size:.74rem;color:var(--charcoal)}.machine-inventory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.machine-card{padding:16px;border:1px solid rgba(71,85,105,.82);border-radius:18px;background:linear-gradient(180deg,#0f172af5,#0f172ad6);display:grid;gap:14px;text-align:left;color:inherit;cursor:pointer;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.machine-card:hover,.machine-card.active{border-color:#d4a843b8;transform:translateY(-1px);box-shadow:0 14px 28px #0206173d}.machine-card-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.machine-card-id{font-family:var(--font-display);font-size:1.1rem;color:var(--charcoal)}.machine-card-type{margin-top:4px;font-size:.82rem;color:var(--muted)}.machine-card-status{padding:6px 10px;border-radius:999px;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.machine-card-status.running{color:#48bb78;border-color:#48bb784d;background:#48bb7814}.machine-card-status.idle{color:#a0aec0;border-color:#a0aec047;background:#a0aec014}.machine-card-status.setup{color:#ecc94b;border-color:#ecc94b4d;background:#ecc94b14}.machine-card-status.maintenance{color:#fc8181;border-color:#fc818152;background:#fc818114}.machine-card-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.machine-card-metrics div,.machine-card-order{padding:12px;border-radius:14px;background:#02061757;border:1px solid rgba(71,85,105,.52)}.machine-card-metrics span,.machine-card-order span{display:block;font-size:.72rem;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.machine-card-metrics strong,.machine-card-order strong{display:block;font-size:1rem;color:var(--charcoal)}.machine-card-order em{display:block;margin-top:6px;font-size:.82rem;font-style:normal;color:#cbd5e1;line-height:1.5}.connector-footer{display:flex;align-items:center;justify-content:center;gap:24px;padding:6px 24px;height:32px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.conn-item{display:flex;align-items:center;gap:6px;font-size:.75rem;font-family:var(--font-mono);color:var(--muted)}.conn-dot{width:7px;height:7px;border-radius:50%}.conn-dot.online{background:var(--success);box-shadow:0 0 4px var(--success)}.conn-dot.degraded{background:var(--warning);box-shadow:0 0 4px var(--warning)}.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.dash-card .label{font-size:.8rem;color:var(--muted);margin-bottom:4px}.dash-card .value{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--charcoal)}.dash-card .sub{font-size:.75rem;color:var(--success);margin-top:4px;font-weight:500}.dash-card.risk .value,.dash-card.risk .sub{color:var(--danger)}.dash-section-title{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--charcoal);margin-bottom:12px}.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}.activity-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm)}.activity-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.activity-icon.prod{background:#10b98126;color:var(--success)}.activity-icon.alert{background:#ef444426;color:var(--danger)}.activity-icon.order{background:#3b82f626;color:var(--info)}.activity-icon.maint{background:#f59e0b26;color:var(--warning)}.activity-text{flex:1;font-size:.85rem;color:var(--charcoal)}.activity-time{font-size:.75rem;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}.oee-overview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm)}.oee-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.oee-mini{text-align:center;padding:12px}.oee-mini .gauge-wrap{width:72px;height:72px;margin:0 auto 8px;position:relative}.oee-mini .gauge-wrap svg{width:72px;height:72px}.oee-mini .gauge-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--charcoal)}.oee-mini .gauge-label{font-size:.75rem;color:var(--muted)}.kanban{display:flex;gap:16px;padding:16px 24px;flex:1;overflow-x:auto;align-items:flex-start}.kanban-col{min-width:280px;max-width:320px;flex:1;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:100%}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.kanban-col-title{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--charcoal)}.kanban-col-count{font-family:var(--font-mono);font-size:.7rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:2px 8px;color:var(--muted)}.kanban-col-body{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}.k-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.k-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--gold-light)}.k-card.highlighted{border-color:var(--gold);box-shadow:0 0 0 2px #d4a8434d,var(--shadow-md)}.k-card .priority-ribbon{position:absolute;top:0;left:0;width:4px;height:100%;border-radius:10px 0 0 10px}.k-card .priority-ribbon.p1{background:var(--danger)}.k-card .priority-ribbon.p2{background:var(--warning)}.k-card .priority-ribbon.p3{background:var(--info)}.k-card .priority-ribbon.p4{background:var(--muted)}.k-card .card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding-left:8px}.k-card .order-id{font-family:var(--font-mono);font-size:.72rem;font-weight:600;color:var(--gold)}.k-card .priority-tag{font-family:var(--font-mono);font-size:.6rem;font-weight:700;letter-spacing:.5px;padding:2px 6px;border-radius:3px}.k-card .priority-tag.p1{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.k-card .priority-tag.p2{background:#f59e0b33;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.k-card .priority-tag.p3{background:#3b82f633;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.k-card .priority-tag.p4{background:#94a3b826;color:var(--muted);border:1px solid rgba(148,163,184,.2)}.k-card .customer{font-size:.85rem;font-weight:600;color:var(--charcoal);margin-bottom:2px;padding-left:8px}.k-card .product{font-size:.78rem;color:var(--muted);margin-bottom:8px;padding-left:8px}.k-card .card-meta{display:flex;gap:8px;flex-wrap:wrap;padding-left:8px;margin-bottom:8px}.k-card .meta-chip{display:flex;align-items:center;gap:4px;font-size:.68rem;padding:2px 6px;border-radius:4px;background:var(--bg-warm);color:var(--muted);font-family:var(--font-mono)}.k-card .meta-chip.due{color:var(--muted)}.k-card .meta-chip.due.overdue{background:#ef444426;color:#fca5a5}.k-card .meta-chip.due.today{background:#f59e0b26;color:#fcd34d}.k-card .machine-chips{display:flex;gap:4px;flex-wrap:wrap;padding-left:8px;margin-bottom:6px}.k-card .m-chip{font-family:var(--font-mono);font-size:.62rem;padding:2px 5px;border-radius:3px;background:#d4a84314;color:var(--gold);border:1px solid rgba(212,168,67,.15)}.k-card .routing-dots{display:flex;gap:3px;padding-left:8px;margin-bottom:6px}.k-card .r-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--border)}.k-card .r-dot.done{background:var(--success);border-color:var(--success)}.k-card .r-dot.active{background:var(--gold);border-color:var(--gold);box-shadow:0 0 4px var(--gold)}.k-card .r-dot.pending{background:transparent}.k-card .progress-wrap{padding-left:8px}.k-card .progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.k-card .progress-fill{height:100%;border-radius:2px;background:var(--gold);transition:width .4s ease}.view-floorplan{background:var(--bg);color:var(--charcoal);font-family:var(--font-body);font-size:14px;position:relative}.view-floorplan{display:flex;flex-direction:column;height:100%}.fp-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border);flex-shrink:0;z-index:20;background:var(--bg-warm)}.fp-toolbar-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--gold);letter-spacing:1px;text-transform:uppercase}.fp-layer-toggles{display:flex;gap:6px;flex-wrap:wrap}.fp-toggle{display:flex;align-items:center;gap:5px;padding:5px 10px;background:#d4a84314;border:1px solid rgba(212,168,67,.2);border-radius:999px;font-family:var(--font-mono);font-size:.68rem;color:var(--muted);cursor:pointer;transition:all .2s}.fp-toggle.on{background:#d4a84326;border-color:var(--gold);color:var(--gold)}.fp-toggle:hover{border-color:var(--gold)}.fp-floor{flex:1;position:relative;overflow:auto;padding:20px;background:radial-gradient(circle at top left,rgba(30,41,59,.65),transparent 40%),radial-gradient(circle at bottom right,rgba(212,168,67,.08),transparent 25%),var(--bg)}.fp-floor:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,#162544 1px,transparent 1px);background-size:20px 20px;opacity:.32;pointer-events:none}.fp-layout{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.8fr) minmax(280px,.9fr);gap:18px;align-items:start}.fp-main-column,.fp-side-column{display:flex;flex-direction:column;gap:18px}.fp-zone-section{position:relative;background:#0f172ae6;border:1px solid rgba(71,85,105,.85);border-radius:18px;padding:16px;box-shadow:var(--shadow-md)}.fp-zone-section.accent-gold{border-color:#d4a84347}.fp-zone-section.accent-emerald{border-color:#10b98133}.fp-zone-section.accent-blue{border-color:#3b82f633}.fp-zone-section.accent-amber{border-color:#f59e0b33}.fp-zone-section.accent-slate{border-color:#94a3b838}.fp-zone-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.fp-zone-section-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--charcoal)}.fp-zone-section-subtitle{font-size:.76rem;color:var(--muted)}.fp-zone-metrics{display:flex;gap:8px;flex-wrap:wrap}.fp-zone-metrics span{padding:4px 8px;border-radius:999px;background:#94a3b814;border:1px solid rgba(148,163,184,.14);font-family:var(--font-mono);font-size:.66rem;color:#cbd5e1}.fp-zone-machine-grid{display:grid;grid-template-columns:repeat(var(--zone-columns),minmax(0,1fr));gap:12px}.fp-machine{position:relative;width:100%;min-height:82px;background:linear-gradient(180deg,#1e293beb,#0f172af2);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;z-index:2;padding:10px 8px;text-align:center}.fp-machine:hover{border-color:var(--gold);box-shadow:0 0 12px #d4a84333;transform:translateY(-1px)}.fp-machine.active{border-color:var(--gold);box-shadow:0 0 16px #d4a8434d}.fp-machine.highlighted{border-color:var(--gold);box-shadow:0 0 16px #d4a84366}.fp-machine .m-id{font-family:var(--font-mono);font-size:.72rem;font-weight:700;color:var(--charcoal)}.fp-machine .m-status{font-size:.6rem;color:var(--muted)}.fp-machine .m-oee-bar{width:70%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.fp-machine .m-oee-fill{height:100%;border-radius:2px}.fp-machine .m-order{font-size:.58rem;color:#94a3b8}.fp-machine .status-glow{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%}.fp-machine .status-glow.running{background:#48bb78;box-shadow:0 0 6px #48bb7880}.fp-machine .status-glow.idle{background:#718096}.fp-machine .status-glow.maintenance{background:#fc8181;box-shadow:0 0 6px #fc818180}.fp-machine .status-glow.setup{background:#ecc94b;box-shadow:0 0 6px #ecc94b80}.fp-machine.future{border-style:dashed;opacity:.5}.fp-machine.future .m-id{color:#718096}.fp-detail{position:absolute;bottom:0;left:0;right:0;background:var(--surface);border-top:2px solid var(--gold);padding:16px 24px;z-index:30;transform:translateY(100%);transition:transform .3s ease;max-height:220px;overflow-y:auto}.fp-detail.open{transform:translateY(0)}.fp-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.fp-detail-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--gold)}.fp-detail-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem}.fp-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.fp-detail-item{text-align:center}.fp-detail-item .dl{font-size:.7rem;color:#718096;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-family:var(--font-mono)}.fp-detail-item .dv{font-family:var(--font-mono);font-size:1.1rem;font-weight:700}.fp-bottom-row{position:relative;z-index:1;display:grid;grid-template-columns:220px minmax(0,1fr);gap:18px;margin-top:18px}.fp-legend{background:#111827f2;border:1px solid var(--border);border-radius:14px;padding:12px 14px}.fp-legend-title{font-family:var(--font-display);font-size:.65rem;font-weight:700;color:var(--gold);letter-spacing:1px;margin-bottom:6px;text-transform:uppercase}.fp-legend-items{display:flex;flex-direction:column;gap:4px}.fp-legend-item{display:flex;align-items:center;gap:6px;font-size:.68rem;color:var(--muted)}.fp-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fp-infra-rail{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.fp-infra{padding:12px 14px;background:#d4a84314;border:1px dashed rgba(212,168,67,.3);border-radius:14px;font-family:var(--font-mono);pointer-events:none;z-index:1}.fp-infra-label{font-size:.66rem;color:var(--gold);letter-spacing:.08em}.fp-infra-detail{margin-top:6px;font-size:.74rem;color:#cbd5e1;line-height:1.4}.view-commandcenter{background:var(--bg);color:var(--charcoal);font-family:var(--font-body);font-size:13px}.cc-layout{display:flex;height:100%;flex-direction:column}.cc-main{display:flex;flex:1;overflow:hidden}.cc-left-rail{width:280px;min-width:280px;background:var(--bg-warm);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.cc-rail-header{padding:14px 14px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.cc-rail-title{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:2px;color:var(--gold);margin-bottom:8px;display:flex;align-items:center;gap:8px}.cc-rail-title .count{font-size:10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1px 8px;color:var(--muted);letter-spacing:0}.cc-filter-tabs{display:flex;gap:2px;background:var(--surface);border-radius:6px;padding:2px}.cc-filter-tab{flex:1;padding:5px 4px;border:none;background:transparent;color:var(--text-dim);font-family:var(--font-body);font-size:11px;font-weight:500;border-radius:4px;cursor:pointer;transition:all .15s ease;text-align:center}.cc-filter-tab.active{background:#253349;color:var(--charcoal);box-shadow:0 1px 3px #0000004d}.cc-filter-tab:hover:not(.active){color:var(--muted)}.cc-order-list{flex:1;overflow-y:auto;padding:8px}.cc-order-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:6px;cursor:pointer;transition:all .15s ease;position:relative}.cc-order-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;border-color:var(--text-dim)}.cc-order-card.selected{border-color:var(--gold);box-shadow:0 0 0 1px #d4a843,0 4px 12px #d4a84326}.cc-order-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.cc-order-id{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--charcoal)}.cc-priority-badge{font-family:var(--font-mono);font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;letter-spacing:.5px}.cc-priority-badge.p1{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.cc-priority-badge.p2{background:#f59e0b33;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.cc-priority-badge.p3{background:#3b82f633;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.cc-priority-badge.p4{background:#64748b33;color:var(--muted);border:1px solid rgba(100,116,139,.3)}.cc-order-customer{font-size:12px;font-weight:500;color:var(--charcoal);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-order-product{font-size:11px;color:var(--muted);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-order-meta{display:flex;justify-content:space-between;align-items:center;gap:6px;flex-wrap:wrap}.cc-order-due{font-family:var(--font-mono);font-size:10px;padding:2px 6px;border-radius:3px}.cc-order-due.overdue{background:#ef444426;color:#fca5a5}.cc-order-due.today{background:#f59e0b26;color:#fcd34d}.cc-order-due.upcoming{background:#10b98126;color:#6ee7b7}.cc-order-status{font-size:10px;font-weight:500;padding:2px 6px;border-radius:3px}.cc-order-status.in-production{background:#10b98133;color:#6ee7b7}.cc-order-status.scheduled{background:#3b82f633;color:#93c5fd}.cc-order-status.pending{background:#64748b33;color:var(--muted)}.cc-order-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding-top:6px;border-top:1px solid var(--surface)}.cc-order-machine{font-family:var(--font-mono);font-size:10px;color:var(--gold);background:#d4a8431a;padding:2px 6px;border-radius:3px;border:1px solid rgba(212,168,67,.2)}.cc-order-qty{font-family:var(--font-mono);font-size:10px;color:var(--text-dim)}.cc-gantt-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.cc-gantt-header{display:flex;padding:8px 16px;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-warm)}.cc-gantt-title{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:2px;color:var(--muted)}.cc-gantt-controls{display:flex;gap:8px}.cc-gantt-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);font-family:var(--font-mono);font-size:10px;padding:4px 10px;border-radius:4px;cursor:pointer;transition:all .15s}.cc-gantt-btn:hover{border-color:var(--text-dim);color:var(--charcoal)}.cc-gantt-btn.active{border-color:var(--gold);color:var(--gold);background:#d4a84314}.cc-gantt-scroll{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}.cc-gantt-timeline{display:flex;flex-direction:column;min-height:100%;position:relative}.cc-time-axis{display:flex;position:sticky;top:0;z-index:10;background:var(--bg-warm);border-bottom:1px solid var(--border);flex-shrink:0}.cc-time-label-col{min-width:140px;max-width:140px;padding:6px 12px;font-family:var(--font-mono);font-size:10px;color:var(--text-dim);border-right:1px solid var(--border);display:flex;align-items:center}.cc-time-slots{flex:1;display:flex;position:relative}.cc-time-slot{flex:1;padding:6px 0;text-align:center;font-family:var(--font-mono);font-size:10px;color:var(--text-dim);border-right:1px solid var(--surface);position:relative}.cc-time-slot.current-hour{color:var(--gold);font-weight:600}.cc-machine-group{border-bottom:1px solid var(--border)}.cc-group-header{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface);cursor:pointer;user-select:none;border-bottom:1px solid var(--surface)}.cc-group-chevron{width:14px;height:14px;color:var(--text-dim);transition:transform .15s}.cc-group-header.collapsed .cc-group-chevron{transform:rotate(-90deg)}.cc-group-name{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1px;color:var(--muted);text-transform:uppercase}.cc-group-count{font-family:var(--font-mono);font-size:9px;color:var(--text-dim);background:var(--bg);padding:1px 6px;border-radius:8px}.cc-group-body{overflow:hidden;transition:max-height .3s ease}.cc-machine-row{display:flex;border-bottom:1px solid var(--surface);height:38px;align-items:center;transition:background .15s}.cc-machine-row:hover{background:#ffffff05}.cc-machine-row.highlighted{background:#d4a8430d}.cc-machine-label{min-width:140px;max-width:140px;padding:0 12px;font-family:var(--font-mono);font-size:11px;color:var(--muted);border-right:1px solid var(--border);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden}.cc-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cc-status-dot.running{background:#10b981;box-shadow:0 0 4px #10b981}.cc-status-dot.idle{background:#64748b}.cc-status-dot.maintenance{background:#ef4444}.cc-status-dot.setup{background:#f59e0b}.cc-machine-timeline{flex:1;height:100%;position:relative;display:flex;align-items:center;padding:3px 0}.cc-gantt-block{position:absolute;height:28px;border-radius:4px;display:flex;align-items:center;padding:0 6px;font-size:10px;font-family:var(--font-mono);overflow:hidden;white-space:nowrap;cursor:pointer;transition:all .15s;z-index:2;top:50%;transform:translateY(-50%)}.cc-gantt-block:hover{z-index:5;filter:brightness(1.2);box-shadow:0 2px 8px #0006}.cc-gantt-block.highlighted{z-index:6;box-shadow:0 0 0 2px #d4a843,0 4px 16px #d4a8434d}.cc-gantt-block.p1{background:#ef444459;border:1px solid rgba(239,68,68,.5);color:#fca5a5}.cc-gantt-block.p2{background:#f59e0b4d;border:1px solid rgba(245,158,11,.45);color:#fcd34d}.cc-gantt-block.p3{background:#3b82f64d;border:1px solid rgba(59,130,246,.45);color:#93c5fd}.cc-gantt-block.p4{background:#64748b40;border:1px solid rgba(100,116,139,.4);color:#cbd5e1}.cc-gantt-block.active-block{border-left:3px solid #D4A843;box-shadow:0 0 8px #d4a84333}.cc-gantt-block.setup-block{background:repeating-linear-gradient(45deg,rgba(245,158,11,.15),rgba(245,158,11,.15) 4px,transparent 4px,transparent 8px);border:1px dashed rgba(245,158,11,.4);color:#f59e0b}.cc-gantt-block .block-text{overflow:hidden;text-overflow:ellipsis}.cc-time-line{position:absolute;top:0;bottom:0;width:2px;background:#d4a843;z-index:8;pointer-events:none}.cc-time-line:before{content:"";position:absolute;top:0;left:-4px;width:10px;height:10px;background:#d4a843;border-radius:50%;box-shadow:0 0 10px #d4a843}.cc-bottom-strip{height:160px;min-height:160px;background:var(--bg-warm);border-top:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.cc-oee-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 4px;flex-shrink:0}.cc-oee-title{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:2px;color:var(--text-dim)}.cc-oee-clusters{flex:1;display:flex;gap:4px;padding:4px 12px 8px;overflow-x:auto}.cc-oee-cluster{flex:1;min-width:160px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:12px}.cc-oee-gauge-wrap{position:relative;width:70px;height:70px;flex-shrink:0}.cc-oee-gauge-wrap svg{width:70px;height:70px}.cc-oee-gauge-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.cc-oee-gauge-pct{font-family:var(--font-mono);font-size:16px;font-weight:700;line-height:1}.cc-oee-gauge-label{font-size:8px;color:var(--text-dim);letter-spacing:1px;font-family:var(--font-mono)}.cc-oee-info{flex:1;min-width:0}.cc-oee-cluster-name{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--charcoal);margin-bottom:4px;letter-spacing:.5px}.cc-oee-metrics{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}.cc-oee-metric{display:flex;justify-content:space-between;font-size:10px}.cc-oee-metric-label{color:var(--text-dim)}.cc-oee-metric-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.cc-sparkline-wrap{height:20px;width:100%}.cc-sparkline-wrap svg{width:100%;height:20px}.cc-tooltip{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 14px;width:240px;box-shadow:0 8px 24px #00000080;z-index:2000;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease;font-size:12px;font-family:var(--font-body);color:var(--charcoal)}.cc-tooltip.visible{opacity:1;transform:translateY(0)}.cc-tooltip .tt-order{font-family:var(--font-mono);font-weight:600;color:var(--gold);font-size:12px;margin-bottom:4px}.cc-tooltip .tt-product{color:var(--charcoal);font-weight:500;margin-bottom:8px}.cc-tooltip .tt-row{display:flex;justify-content:space-between;margin-bottom:3px}.cc-tooltip .tt-label{color:var(--text-dim);font-size:11px}.cc-tooltip .tt-value{color:var(--charcoal);font-family:var(--font-mono);font-size:11px}.cc-tooltip .tt-progress{margin-top:8px;height:4px;background:var(--bg);border-radius:2px;overflow:hidden}.cc-tooltip .tt-progress-bar{height:100%;border-radius:2px;background:#d4a843}.view-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);padding:60px}.view-placeholder svg{width:48px;height:48px;opacity:.3}.view-placeholder .ph-title{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--charcoal)}.view-placeholder .ph-sub{font-size:.9rem;text-align:center;max-width:400px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.jarvis-fab{position:fixed;bottom:48px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--gold-shimmer);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #d4a84366;z-index:200;transition:all .3s ease;background-size:200% 100%;animation:shimmer 3s linear infinite}.jarvis-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #d4a84380}.jarvis-fab svg{width:24px;height:24px;color:#fff}.jarvis-overlay{position:fixed;inset:0;background:#0006;z-index:250;opacity:0;pointer-events:none;transition:opacity .3s ease}.jarvis-overlay.open{opacity:1;pointer-events:auto}.jarvis-drawer{position:fixed;top:0;right:0;bottom:0;width:380px;background:var(--surface);box-shadow:var(--shadow-xl);z-index:300;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.jarvis-drawer.open{transform:translate(0)}.jarvis-drawer-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}.jarvis-brand{display:flex;align-items:center;gap:10px}.jarvis-icon{width:32px;height:32px;background:var(--gold-shimmer);background-size:200% 100%;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;animation:shimmer 3s linear infinite}.jarvis-name{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--charcoal)}.jarvis-status{font-size:.7rem;color:var(--success);display:flex;align-items:center;gap:4px}.jarvis-status .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.jarvis-clear,.jarvis-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:4px;transition:color var(--transition)}.jarvis-clear:hover,.jarvis-close:hover{color:var(--charcoal)}.jarvis-clear svg,.jarvis-close svg{width:18px;height:18px}.jarvis-header-actions{display:flex;align-items:center;gap:6px;flex:0 0 auto}.jarvis-clear.active{color:var(--gold);background:#d4a8431f}.jarvis-history-panel{border-bottom:1px solid var(--border);background:#0f172afa;padding:10px 14px;max-height:220px;overflow:hidden;display:flex;flex-direction:column;gap:8px}.jarvis-history-title{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gold)}.jarvis-history-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;padding-right:2px}.jarvis-history-item{width:100%;border:1px solid rgba(148,163,184,.14);background:#ffffff0a;border-radius:8px;padding:8px 10px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:3px;min-height:50px}.jarvis-history-item:hover,.jarvis-history-item.active{border-color:#d4a84361;background:#d4a8431a}.jarvis-history-item-title{font-size:.78rem;color:var(--charcoal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jarvis-history-item-meta{font-family:var(--font-mono);font-size:.62rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jarvis-history-empty{font-size:.78rem;color:var(--muted);padding:8px 2px}.jarvis-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:4px;transition:color var(--transition)}.jarvis-close:hover{color:var(--charcoal)}.jarvis-close svg{width:20px;height:20px}.jarvis-session{padding:10px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#0f172af5,#111827f5);display:flex;align-items:center;justify-content:space-between;gap:12px}.jarvis-session-badge{flex:0 0 auto;font-size:.68rem;font-weight:700;padding:5px 9px;border-radius:999px;background:#94a3b814;border:1px solid rgba(148,163,184,.12);letter-spacing:.04em;text-transform:uppercase}.jarvis-session-badge.connected{color:var(--success)}.jarvis-session-badge.disconnected{color:var(--warning)}.jarvis-session-detail{min-width:0;flex:1;font-size:.78rem;color:var(--charcoal);font-family:var(--font-mono);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jarvis-session-error{font-size:.74rem;color:#b42318}.jarvis-thread{flex:1;overflow-y:auto;padding:14px 18px;display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,#0b1120f0,#0f172ae6)}.jarvis-empty-state{margin:auto 0;padding:14px 16px;border:1px dashed rgba(71,85,105,.7);border-radius:14px;background:#0f172a80;color:var(--muted);font-size:.84rem;line-height:1.6}.jarvis-example-prompts{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.jarvis-example-prompt{padding:8px 10px;border-radius:999px;border:1px solid rgba(212,168,67,.24);background:#d4a84314;color:var(--charcoal);font-size:.74rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.jarvis-example-prompt:hover{border-color:#d4a8436b;background:#d4a84324}.j-msg{max-width:90%;display:flex;flex-direction:column;gap:4px}.j-msg.bot{align-self:flex-start}.j-msg.user{align-self:flex-end}.j-msg .bubble{padding:10px 12px;border-radius:14px;font-size:.82rem;line-height:1.5}.j-msg .bubble p{margin:0}.j-msg .bubble p+p{margin-top:.75rem}.j-msg .bubble ul,.j-msg .bubble ol{margin:.6rem 0 0 1.1rem;padding:0}.j-msg .bubble li+li{margin-top:.25rem}.j-msg .bubble code{font-family:var(--font-mono);font-size:.78rem;background:#94a3b824;padding:.08rem .32rem;border-radius:4px}.j-msg .bubble strong{font-weight:700;color:#fff}.j-msg.bot .bubble{background:var(--bg-warm);color:var(--charcoal);border:1px solid var(--border);border-bottom-left-radius:4px}.j-msg.user .bubble{background:#d4a84333;color:var(--charcoal);border:1px solid rgba(212,168,67,.3);border-bottom-right-radius:4px}.j-msg .timestamp{font-size:.65rem;color:var(--muted);font-family:var(--font-mono)}.j-msg.bot .timestamp{padding-left:4px}.j-msg.user .timestamp{text-align:right;padding-right:4px}.jarvis-composer{padding:12px 18px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;background:#0f172afa}.jarvis-request-status{width:100%;font-size:.72rem;color:var(--gold);font-family:var(--font-mono)}.jarvis-input{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:12px;background:var(--bg-warm);color:var(--charcoal);font-family:var(--font-body);font-size:.84rem;outline:none;transition:border-color var(--transition)}.jarvis-input:focus{border-color:var(--gold)}.jarvis-send{width:36px;height:36px;border-radius:50%;border:none;background:var(--gold);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.jarvis-send:hover{background:var(--gold-light);transform:scale(1.05)}.jarvis-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.jarvis-send svg{width:16px;height:16px}.jarvis-send.is-stop{background:#b42318}.jarvis-send.is-stop:hover{background:#d92d20}@media(max-width:1100px){.fp-layout,.fp-bottom-row{grid-template-columns:1fr}}@media(max-width:820px){.fp-zone-machine-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.fp-infra-rail{grid-template-columns:1fr}.jarvis-drawer{width:min(100vw,380px)}}.modal-overlay{position:fixed;inset:0;background:#0009;z-index:400;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.modal-overlay.open{display:flex;opacity:1}.modal-card{background:var(--surface);border-radius:var(--radius-xl);padding:28px;max-width:480px;width:90%;box-shadow:var(--shadow-xl);position:relative}.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.3rem}.modal-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal);margin-bottom:4px}.modal-subtitle{font-size:.85rem;color:var(--muted);margin-bottom:16px}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.modal-field .label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;font-family:var(--font-mono)}.modal-field .value{font-size:.9rem;font-weight:500;color:var(--charcoal)}.modal-progress{margin-top:8px}.modal-progress .bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.modal-progress .fill{height:100%;border-radius:3px;background:var(--gold)}.modal-progress .pct{font-size:.75rem;color:var(--muted);margin-top:4px;text-align:right;font-family:var(--font-mono)}.scenario-panel{padding:0;display:flex;flex-direction:column}.scenario-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-warm)}.scenario-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal)}.scenario-new-btn{padding:8px 16px;background:var(--gold);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.scenario-new-btn:hover{background:var(--gold-light);transform:translateY(-1px)}.scenario-body{display:flex;flex:1;overflow:hidden}.scenario-sidebar{width:280px;min-width:280px;background:var(--bg-warm);border-right:1px solid var(--border);overflow-y:auto}.scenario-mode-banner{margin:16px 16px 0;padding:10px 12px;border-radius:14px;border:1px solid rgba(212,168,67,.28);background:#d4a84314;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}.scenario-list{display:flex;flex-direction:column;padding:8px}.scenario-item{padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:6px;cursor:pointer;transition:all var(--transition)}.scenario-item:hover{border-color:var(--gold-light);transform:translateY(-1px)}.scenario-item.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),var(--shadow-sm)}.scenario-item-name{font-size:.9rem;font-weight:600;color:var(--charcoal);margin-bottom:4px}.scenario-item-meta{display:flex;align-items:center;gap:8px}.scenario-status-badge{font-family:var(--font-mono);font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:10px;text-transform:lowercase}.scenario-status-badge.draft{background:#3b82f633;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.scenario-status-badge.approved{background:#10b98133;color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}.scenario-status-badge.archived{background:#64748b33;color:var(--muted);border:1px solid rgba(100,116,139,.3)}.scenario-date{font-family:var(--font-mono);font-size:.7rem;color:var(--muted)}.scenario-main{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px}.scenario-whatif{display:flex;flex-direction:column;gap:6px}.scenario-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:1px;color:var(--muted);text-transform:uppercase}.scenario-select{padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--charcoal);font-family:var(--font-body);font-size:.85rem;cursor:pointer;transition:border-color var(--transition)}.scenario-select:focus{border-color:var(--gold);outline:none}.scenario-input{padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--charcoal);font:inherit}.scenario-input:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px #d4a8431f}.scenario-comparison{display:grid;grid-template-columns:1fr 1fr;gap:16px}.comparison-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.comparison-heading{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--gold);margin-bottom:12px}.comparison-stat{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}.comparison-stat:last-child{border-bottom:none}.comparison-label{font-size:.8rem;color:var(--muted)}.comparison-value{font-family:var(--font-mono);font-size:.85rem;font-weight:600;color:var(--charcoal)}.scenario-impact{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.impact-heading{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--charcoal);margin-bottom:12px}.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.impact-item{text-align:center;padding:12px;background:var(--bg-warm);border-radius:var(--radius-md)}.impact-label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:4px}.impact-value{display:block;font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:var(--charcoal)}.scenario-results-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.scenario-impact-list{display:grid;gap:10px}.scenario-impact-row{display:grid;grid-template-columns:120px 120px 1fr;gap:12px;padding:12px;border-radius:14px;background:var(--bg-warm);align-items:center}.scenario-impact-row strong{color:var(--charcoal)}.scenario-impact-row span{font-family:var(--font-mono);font-size:.78rem;color:var(--gold)}.scenario-impact-row em{font-style:normal;color:#cbd5e1}.scenario-empty-copy{color:var(--muted);line-height:1.6}.scenario-actions{display:flex;gap:10px}.scenario-approve-btn{padding:8px 20px;background:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all var(--transition)}.scenario-approve-btn:hover:not(:disabled){filter:brightness(1.1)}.scenario-approve-btn:disabled{opacity:.5;cursor:not-allowed}.scenario-archive-btn{padding:8px 20px;background:var(--surface);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all var(--transition)}.scenario-archive-btn:hover:not(:disabled){border-color:var(--warning);color:var(--warning)}.scenario-archive-btn:disabled{opacity:.5;cursor:not-allowed}.connector-health-panel{padding:0;display:flex;flex-direction:column}.ch-header{display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-warm)}.ch-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal)}.ch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;padding:20px 24px;overflow-y:auto;flex:1}.ch-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}.ch-card-header{display:flex;align-items:center;justify-content:space-between}.ch-card-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--charcoal)}.ch-status-indicator{display:flex;align-items:center;gap:6px}.ch-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ch-status-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.ch-status-dot.degraded{background:var(--warning);box-shadow:0 0 6px var(--warning)}.ch-status-dot.offline{background:var(--danger);box-shadow:0 0 6px var(--danger)}.ch-status-text{font-family:var(--font-mono);font-size:.72rem;font-weight:600;text-transform:lowercase}.ch-status-indicator.online .ch-status-text{color:var(--success)}.ch-status-indicator.degraded .ch-status-text{color:var(--warning)}.ch-status-indicator.offline .ch-status-text{color:var(--danger)}.ch-card-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ch-metric{display:flex;flex-direction:column;gap:2px;padding:8px;background:var(--bg-warm);border-radius:var(--radius-sm)}.ch-metric-label{font-size:.7rem;color:var(--muted);font-family:var(--font-mono);letter-spacing:.5px}.ch-metric-value{font-family:var(--font-mono);font-size:.9rem;font-weight:600;color:var(--charcoal)}.ch-metric-value.error{color:var(--danger)}.ch-metric-value.warning{color:var(--warning)}.ch-dead-letter-row{display:flex;align-items:center;justify-content:space-between;padding:8px;background:var(--bg-warm);border-radius:var(--radius-sm)}.ch-dead-letter-btn{padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.7rem;color:var(--muted);cursor:pointer;transition:all var(--transition)}.ch-dead-letter-btn:hover{border-color:var(--gold);color:var(--gold)}.ch-dead-letter-details{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px}.ch-dl-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:.78rem}.ch-dl-item:last-child{border-bottom:none}.ch-dl-msg{color:var(--charcoal);flex:1}.ch-dl-time{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);white-space:nowrap;margin-left:12px}.ch-msg-rate{display:flex;flex-direction:column;gap:6px}.ch-bar-chart{display:flex;align-items:flex-end;gap:3px;height:40px}.ch-bar{flex:1;background:var(--gold);border-radius:2px 2px 0 0;min-width:4px;transition:height .3s ease;opacity:.7}.ch-bar:hover{opacity:1}.ch-config-panel{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid rgba(212,168,67,.18);border-radius:var(--radius-md);background:linear-gradient(180deg,#d4a8431f,#0f172afa);box-shadow:inset 0 1px #ffffff0a}.ch-config-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.ch-config-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--charcoal)}.ch-config-subtitle{font-family:var(--font-mono);font-size:.68rem;color:#c7d2e0;text-transform:uppercase;letter-spacing:.08em}.ch-config-meta{display:flex;gap:8px;flex-wrap:wrap}.ch-config-chip{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;background:#10b9811f;border:1px solid rgba(16,185,129,.22);color:#a7f3d0;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase}.ch-config-chip.muted{background:#94a3b814;border-color:#94a3b82e;color:#cbd5e1}.ch-config-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ch-config-field{display:flex;flex-direction:column;gap:6px}.ch-config-label{font-family:var(--font-mono);font-size:.7rem;color:#c7d2e0}.ch-config-input{width:100%;padding:10px 12px;border:1px solid #475569;border-radius:var(--radius-sm);background:#0f172a;color:var(--charcoal);font:inherit}.ch-config-input::placeholder{color:#64748b}.ch-config-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #e4b74a2e}.ch-config-footer{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center}.ch-config-feedback-wrap{min-height:20px}.ch-config-btn{padding:10px 14px;border:none;border-radius:var(--radius-sm);background:var(--charcoal);color:#fff;font-family:var(--font-mono);font-size:.72rem;cursor:pointer;transition:transform var(--transition),opacity var(--transition)}.ch-config-btn.primary{background:linear-gradient(135deg,var(--gold-light),var(--gold));color:#0f172a;font-weight:700;box-shadow:0 8px 20px #d4a84338}.ch-config-btn.secondary{background:var(--bg-warm);color:var(--charcoal);border:1px solid #475569}.ch-config-btn:hover{transform:translateY(-1px);opacity:.92}.ch-config-feedback{margin:0;font-size:.78rem;color:#e2e8f0}.ch-config-feedback.muted{color:#94a3b8}@media(max-width:1280px){.ch-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}@media(max-width:780px){.ch-grid{grid-template-columns:1fr;padding:16px}.ch-card{padding:16px}.ch-config-grid{grid-template-columns:1fr}.ch-config-header{align-items:flex-start;flex-direction:column}.ch-config-footer{grid-template-columns:1fr}.ch-config-btn{width:100%}}.approval-screen{padding:0;display:flex;flex-direction:column}.approval-header{display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-warm)}.approval-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal)}.approval-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:24px}.approval-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.approval-section-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--gold);margin-bottom:14px}.approval-list{display:flex;flex-direction:column;gap:10px}.approval-item{display:flex;align-items:center;justify-content:space-between;padding:14px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-md);gap:16px;transition:all var(--transition)}.approval-item:hover{border-color:var(--gold-light)}.approval-item-content{flex:1;min-width:0}.approval-item-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.approval-action-type{font-family:var(--font-mono);font-size:.78rem;font-weight:600;color:var(--gold);padding:2px 8px;background:#d4a8431a;border-radius:4px}.approval-timestamp{font-family:var(--font-mono);font-size:.7rem;color:var(--muted)}.approval-details{font-size:.85rem;color:var(--charcoal);margin-bottom:4px}.approval-requestor{font-size:.78rem;color:var(--muted)}.approval-item-actions{display:flex;gap:8px;flex-shrink:0}.approval-btn{padding:6px 14px;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.approval-btn.approve{background:var(--success);color:#fff}.approval-btn.approve:hover{filter:brightness(1.1)}.approval-btn.reject{background:var(--surface);color:var(--muted);border:1px solid var(--border)}.approval-btn.reject:hover{border-color:var(--danger);color:var(--danger)}.approval-empty{text-align:center;padding:24px;color:var(--muted);font-size:.85rem}.audit-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.audit-section-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--gold);margin-bottom:14px}.audit-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.audit-filter{display:flex;flex-direction:column;gap:4px}.audit-filter label{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);letter-spacing:.5px}.audit-filter select,.audit-filter input{padding:6px 10px;background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--charcoal);font-family:var(--font-body);font-size:.82rem;transition:border-color var(--transition)}.audit-filter select:focus,.audit-filter input:focus{border-color:var(--gold);outline:none}.audit-table{width:100%;border-collapse:collapse;font-size:.82rem}.audit-table th{text-align:left;padding:8px 12px;border-bottom:2px solid var(--border);color:var(--muted);font-family:var(--font-mono);font-size:.72rem;letter-spacing:1px;text-transform:uppercase}.audit-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--charcoal)}.audit-table tr:hover td{background:#d4a84308}.audit-result{font-family:var(--font-mono);font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:10px}.audit-result.approved{background:#10b98133;color:#6ee7b7}.audit-result.rejected{background:#ef444433;color:#fca5a5}.audit-ts{font-family:var(--font-mono);font-size:.75rem;color:var(--muted)}.audit-empty{text-align:center;padding:16px;color:var(--muted)}.violations-panel{padding:0;display:flex;flex-direction:column}.violations-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-warm)}.violations-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--charcoal)}.violations-count{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);padding:4px 10px;border-radius:10px}.violations-list{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:10px}.violation-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;transition:all var(--transition)}.violation-item.blocked{border-left:4px solid var(--danger)}.violation-item.warning{border-left:4px solid var(--warning)}.violation-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}.violation-severity-badge{font-family:var(--font-mono);font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:10px}.violation-severity-badge.hard{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.violation-severity-badge.soft{background:#f59e0b33;color:#fcd34d;border:1px solid rgba(245,158,11,.3)}.violation-type{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--charcoal)}.violation-details{margin-bottom:8px}.violation-refs{display:flex;gap:8px;margin-bottom:4px}.violation-order{font-family:var(--font-mono);font-size:.75rem;color:var(--gold);background:#d4a8431a;padding:2px 6px;border-radius:4px}.violation-machine{font-family:var(--font-mono);font-size:.75rem;color:var(--info);background:#3b82f61a;padding:2px 6px;border-radius:4px}.violation-description{font-size:.82rem;color:var(--muted);line-height:1.5}.violation-actions{margin-top:8px}.violation-resolve-btn{padding:6px 14px;background:var(--surface);border:1px solid var(--warning);border-radius:var(--radius-sm);color:var(--warning);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.violation-resolve-btn:hover{background:#f59e0b1a}.violation-suggestion{margin-top:8px;padding:10px 12px;background:#10b98114;border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-sm);font-size:.82rem;color:var(--charcoal);line-height:1.5}.suggestion-label{font-weight:600;color:var(--success)}.runtime-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 20px;padding:14px 18px;border-radius:16px;border:1px solid rgba(148,163,184,.2);background:linear-gradient(135deg,#0f172aeb,#1e293bd1)}.runtime-banner.demo{border-color:#f59e0b59}.runtime-banner.live{border-color:#10b98159}.runtime-banner.warning{border-color:#ef444459}.runtime-banner-label{font-size:14px;font-weight:700;color:#f8fafc}.runtime-banner-detail,.runtime-banner-meta{font-size:12px;color:#94a3b8}.runtime-banner-meta{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}.autonomy-panel{display:grid;gap:12px;padding:16px;border-radius:18px;border:1px solid rgba(148,163,184,.16);background:#0f172ab3}.autonomy-item{padding:12px 14px;border-radius:14px;background:#1e293ba6;border:1px solid rgba(148,163,184,.12)}.autonomy-item-title,.autonomy-count{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#cbd5e1}.autonomy-item-text,.autonomy-empty{margin-top:6px;font-size:13px;line-height:1.5;color:#e2e8f0}.cc-autonomy-panel{width:320px;min-width:320px;display:grid;gap:12px;padding-left:16px}@media(max-width:1200px){.cc-main{flex-wrap:wrap}.cc-autonomy-panel{width:100%;min-width:0;padding-left:0;padding-top:16px}}
