@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Sans+Condensed:wght@500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--ibe-navy:#0a2540;--ibe-navy-700:#143559;--ibe-navy-500:#2a4d75;--ibe-cyan:#00b4d8;--ibe-cyan-soft:#cfeef6;--yanmar-red:#e60012;--yanmar-red-soft:#fbd8da;--st-success:#0e9f6e;--st-success-soft:#def7ec;--st-warning:#c2410c;--st-warning-soft:#fdf2d7;--st-danger:#dc2626;--st-danger-soft:#fee2e2;--st-info:#1d4ed8;--st-info-soft:#dbeafe;--paint-grey:#6b7280;--paint-red:#dc2626;--paint-white:#f3f4f6;--n-50:#fafaf7;--n-100:#f4f4f0;--n-200:#e5e5df;--n-300:#d1d1c9;--n-400:#a8a8a0;--n-500:#71716a;--n-600:#525250;--n-700:#3a3a38;--n-800:#262624;--n-900:#1a1a18;--bg:var(--n-50);--bg-panel:#fff;--bg-elev:#fff;--bg-subtle:var(--n-100);--border:var(--n-200);--border-strong:var(--n-300);--border-dark:var(--n-700);--text:var(--n-900);--text-muted:var(--n-500);--text-subtle:var(--n-400);--text-inverse:#fff;--font-sans:"IBM Plex Sans", system-ui, sans-serif;--font-cond:"IBM Plex Sans Condensed", "IBM Plex Sans", sans-serif;--font-mono:"IBM Plex Mono", ui-monospace, monospace;--radius-sm:2px;--radius:4px;--radius-lg:8px;--shadow-none:none;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;--s-20:80px}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"tnum", "ss01";font-size:14px;line-height:1.5}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:0;padding:0}a{color:var(--ibe-navy);text-decoration:none}a:hover{text-decoration:underline}img,svg{max-width:100%;display:block}.h1{font-family:var(--font-cond);letter-spacing:-.01em;font-size:32px;font-weight:700;line-height:1.1}.h2{font-family:var(--font-cond);letter-spacing:-.005em;font-size:22px;font-weight:600;line-height:1.2}.h3{font-size:16px;font-weight:600;line-height:1.3}.label{font-family:var(--font-cond);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.code{font-family:var(--font-mono);font-size:.92em}.mono{font-family:var(--font-mono)}.muted{color:var(--text-muted)}.kbd{font-family:var(--font-mono);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-elev);color:var(--text);padding:2px 6px;font-size:11px}.stat-hero{font-family:var(--font-cond);letter-spacing:-.02em;color:var(--text);font-feature-settings:"tnum";font-size:56px;font-weight:700;line-height:1}.stat-mid{font-family:var(--font-cond);font-feature-settings:"tnum";font-size:32px;font-weight:600;line-height:1}.stat-small{font-family:var(--font-cond);font-feature-settings:"tnum";font-size:20px;font-weight:600}.app{grid-template:"sidebar topbar"56px"sidebar main"1fr/240px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--ibe-navy);color:var(--text-inverse);border-right:1px solid var(--border-dark);flex-direction:column;grid-area:sidebar;display:flex}.sidebar__brand{border-bottom:1px solid var(--ibe-navy-700);align-items:center;gap:10px;padding:18px 20px 22px;display:flex}.sidebar__brand .logo{background:var(--ibe-cyan);width:28px;height:28px;font-family:var(--font-cond);color:var(--ibe-navy);place-items:center;font-size:14px;font-weight:700;display:grid}.sidebar__brand .name{font-family:var(--font-cond);letter-spacing:.02em;font-size:17px;font-weight:700}.sidebar__brand .name span{color:var(--ibe-cyan)}.sidebar__group{padding:16px 12px 8px}.sidebar__group .label{color:#ffffff73;padding:0 8px 8px}.sidebar__nav{flex-direction:column;gap:1px;display:flex}.sidebar__nav a{color:#ffffffc7;border-radius:var(--radius);align-items:center;gap:10px;padding:9px 10px;font-size:13.5px;text-decoration:none;display:flex}.sidebar__nav a:hover{background:var(--ibe-navy-700);color:#fff}.sidebar__nav a.active{background:var(--ibe-navy-700);color:#fff;position:relative}.sidebar__nav a.active:before{content:"";background:var(--ibe-cyan);width:3px;position:absolute;top:8px;bottom:8px;left:-12px}.sidebar__nav a svg{opacity:.8;flex-shrink:0;width:16px;height:16px}.sidebar__footer{border-top:1px solid var(--ibe-navy-700);color:#ffffff80;font-size:11px;font-family:var(--font-mono);margin-top:auto;padding:14px 16px}.topbar{background:var(--bg-panel);border-bottom:1px solid var(--border);grid-area:topbar;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.topbar__crumb{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.topbar__crumb .sep{color:var(--text-subtle)}.topbar__crumb .curr{color:var(--text);font-weight:500}.topbar__right{align-items:center;gap:14px;display:flex}.topbar__shift{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.topbar__shift .pill{background:var(--st-success-soft);color:var(--st-success);font-weight:600;font-family:var(--font-cond);padding:3px 8px}.topbar__icon{width:36px;height:36px;color:var(--text-muted);border-radius:var(--radius);place-items:center;display:grid;position:relative}.topbar__icon:hover{background:var(--bg-subtle)}.topbar__icon svg{width:18px;height:18px}.topbar__icon .dot{background:var(--yanmar-red);border:1.5px solid var(--bg-panel);border-radius:50%;width:7px;height:7px;position:absolute;top:8px;right:8px}.topbar__user{border-left:1px solid var(--border);align-items:center;gap:10px;padding:4px 4px 4px 12px;display:flex}.topbar__user .name{font-size:13px;font-weight:500;line-height:1.1}.topbar__user .role{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.topbar__user .avatar{background:var(--ibe-navy);color:#fff;width:32px;height:32px;font-family:var(--font-cond);place-items:center;font-size:13px;font-weight:600;display:grid}.main{grid-area:main;padding:24px 28px 64px;overflow-x:auto}.pagehead{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px;padding-bottom:18px;display:flex}.pagehead__meta{align-items:center;gap:8px;display:flex}.pagehead__title{flex-direction:column;gap:4px;display:flex}.pagehead__title .h1{margin:0}.pagehead__title .sub{color:var(--text-muted);font-size:13px}.pagehead__actions{align-items:center;gap:8px;display:flex}.btn{font-family:var(--font-sans);border:1px solid var(--border-strong);background:var(--bg-panel);color:var(--text);border-radius:var(--radius);white-space:nowrap;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.btn:hover{background:var(--bg-subtle)}.btn svg{width:14px;height:14px}.btn--primary{background:var(--ibe-navy);border-color:var(--ibe-navy);color:#fff}.btn--primary:hover{background:var(--ibe-navy-700);border-color:var(--ibe-navy-700)}.btn--accent{background:var(--yanmar-red);border-color:var(--yanmar-red);color:#fff}.btn--danger{background:var(--st-danger);border-color:var(--st-danger);color:#fff}.btn--ghost{background:0 0;border-color:#0000}.btn--ghost:hover{background:var(--bg-subtle)}.btn--lg{padding:12px 20px;font-size:14px}.btn--xl{padding:18px 32px;font-size:16px;font-weight:600}.card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius)}.card__head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.card__head .title{align-items:baseline;gap:12px;font-size:14px;font-weight:600;display:flex}.card__head .title .meta{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.card__body{padding:18px}.card__body--compact{padding:12px 14px}.card__body--flush{padding:0}.kpi-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;display:grid;overflow:hidden}.kpi{background:var(--bg-panel);flex-direction:column;gap:6px;padding:18px 20px;display:flex;position:relative}.kpi__label{font-family:var(--font-cond);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.kpi__value{font-family:var(--font-cond);font-feature-settings:"tnum";color:var(--text);font-size:36px;font-weight:700;line-height:1.05}.kpi__value .unit{color:var(--text-muted);margin-left:4px;font-size:18px;font-weight:500}.kpi__sub{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);align-items:center;gap:6px;display:flex}.kpi__delta{align-items:center;gap:3px;font-weight:600;display:inline-flex}.kpi__delta--up{color:var(--st-success)}.kpi__delta--down{color:var(--st-danger)}.kpi__spark{margin-top:6px}.tbl{border-collapse:collapse;width:100%}.tbl th,.tbl td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.tbl th{font-family:var(--font-cond);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-subtle);white-space:nowrap;font-size:11px;font-weight:600}.tbl tr:hover td{background:var(--bg-subtle)}.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.tbl td .code{font-size:12px}.badge{font-family:var(--font-cond);letter-spacing:.04em;text-transform:uppercase;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-subtle);color:var(--text);align-items:center;gap:5px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge--success{background:var(--st-success-soft);color:var(--st-success);border-color:#0000}.badge--warning{background:var(--st-warning-soft);color:var(--st-warning);border-color:#0000}.badge--danger{background:var(--st-danger-soft);color:var(--st-danger);border-color:#0000}.badge--info{background:var(--st-info-soft);color:var(--st-info);border-color:#0000}.badge--grey{background:var(--n-200);color:var(--n-700);border-color:#0000}.dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px;display:inline-block}.dot--success{background:var(--st-success)}.dot--warning{background:var(--st-warning)}.dot--danger{background:var(--st-danger)}.dot--info{background:var(--st-info)}.color-chip{border:1px solid var(--border-strong);vertical-align:middle;border-radius:2px;width:14px;height:14px;display:inline-block}.color-chip--grey{background:var(--paint-grey)}.color-chip--red{background:var(--paint-red)}.color-chip--white{background:var(--paint-white)}.section-rule{align-items:center;gap:10px;margin:28px 0 14px;display:flex}.section-rule__bar{background:var(--ibe-navy);width:24px;height:2px}.section-rule__title{font-family:var(--font-cond);letter-spacing:.1em;text-transform:uppercase;color:var(--text);font-size:12px;font-weight:600}.section-rule__hr{background:var(--border);flex:1;height:1px}.row{gap:var(--s-3);align-items:center;display:flex}.row--between{justify-content:space-between}.row--gap-2{gap:var(--s-2)}.row--gap-6{gap:var(--s-6)}.col{gap:var(--s-2);flex-direction:column;display:flex}.grid-2{gap:var(--s-4);grid-template-columns:1fr 1fr;display:grid}.grid-3{gap:var(--s-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--s-4);grid-template-columns:repeat(4,1fr);display:grid}.mt-0{margin-top:0}.mt-2{margin-top:var(--s-2)}.mt-4{margin-top:var(--s-4)}.mt-6{margin-top:var(--s-6)}.mt-8{margin-top:var(--s-8)}.mb-0{margin-bottom:0}.mb-4{margin-bottom:var(--s-4)}.text-c{text-align:center}.text-r{text-align:right}.no-wrap{white-space:nowrap}.minibar{align-items:flex-end;gap:2px;height:30px;display:flex}.minibar span{background:var(--ibe-navy);opacity:.85;border-radius:1px 1px 0 0;flex:1;min-height:2px;display:block}.minibar span.alt{background:var(--ibe-cyan)}.minibar--mini{height:20px}.tablet-frame{background:var(--n-100);flex-direction:column;min-height:100vh;display:flex}.tablet-frame__bar{background:var(--ibe-navy);color:#fff;justify-content:space-between;align-items:center;padding:14px 22px;display:flex}.tablet-frame__bar .left{align-items:center;gap:14px;display:flex}.tablet-frame__bar .pos-name{font-family:var(--font-cond);letter-spacing:.02em;font-size:18px;font-weight:700}.tablet-frame__bar .pos-code{font-family:var(--font-mono);opacity:.7;font-size:11px}.tablet-frame__bar .right{align-items:center;gap:18px;font-size:13px;display:flex}.tablet-frame__main{flex-direction:column;flex:1;gap:18px;padding:24px;display:flex}.bigbtn{font-family:var(--font-cond);letter-spacing:.03em;border-radius:var(--radius);color:var(--text);text-align:center;text-transform:uppercase;cursor:pointer;background:#fff;border:2px solid;justify-content:center;align-items:center;gap:10px;padding:24px 32px;font-size:22px;font-weight:700;display:flex}.bigbtn svg{width:28px;height:28px}.bigbtn--primary{background:var(--ibe-navy);border-color:var(--ibe-navy);color:#fff}.bigbtn--success{background:var(--st-success);border-color:var(--st-success);color:#fff}.bigbtn--danger{background:var(--st-danger);border-color:var(--st-danger);color:#fff}.bigbtn--ghost{border-color:var(--border-strong);color:var(--text);background:#fff}.login-split{grid-template-columns:1.1fr 1fr;min-height:100vh;display:grid}.login-art{background:var(--ibe-navy);color:#fff;flex-direction:column;justify-content:space-between;padding:56px 64px;display:flex;position:relative;overflow:hidden}.login-art:after{content:"";border:1px solid #ffffff14;width:320px;height:320px;position:absolute;bottom:-120px;right:-120px;transform:rotate(15deg)}.login-art:before{content:"";border:1px solid #00b4d82e;width:220px;height:220px;position:absolute;bottom:-60px;right:-60px;transform:rotate(15deg)}.login-form{background:var(--bg);flex-direction:column;justify-content:center;padding:56px 80px;display:flex}.input{font-family:var(--font-sans);border:1px solid var(--border-strong);background:var(--bg-panel);border-radius:var(--radius);width:100%;color:var(--text);padding:11px 14px;font-size:14px}.input:focus{outline:2px solid var(--ibe-cyan);outline-offset:-1px;border-color:var(--ibe-cyan)}.input-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.input-group label{font-family:var(--font-cond);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.pinpad{grid-template-columns:repeat(3,1fr);gap:8px;max-width:320px;display:grid}.pinpad button{font-family:var(--font-cond);background:var(--bg-panel);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);padding:22px 0;font-size:24px;font-weight:600}.pinpad button:hover{background:var(--bg-subtle)}.pinpad button:active{transform:translateY(1px)}.pinpad button.dim{color:var(--text-muted)}.pin-display{justify-content:center;gap:10px;margin:18px 0;display:flex}.pin-display span{border:1.5px solid var(--border-strong);background:var(--bg-panel);border-radius:50%;width:14px;height:14px}.pin-display span.filled{background:var(--ibe-navy);border-color:var(--ibe-navy)}.factory-map{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);padding:30px;position:relative}.pos-node{background:var(--bg-panel);border:2px solid var(--border-strong);text-align:center;border-radius:var(--radius-sm);min-width:100px;padding:8px 10px;font-size:11px;position:absolute}.pos-node .name{font-family:var(--font-cond);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:600;line-height:1.1}.pos-node .count{font-family:var(--font-mono);margin-top:4px;font-size:14px;font-weight:600}.pos-node--active{border-color:var(--st-success);background:var(--st-success-soft)}.pos-node--warning{border-color:var(--st-warning);background:var(--st-warning-soft)}.pos-node--danger{border-color:var(--st-danger);background:var(--st-danger-soft);animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #dc262673}50%{box-shadow:0 0 0 6px #dc262600}}.andon-row{border-left:3px solid var(--st-danger);background:var(--st-danger-soft);grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;display:grid}.andon-row .ts{font-family:var(--font-mono);color:var(--st-danger);font-size:11px;font-weight:600}.seq-row{border-bottom:1px solid var(--border);grid-template-columns:36px 60px 1fr 100px 120px 120px 80px;align-items:center;gap:12px;padding:10px 12px;font-size:13px;display:grid}.seq-row:hover{background:var(--bg-subtle)}.seq-row .num{font-family:var(--font-cond);color:var(--text-muted);font-size:16px;font-weight:700}.seq-row .body-no{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.matrix{border-collapse:collapse;width:100%;font-size:12px}.matrix th,.matrix td{border:1px solid var(--border);text-align:center;vertical-align:middle;height:32px;padding:0}.matrix th.model-col,.matrix td.model-col{text-align:left;font-weight:500;font-family:var(--font-mono);background:var(--bg-panel);white-space:nowrap;padding:6px 10px;font-size:12px;position:sticky;left:0}.matrix thead th{background:var(--bg-subtle);font-family:var(--font-cond);letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);padding:4px 6px;font-size:10px;font-weight:600}.matrix .cell-on{background:var(--st-success-soft)}.matrix .cell-cond{background:var(--st-warning-soft)}.matrix .cell-off{background:var(--bg-subtle)}.matrix .grp-grey{background:#6b728014}.matrix .grp-red{background:#dc26260f}.matrix .grp-white{background:#f3f4f680}.matrix .check{color:var(--st-success);font-weight:700}.chartbox{width:100%;height:auto}@media (width<=900px){.app{grid-template-columns:1fr;grid-template-areas:"topbar""main"}.sidebar{display:none}.login-split{grid-template-columns:1fr}.login-art,.login-form{padding:32px}.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media print{.sidebar,.topbar{display:none}.main{padding:0}}.showcase{max-width:1280px;margin:0 auto;padding:64px 40px 80px}.showcase__hero{border-bottom:1px solid var(--border);grid-template-columns:1.5fr 1fr;align-items:end;gap:48px;margin-bottom:40px;padding-bottom:40px;display:grid}.showcase__hero .h1{font-size:64px}.showcase__hero .h1 strong{color:var(--yanmar-red)}.showcase__hero .lede{color:var(--text-muted);max-width:560px;margin-top:16px;font-size:17px;line-height:1.55}.showcase__hero .meta-grid{background:var(--border);border:1px solid var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.showcase__hero .meta-grid>div{background:var(--bg-panel);padding:14px 16px}.showcase__hero .meta-grid .label{margin-bottom:4px;display:block}.showcase__hero .meta-grid .val{font-family:var(--font-cond);font-size:18px;font-weight:600}.deck{background:var(--border);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;display:grid}.deck__card{background:var(--bg-panel);color:inherit;flex-direction:column;padding:24px;text-decoration:none;transition:background .15s;display:flex;position:relative}.deck__card:hover{background:var(--bg-subtle);text-decoration:none}.deck__card .num{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:8px;font-size:11px}.deck__card h3{font-family:var(--font-cond);letter-spacing:-.005em;margin:0 0 8px;font-size:22px;font-weight:700}.deck__card .desc{color:var(--text-muted);flex:1;font-size:13px;line-height:1.5}.deck__card .tags{flex-wrap:wrap;gap:4px;margin-top:14px;display:flex}.deck__card .arrow{color:var(--text-muted);position:absolute;top:24px;right:24px}.deck__card:hover .arrow{color:var(--ibe-navy)}#root{min-height:100vh}.recharts-cartesian-axis-tick text{font-family:var(--font-mono);fill:var(--text-muted);font-size:11px}.recharts-default-tooltip{border:1px solid var(--border-strong)!important;border-radius:var(--radius)!important;font-family:var(--font-sans)!important;font-size:12px!important}.recharts-tooltip-label{font-family:var(--font-cond);font-weight:600}.heat{gap:2px;display:grid}.heat-cell{height:26px;font-family:var(--font-mono);color:var(--text);border-radius:2px;place-items:center;font-size:10px;display:grid}.toggle-group{border:1px solid var(--border-strong);border-radius:var(--radius);display:inline-flex;overflow:hidden}.toggle-group button{background:var(--bg-panel);color:var(--text-muted);border-right:1px solid var(--border);padding:6px 12px;font-size:12px;font-weight:500}.toggle-group button:last-child{border-right:0}.toggle-group button.on{background:var(--ibe-navy);color:#fff}.modal-backdrop{z-index:50;background:#0a25408c;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:560px;overflow:hidden}.andon-cat{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.andon-cat button{border:2px solid var(--border-strong);border-radius:var(--radius);background:var(--bg-panel);font-family:var(--font-cond);color:var(--text);flex-direction:column;align-items:center;gap:10px;padding:22px 16px;font-size:15px;font-weight:600;display:flex}.andon-cat button:hover{border-color:var(--st-danger);background:var(--st-danger-soft)}.andon-cat button svg{width:30px;height:30px;color:var(--st-danger)}.toast{z-index:60;background:var(--ibe-navy);color:#fff;border-radius:var(--radius);border-left:3px solid var(--ibe-cyan);align-items:center;gap:10px;padding:14px 18px;font-size:13px;display:flex;position:fixed;bottom:24px;right:24px}.toast.success{border-left-color:var(--st-success)}.toast.danger{border-left-color:var(--st-danger)}.link-btn{color:var(--ibe-cyan);background:0 0;font-weight:500}.flex1{flex:1}.gap-row{flex-wrap:wrap;gap:8px;display:flex}
