/* XLTION CMMS - Main Stylesheet */
/* Extracted from index.html */


/* ═══════════════════════════════════════════
   ROOT – Matte Paper Theme
═══════════════════════════════════════════ */
/* ═══════════════════════════════════════════
   COMMON – Root Variables & Base Styles
═══════════════════════════════════════════ */
:root {
  /* Pantone palette: Bianca White · Stone Gray · Fog · Slate · Ink */
  --bg0:#f2f3f5;       /* Pantone 11-4800 Light Gray – page canvas  */
  --bg1:#ffffff;       /* Pure white – cards, panels                 */
  --bg2:#f7f8fa;       /* Pantone 11-0601 – subtle row alt           */
  --bg3:#eceef2;       /* Pantone 14-4102 Silver – inputs/dividers   */
  --bg4:#dde0e8;       /* Pantone 14-4110 – deeper dividers          */
  --border:#e2e5ec;
  --border2:#cdd1db;
  /* Text — Pantone Ink Blues */
  --txt0:#1c2333;      /* Pantone 19-3832 – near-black               */
  --txt1:#3d4f6b;      /* Pantone 18-3935 – dark body                */
  --txt2:#6e7f99;      /* Pantone 17-3911 Silver Gray – secondary    */
  --txt3:#aab4c8;      /* Pantone 14-4112 – placeholder/hints        */
  /* Accent – Pantone 19-4340 Deep Teal (calm authority) */
  --accent:#1f6f78; --accent-dim:rgba(31,111,120,.10);
  /* Sidebar – Pantone 19-3911 Turbulence (near-navy) */
  --sidebar-bg:#1a2640;
  --sidebar-txt:rgba(255,255,255,.80);
  --sidebar-active:#ffffff;
  --sidebar-ico-bg:rgba(255,255,255,.12);
  --sidebar-hover:rgba(255,255,255,.08);
  /* Semantic */
  --green:#1d7a48;     /* Pantone 17-0145 Jade */
  --red:#c0283a;       /* Pantone 18-1660 Fiesta */
  --blue:#1a55a0;      /* Pantone 18-4051 Classic Blue */
  --purple:#5c3db0;    /* Pantone 18-3838 Ultra Violet */
  --yellow:#b08a00;    /* Pantone 15-1062 Saffron */
  --cyan:#0d84a0;      /* Pantone 17-4728 Larkspur */
  --orange:#c45018;    /* Pantone 16-1440 Amber */
  --font:'Sora',sans-serif;
  --mono:'JetBrains Mono',monospace;
  --sidebar-w:228px; --sidebar-icon:52px; --topbar:52px; --r:6px;
  --primary-dark:#1a2e40;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg0);color:var(--txt0);font-size:13px;line-height:1.5}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:4px}
button,input,select,textarea{font-family:var(--font)}
a{color:inherit;text-decoration:none}

/* ═══════════════════════════════════════════
   LOGIN
═══════════════════════════════════════════ */
#login-screen {
  position:fixed;inset:0;background:var(--bg0);
  display:flex;align-items:center;justify-content:center;z-index:9999;
}
#login-screen::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 40%, rgba(192,96,16,.08) 0%, transparent 70%);
  pointer-events:none;
}
.login-wrap {
  background:var(--bg1);border:1px solid var(--border2);
  border-radius:12px;padding:44px 40px;width:400px;
  box-shadow:0 16px 60px rgba(0,0,0,.12);position:relative;
}
.login-logo {display:flex;align-items:center;gap:12px;margin-bottom:32px;}
.logo-icon {
  width:44px;height:44px;background:var(--accent);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:#fff;flex-shrink:0;
  box-shadow:0 4px 18px rgba(192,96,16,.30);
}
.logo-text .t1{font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--txt0)}
.logo-text .t2{font-size:10px;color:var(--txt2);font-family:var(--mono);letter-spacing:1.2px;margin-top:1px}
.l-fg{margin-bottom:16px}
.l-label{display:block;font-size:10px;font-weight:600;color:var(--txt2);letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px}
.l-input{
  width:100%;background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r);padding:10px 12px;font-size:13px;
  color:var(--txt0);outline:none;transition:border-color .15s;
}
.l-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(26,107,114,.12)}
.l-input::placeholder{color:var(--txt3)}
.l-err{font-size:11px;color:var(--red);margin-bottom:12px;display:none}
.l-btn{
  width:100%;padding:12px;background:var(--accent);border:none;
  border-radius:var(--r);font-size:13px;font-weight:700;color:#fff;
  cursor:pointer;transition:all .15s;letter-spacing:.2px;
}
.l-btn:hover{background:#1d7c84;box-shadow:0 4px 18px rgba(192,96,16,.35)}
.l-btn:disabled{opacity:.6;cursor:default}
.l-hint{text-align:center;margin-top:16px;font-size:10px;color:var(--txt3);font-family:var(--mono)}

/* ═══════════════════════════════════════════
   APP SHELL
═══════════════════════════════════════════ */
#app{display:flex;height:100vh;overflow:hidden;background:var(--bg0)}
#app.hidden{display:none}

/* ═══════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════ */
#sidebar {
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--sidebar-bg);
  display:flex;flex-direction:column;overflow:hidden;
  transition:width .22s cubic-bezier(.4,0,.2,1);
  border-radius:0 10px 10px 0;
  box-shadow:4px 0 20px rgba(0,0,0,.10);
  position:relative;z-index:10;
}
#sidebar.collapsed {
  width:var(--sidebar-icon);
}
#sidebar.collapsed .sb-nm,
#sidebar.collapsed .sb-ver,
#sidebar.collapsed .nav-lbl,
#sidebar.collapsed .nav-grp-label,
#sidebar.collapsed .nav-badge,
#sidebar.collapsed .sb-user,
#sidebar.collapsed .sb-online { display:none!important; }
#sidebar.collapsed .sb-brand {
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:0!important;
  height:var(--topbar)!important;
  width:var(--sidebar-icon)!important;
  box-sizing:border-box!important;
}
#sidebar.collapsed .sb-icon {
  width:38px!important;
  height:38px!important;
  border-radius:10px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  margin:0!important;
  flex-shrink:0!important;
}
#sidebar.collapsed nav { padding:4px 0; display:flex; flex-direction:column; align-items:center; }
#sidebar.collapsed .nav-item {
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:38px!important;
  height:38px!important;
  min-height:38px!important;
  padding:0!important;
  margin:3px 0!important;
  border-radius:50%!important;
  background:rgba(255,255,255,.1)!important;
  gap:0!important;
}
#sidebar.collapsed .nav-item:hover {
  background:rgba(255,255,255,.2)!important;
}
#sidebar.collapsed .nav-item.active {
  background:var(--accent)!important;
}
#sidebar.collapsed .nav-item.active::before { display:none!important; }
#sidebar.collapsed .nav-ico {
  width:16px!important; height:16px!important;
  background:none!important;
  border-radius:0!important;
  color:rgba(255,255,255,.95)!important;
}
#sidebar.collapsed .nav-item.active .nav-ico { background:none!important; color:#fff!important; }
#sidebar.collapsed .sb-footer { padding:8px 0!important; display:flex!important; justify-content:center!important; }

.sb-toggle {
  background:none;border:none;cursor:pointer;
  font-size:15px;color:rgba(255,255,255,.5);padding:5px 7px;
  border-radius:5px;line-height:1;transition:all .12s;
}
.sb-toggle:hover{background:rgba(255,255,255,.1);color:#fff}
/* topbar toggle has different context */
#topbar .sb-toggle{color:var(--txt2)}
#topbar .sb-toggle:hover{background:var(--bg2);color:var(--txt0)}
.sb-brand {
  height:var(--topbar);display:flex;align-items:center;gap:10px;
  padding:0 14px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;
}
.sb-icon{
  width:30px;height:30px;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),#2596a0);
  border-radius:7px;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;color:#fff;letter-spacing:-.5px;
  box-shadow:0 2px 8px rgba(31,111,120,.4);
}
.sb-nm{font-size:13px;font-weight:700;letter-spacing:.2px;color:#fff}
.sb-ver{font-size:9px;color:rgba(255,255,255,.5);font-family:var(--mono);letter-spacing:1px}

.nav-group{padding:6px 0}
.nav-grp-label{
  font-size:9px;font-weight:600;letter-spacing:1.5px;
  color:rgba(255,255,255,.4);padding:10px 16px 3px;text-transform:uppercase;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;cursor:pointer;border:none;background:none;
  color:rgba(255,255,255,.88);width:100%;text-align:left;
  transition:all .15s;position:relative;border-radius:0;
  margin:1px 6px;width:calc(100% - 12px);border-radius:7px;
}
.nav-item:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.95)}
.nav-item.active{background:rgba(255,255,255,.13);color:#fff}
.nav-item.active::before{content:'';position:absolute;left:-6px;top:6px;bottom:6px;
  width:3px;background:var(--accent);border-radius:2px;box-shadow:0 0 8px rgba(31,111,120,.6)}
.nav-ico{
  width:28px;height:28px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border-radius:6px;font-size:13px;
  background:var(--sidebar-ico-bg);
  transition:all .15s;
  color:rgba(255,255,255,.75);
}
.nav-item.active .nav-ico { background:rgba(255,255,255,.15); }
.nav-item:hover .nav-ico { background:rgba(255,255,255,.14); color:rgba(255,255,255,.95); }
.nav-item:hover .nav-lbl { color:#fff; }
.nav-lbl{font-size:11.5px;font-weight:500;letter-spacing:.1px;white-space:nowrap;overflow:hidden;color:rgba(255,255,255,.88)}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;
  font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.nav-badge.blue{background:var(--blue)}
.nav-badge.yellow{background:var(--yellow);color:#333}

.sb-footer{margin-top:auto;padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}
.sb-user{font-size:11px;color:rgba(255,255,255,.8)}
.sb-online{font-size:10px;color:#4ec98a;margin-top:2px;font-family:var(--mono)}

/* ═══════════════════════════════════════════
   MAIN
═══════════════════════════════════════════ */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--bg0)}
#topbar{
  height:var(--topbar);flex-shrink:0;
  background:var(--bg1);border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 var(--border),0 2px 8px rgba(28,35,51,.04);
  display:flex;align-items:center;gap:10px;padding:0 18px;
}
.tb-title{font-size:13px;font-weight:700;letter-spacing:0px;color:var(--txt0)}
.tb-sub{font-size:11px;color:var(--txt2);margin-left:6px}
.tb-space{flex:1}
.tb-search{
  display:flex;align-items:center;gap:6px;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r);padding:0 10px;height:32px;
}
.tb-search input{background:none;border:none;outline:none;color:var(--txt0);font-size:12px;width:180px}
.tb-search input::placeholder{color:var(--txt3)}
.tb-search span{color:var(--txt3);font-size:13px}

#content{flex:1;overflow-y:auto;padding:18px}
.page{display:none}
.page.active{display:block;animation:pageIn .15s ease}
#page-block-builder.active{display:flex}
@keyframes pageIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════
   COMPONENTS
═══════════════════════════════════════════ */
/* Button */
.btn{padding:7px 14px;border-radius:var(--r);border:1px solid var(--border2);background:var(--bg2);color:var(--txt1);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.btn.primary:hover{background:#1d7c84}
.btn.danger{border-color:var(--red);color:var(--red);background:rgba(188,44,44,.06)}
.btn.danger:hover{background:rgba(188,44,44,.14)}
.btn.sm{padding:4px 10px;font-size:11px}
.btn.ghost{background:none;border-color:transparent;color:var(--txt2)}
.btn.ghost:hover{background:var(--bg2);border-color:var(--border2);color:var(--txt0)}
.btn:disabled{opacity:.45;cursor:default}

/* Card */
.card{background:var(--bg1);border:1px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(28,35,51,.06)}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);gap:8px}
.card-title{font-size:12px;font-weight:600;color:var(--txt0);letter-spacing:.2px}
.card-body{padding:14px}
.card-body-0{padding:0}

/* KPI Grid */
.kpi-grid{display:grid;gap:10px;margin-bottom:14px}
.g4{grid-template-columns:repeat(4,1fr)}
.g5{grid-template-columns:repeat(5,1fr)}
.g6{grid-template-columns:repeat(6,1fr)}
.kpi-card{
  background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);
  padding:12px 14px;position:relative;overflow:hidden;cursor:default;
  transition:border-color .15s;
}
.kpi-card:hover{border-color:var(--border2)}
.kpi-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.k-g::after{background:var(--green)}.k-r::after{background:var(--red)}
.k-y::after{background:var(--yellow)}.k-b::after{background:var(--blue)}
.k-a::after{background:var(--accent)}.k-p::after{background:var(--purple)}
.k-c::after{background:var(--cyan)}.k-o::after{background:var(--orange)}
.kpi-lbl{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-weight:500}
.kpi-val{font-size:22px;font-weight:700;font-family:var(--mono);line-height:1.1;color:var(--txt0)}
.kpi-sub{font-size:10px;color:var(--txt2);margin-top:3px}

/* Table */
.tbl-wrap{overflow-x:auto;width:100%}
table{width:100%;border-collapse:collapse}
thead th{
  background:var(--bg2);color:var(--txt2);font-size:10px;font-weight:600;
  letter-spacing:.7px;text-transform:uppercase;padding:9px 12px;
  border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;
  position:sticky;top:0;z-index:1;
}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
tbody tr:hover{background:var(--bg2)}
tbody tr:last-child{border-bottom:none}
td{padding:9px 12px;color:var(--txt1);font-size:12px;white-space:nowrap;vertical-align:middle}
td.t0{color:var(--txt0);font-weight:600}
td.mono{font-family:var(--mono);font-size:11px;color:var(--txt0)}
td.dim{color:var(--txt2)}
td.actions{white-space:nowrap}
td.actions button{margin-right:4px}

/* Badge */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.2px;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.b-green{background:rgba(26,122,66,.1);color:var(--green);border:1px solid rgba(26,122,66,.25)}.b-green::before{background:var(--green)}
.b-red{background:rgba(188,44,44,.1);color:var(--red);border:1px solid rgba(188,44,44,.25)}.b-red::before{background:var(--red)}
.b-yellow{background:rgba(154,104,0,.1);color:var(--yellow);border:1px solid rgba(154,104,0,.25)}.b-yellow::before{background:var(--yellow)}
.b-blue{background:rgba(37,84,180,.1);color:var(--blue);border:1px solid rgba(37,84,180,.25)}.b-blue::before{background:var(--blue)}
.b-purple{background:rgba(110,48,204,.1);color:var(--purple);border:1px solid rgba(110,48,204,.25)}.b-purple::before{background:var(--purple)}
.b-gray{background:rgba(122,116,105,.1);color:var(--txt2);border:1px solid rgba(122,116,105,.2)}.b-gray::before{background:var(--txt2)}
.b-orange{background:rgba(190,78,8,.1);color:var(--orange);border:1px solid rgba(190,78,8,.25)}.b-orange::before{background:var(--orange)}
.b-cyan{background:rgba(8,118,160,.1);color:var(--cyan);border:1px solid rgba(8,118,160,.25)}.b-cyan::before{background:var(--cyan)}

/* Progress */
.prog{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .4s ease}
.pf-g{background:var(--green)}.pf-y{background:var(--yellow)}.pf-r{background:var(--red)}.pf-b{background:var(--blue)}.pf-a{background:var(--accent)}

/* Filter bar */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.f-input,.f-select{
  background:var(--bg1);border:1px solid var(--border2);border-radius:var(--r);
  color:var(--txt0);padding:7px 10px;font-size:12px;outline:none;transition:border-color .12s;
}
.f-input{min-width:220px}.f-input::placeholder{color:var(--txt3)}
.f-input:focus,.f-select:focus{border-color:var(--accent)}

/* Section header */
.sec-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.sec-title{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--txt0)}
.sec-space{flex:1}
.tab-row{display:flex;gap:2px;background:var(--bg2);border-radius:var(--r);padding:3px;flex-shrink:0}
.tab-btn{padding:5px 12px;border-radius:4px;border:none;background:none;color:var(--txt2);font-size:11px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}
.tab-btn.active{background:var(--bg1);color:var(--txt0);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.tab-btn:hover:not(.active){color:var(--txt0)}

/* 2-col / 3-col */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.mb14{margin-bottom:14px}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-row{display:flex;align-items:center;gap:8px}

/* Pagination */
.pag-wrap{display:flex;align-items:center;gap:5px;padding:10px 14px;border-top:1px solid var(--border)}
.pag-btn{padding:4px 9px;border-radius:4px;border:1px solid var(--border2);background:var(--bg2);color:var(--txt2);font-size:11px;cursor:pointer;transition:all .12s}
.pag-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.pag-btn.cur{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.pag-btn:disabled{opacity:.35;cursor:default}
.pag-info{margin-left:auto;font-size:10px;color:var(--txt2);font-family:var(--mono)}

/* Detail rows */
.drow{display:flex;justify-content:space-between;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--border)}
.drow:last-child{border-bottom:none}
.dk{font-size:11px;color:var(--txt2);flex-shrink:0;min-width:130px}
.dv{font-size:12px;color:var(--txt0);font-weight:500;text-align:right;word-break:break-word;max-width:60%}

/* Modal */
.overlay{display:none;position:fixed;inset:0;background:rgba(29,27,23,.5);z-index:1000;align-items:flex-start;justify-content:center;padding-top:40px;overflow-y:auto;pointer-events:none}
.overlay.open{display:flex}
.modal{background:var(--bg1);border:1px solid var(--border2);border-radius:10px;width:720px;max-width:96vw;margin:0 auto 40px;animation:mIn .18s ease;box-shadow:0 16px 60px rgba(29,27,23,.18);pointer-events:auto;position:relative}
.modal.wide{width:920px}
@keyframes mIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.mhead{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.mtitle{font-size:14px;font-weight:700;letter-spacing:-.2px;color:var(--txt0)}
.mclose{background:none;border:none;color:var(--txt2);font-size:18px;cursor:pointer;padding:2px;line-height:1;border-radius:3px}
.mclose:hover{color:var(--txt0);background:var(--bg2)}
.mbody{padding:18px}
.mfoot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.g3{grid-template-columns:1fr 1fr 1fr}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.full{grid-column:1/-1}
.fg label{font-size:10px;font-weight:600;color:var(--txt2);letter-spacing:.5px;text-transform:uppercase}
.fg .fc{
  background:var(--bg0);border:1px solid var(--border2);border-radius:var(--r);
  color:var(--txt0);padding:8px 10px;font-size:12px;outline:none;
  width:100%;transition:border-color .12s;
}
.fg .fc:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(26,107,114,.10)}
.fg .fc::placeholder{color:var(--txt3)}
textarea.fc{resize:vertical;min-height:70px;font-family:var(--font)}
.section-divider{grid-column:1/-1;margin:6px 0 2px;border-top:1px solid var(--border);padding-top:10px;font-size:10px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:1px}

/* Toast */
#toasts{position:fixed;bottom:18px;right:18px;z-index:9999;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.toast{background:var(--bg1);border:1px solid var(--border2);border-radius:var(--r);padding:10px 14px;font-size:12px;color:var(--txt0);display:flex;align-items:center;gap:8px;min-width:240px;max-width:360px;box-shadow:0 6px 24px rgba(29,27,23,.14);animation:tin .2s ease;pointer-events:auto}
.toast.s{border-left:3px solid var(--green)}.toast.e{border-left:3px solid var(--red)}.toast.i{border-left:3px solid var(--blue)}
@keyframes tin{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}

/* Tabs inside modal */
.modal-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding:0 18px;background:var(--bg2)}
.modal-tab{padding:10px 14px;border:none;background:none;color:var(--txt2);font-size:12px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s}
.modal-tab:hover{color:var(--txt0)}
.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.modal-tab-body{display:none;padding:16px 18px}
.modal-tab-body.active{display:block}

/* Timeline */
.tl{padding:4px 0}
.tl-item{display:flex;gap:12px;padding:7px 0;position:relative}
.tl-line{position:absolute;left:4px;top:16px;bottom:-7px;width:2px;background:var(--border)}
.tl-item:last-child .tl-line{display:none}
.tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px;border:2px solid var(--bg1)}
.tl-dot.g{background:var(--green)}.tl-dot.y{background:var(--yellow)}.tl-dot.r{background:var(--red)}.tl-dot.b{background:var(--blue)}
.tl-title{font-size:12px;font-weight:600;color:var(--txt0)}
.tl-sub{font-size:10px;color:var(--txt2);margin-top:2px}

/* Tag chip */
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;background:var(--bg2);border:1px solid var(--border2);color:var(--txt1)}

/* Empty */
.empty{text-align:center;padding:40px 20px;color:var(--txt2)}
.empty-ico{font-size:32px;margin-bottom:10px;opacity:.5}
.empty-txt{font-size:12px}

/* Loading */
.loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:32px;color:var(--txt2);font-size:12px}
.spin{width:16px;height:16px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* Confirm dialog */
#confirm-overlay{display:none;position:fixed;inset:0;background:rgba(29,27,23,.5);z-index:2000;align-items:center;justify-content:center}
#confirm-overlay.open{display:flex}
.confirm-box{background:var(--bg1);border:1px solid var(--border2);border-radius:10px;padding:24px;width:360px;text-align:center;box-shadow:0 12px 40px rgba(29,27,23,.16)}
.confirm-title{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--txt0)}
.confirm-msg{font-size:12px;color:var(--txt2);margin-bottom:20px}
.confirm-btns{display:flex;gap:8px;justify-content:center}

/* Hierarchy tree */
.tree-node{padding:5px 0 5px 20px;border-left:1px solid var(--border);position:relative;cursor:pointer}
.tree-node::before{content:'';position:absolute;left:0;top:14px;width:12px;height:1px;background:var(--border)}
.tree-node:hover > .tree-label{color:var(--accent)}
.tree-label{font-size:12px;color:var(--txt1);display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:4px;transition:background .1s}
.tree-label:hover{background:var(--bg2)}
.tree-label.selected{background:var(--accent-dim);color:var(--accent)}
.tree-children{padding-left:8px}
.tree-root{padding-left:0;border-left:none}
.tree-root > .tree-node{border-left:1px solid var(--border)}

/* ═══════════════════════════════════════════
   RELIABILITY MANAGEMENT – v4 Additions
═══════════════════════════════════════════ */
.rel-tabs{display:flex;gap:2px;background:var(--bg2);border-radius:var(--r);padding:3px;margin-bottom:14px}
.rel-tab{padding:6px 14px;border-radius:4px;border:none;background:none;color:var(--txt2);font-size:11px;font-weight:500;cursor:pointer;transition:all .12s}
.rel-tab.active{background:var(--bg1);color:var(--txt0);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.chart-grid-2{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px;margin-bottom:12px}
.chart-grid-3{display:grid;grid-template-columns:1fr 1fr 2fr;gap:12px;margin-bottom:12px}
.chart-box{background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);padding:14px;display:flex;flex-direction:column}
.chart-box-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-shrink:0}
.chart-box-title{font-size:11px;font-weight:600;color:var(--txt0)}
.chart-box-sub{font-size:10px;color:var(--accent);font-weight:600;margin-top:2px}
.chart-canvas-wrap{flex:1;min-height:220px;position:relative}
.rel-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rel-filter-label{font-size:10px;color:var(--txt2);font-weight:600}

/* WO Database table */
.wo-db-table{width:100%;border-collapse:collapse;font-size:11px}
.wo-db-table th{background:var(--bg3);color:var(--txt2);font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1;white-space:nowrap}
.wo-db-table td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--txt1);vertical-align:middle;white-space:nowrap;font-size:11px}
.wo-db-table tr:hover td{background:var(--bg2)}
.wo-db-table td.editable:hover{outline:1px solid var(--accent);cursor:text}
.wo-db-table td.editable:focus{outline:2px solid var(--accent);background:var(--bg1)}

/* RCFA */
.rcfa-status-open{color:var(--red);font-weight:700}
.rcfa-status-closed{color:var(--green);font-weight:700}
.rcfa-tree-wrap{background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:14px;flex:1;overflow-y:auto;min-height:300px}
.rcfa-node{margin-bottom:8px;display:flex;gap:8px;align-items:flex-start}
.rcfa-why-label{font-weight:700;color:#d97706;padding-top:6px;flex-shrink:0;font-size:11px}
.rcfa-node-body{flex:1;background:var(--bg1);border:1px solid var(--border);border-radius:6px;padding:10px}
.rcfa-node-body.is-root{border:2px solid var(--green);background:rgba(26,122,66,.04)}
.rcfa-action-matrix{border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:12px}
.rcfa-action-head{background:rgba(26,122,66,.08);padding:8px 12px;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;display:flex;gap:8px;align-items:center}
.rcfa-action-row{display:grid;grid-template-columns:120px 3fr 1fr 1fr 1fr;border-bottom:1px solid var(--border);font-size:11px}
.rcfa-action-row:last-child{border-bottom:none}
.rcfa-action-row > div{padding:7px 8px;border-right:1px solid var(--border)}
.rcfa-action-row > div:last-child{border-right:none}
.rcfa-action-header{background:var(--bg3);font-weight:600;font-size:10px;color:var(--txt2)}

/* ═══════════════════════════════════════════
   SIDEBAR – SECTION NAV (v8) — overridden by dark sidebar theme
═══════════════════════════════════════════ */
#sidebar nav { padding: 4px 0; }

/* ═══════════════════════════════════════════
   SECTION TAB ROW (inside content pages)
═══════════════════════════════════════════ */
.sec-tab-row {
  display:flex;gap:2px;flex-wrap:wrap;margin-bottom:14px;
  background:var(--bg2);border-radius:var(--r);padding:3px;
}
.sec-tab {
  padding:5px 14px;border-radius:5px;border:none;background:none;
  color:var(--txt2);font-size:11px;font-weight:600;cursor:pointer;
  transition:all .12s;white-space:nowrap;position:relative;
}
.sec-tab.active { background:var(--bg1);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08); }
.sec-tab:hover:not(.active) { color:var(--txt0); }
.sec-tab .tab-badge {
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--red);color:#fff;font-size:8px;font-weight:700;
  padding:1px 5px;border-radius:6px;margin-left:4px;min-width:14px;
}
.sec-tab-content { display:none; }
.sec-tab-content.active { display:block; }

/* ═══════════════════════════════════════════
   SMART SEARCH DROPDOWN
═══════════════════════════════════════════ */
.search-wrap { position:relative; }
.search-dropdown {
  display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--bg1);border:1px solid var(--border2);
  border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);
  z-index:9999;min-width:380px;max-height:480px;overflow:hidden;
  flex-direction:column;
}
.search-dropdown.open { display:flex; }
.search-pill-row {
  display:flex;gap:4px;padding:8px 10px 6px;
  border-bottom:1px solid var(--border);flex-shrink:0;
}
.search-pill {
  padding:3px 10px;border-radius:12px;border:1px solid var(--border2);
  background:none;font-size:11px;font-weight:600;color:var(--txt2);
  cursor:pointer;transition:all .1s;
}
.search-pill.active { background:var(--accent);border-color:var(--accent);color:#fff; }
.search-results { overflow-y:auto;flex:1; }
.search-result-item {
  display:flex;align-items:center;gap:10px;padding:8px 12px;
  cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border);
}
.search-result-item:last-child { border-bottom:none; }
.search-result-item:hover { background:var(--bg2); }
.search-result-ico { font-size:14px;width:20px;text-align:center;flex-shrink:0; }
.search-result-main { flex:1;min-width:0; }
.search-result-title { font-size:12px;font-weight:600;color:var(--txt0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.search-result-sub { font-size:10px;color:var(--txt3);margin-top:1px; }
.search-result-tag { font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--bg2);color:var(--txt2);flex-shrink:0; }
.search-no-result { padding:20px;text-align:center;color:var(--txt3);font-size:12px; }

/* ═══════════════════════════════════════════
   SIDEBAR TOGGLE
═══════════════════════════════════════════ */

/* ═══════════════════════════════════════════
   DASHBOARD TABS
═══════════════════════════════════════════ */
.dash-tab-row{display:flex;gap:2px;margin-bottom:14px;background:var(--bg2);border-radius:var(--r);padding:3px;width:fit-content}
.dash-tab{padding:6px 18px;border-radius:5px;border:none;background:none;color:var(--txt2);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}
.dash-tab.active{background:var(--bg1);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.dash-tab:hover:not(.active){color:var(--txt0)}

/* Buffer time cards */
.buf-card{border-radius:5px;padding:6px 4px;text-align:center;cursor:pointer;transition:all .1s;border:1px solid transparent;display:flex;flex-direction:column;gap:2px}
.buf-card:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.1)}
.buf-card.safe{background:rgba(26,122,66,.1);border-color:rgba(26,122,66,.2)}
.buf-card.warning{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.25)}
.buf-card.exceeded{background:rgba(188,44,44,.1);border-color:rgba(188,44,44,.2)}
.buf-card.future{background:var(--bg2);border-color:var(--border);color:var(--txt3)}
.buf-card.current{background:linear-gradient(135deg,var(--accent),#0d5f6e);border-color:var(--accent);color:#fff}
.buf-card-month{font-size:9px;font-weight:600;color:inherit;opacity:.8}
.buf-card-val{font-size:11px;font-weight:800;color:inherit}
.buf-card-lbl{font-size:8px;opacity:.7;color:inherit}

/* Availability progression */
.avail-prog-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.avail-prog-row:last-child{border-bottom:none}
.avail-prog-label{font-size:11px;color:rgba(255,255,255,.85);font-weight:600;min-width:60px}
.avail-prog-bar{flex:1;height:10px;background:rgba(255,255,255,.2);border-radius:5px;margin:0 10px;overflow:hidden}
.avail-prog-fill{height:100%;border-radius:5px;transition:width .4s ease}
.avail-prog-val{font-size:12px;font-weight:800;color:#fff;min-width:45px;text-align:right}
.avail-prog-target{font-size:9px;color:rgba(255,255,255,.6);min-width:55px;text-align:right}

/* ═══════════════════════════════════════════
   NOTIFICATIONS – v6
═══════════════════════════════════════════ */
.notif-btn{position:relative}
.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:8px;padding:1px 4px;min-width:14px;text-align:center;line-height:14px}
.nav-badge.red{background:var(--red);color:#fff}
.nav-badge.orange{background:#f59e0b;color:#fff}
.notif-panel{position:fixed;top:52px;right:12px;width:360px;max-height:480px;background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:2000;display:none;flex-direction:column;overflow:hidden}
.notif-panel.open{display:flex}
.notif-panel-head{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.notif-panel-title{font-size:12px;font-weight:700;color:var(--txt0)}
.notif-list{flex:1;overflow-y:auto}
.notif-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.notif-item:hover{background:var(--bg2)}
.notif-item.unread{background:rgba(var(--accent-rgb),.06)}
.notif-item-title{font-size:11px;font-weight:700;color:var(--txt0);margin-bottom:2px}
.notif-item-msg{font-size:10px;color:var(--txt2);margin-bottom:3px}
.notif-item-time{font-size:9px;color:var(--txt3)}
.notif-type-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:4px}
.dot-permit{background:#f59e0b}.dot-threshold{background:var(--red)}.dot-approval{background:var(--blue)}.dot-done{background:var(--green)}

/* ═══════════════════════════════════════════
   REGULATION – v6
═══════════════════════════════════════════ */
.reg-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.reg-stat-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;display:flex;align-items:center;gap:10px}
.reg-stat-icon{font-size:22px;flex-shrink:0}
.reg-stat-val{font-size:22px;font-weight:800;line-height:1}
.reg-stat-lbl{font-size:10px;color:var(--txt2);margin-top:1px}
.reg-stat-valid .reg-stat-val{color:var(--green)}
.reg-stat-expiring .reg-stat-val{color:#f59e0b}
.reg-stat-expired .reg-stat-val{color:var(--red)}
.badge-valid{background:rgba(26,122,66,.12);color:var(--green);font-weight:700}
.badge-expiring{background:rgba(245,158,11,.12);color:#d97706;font-weight:700}
.badge-expired{background:rgba(188,44,44,.12);color:var(--red);font-weight:700}
.reg-cat-tabs{display:flex;gap:2px;flex-wrap:wrap;background:var(--bg2);border-radius:var(--r);padding:3px;margin-bottom:12px}
.reg-cat-tab{padding:5px 12px;border-radius:4px;border:none;background:none;color:var(--txt2);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap}
.reg-cat-tab.active{background:var(--bg1);color:var(--txt0);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.countdown-ok{color:var(--txt2)}
.countdown-warn{color:#d97706;font-weight:700}
.countdown-crit{color:var(--red);font-weight:700;animation:pulse .8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ═══════════════════════════════════════════
   OPERATION LOG – v6
═══════════════════════════════════════════ */
.oplog-sheet-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border)}
.oplog-table{width:100%;border-collapse:collapse;font-size:11px;min-width:800px}
.oplog-table th{background:var(--bg3);color:var(--txt2);font-size:10px;font-weight:700;padding:7px 8px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-transform:uppercase;white-space:nowrap;position:sticky;top:0;z-index:2}
.oplog-table td{padding:5px 8px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:middle}
.oplog-table th.time-header{background:var(--accent);color:#fff;text-align:center;min-width:72px}
.oplog-table th.sticky-col{left:0;z-index:3}
.oplog-table td.sticky-col{position:sticky;left:0;background:var(--bg1);z-index:1;font-weight:600;color:var(--txt0)}
.oplog-cell-input{width:100%;border:none;background:transparent;text-align:center;font-size:11px;font-family:var(--mono);padding:2px;border-radius:3px}
.oplog-cell-input:focus{background:rgba(var(--accent-rgb),.1);outline:none}
.oplog-cell-abnormal{background:rgba(188,44,44,.1)!important}
.oplog-cell-abnormal input{color:var(--red);font-weight:700}
.pkg-status-draft{color:var(--txt2)}.pkg-status-submitted{color:#f59e0b;font-weight:700}.pkg-status-approved{color:var(--green);font-weight:700}.pkg-status-rejected{color:var(--red);font-weight:700}
.oplog-area-tabs{display:flex;gap:2px;flex-wrap:wrap;background:var(--bg2);border-radius:var(--r);padding:3px;margin-bottom:10px}
.oplog-area-tab{padding:5px 12px;border-radius:4px;border:none;background:none;color:var(--txt2);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}
.oplog-area-tab.active{background:var(--accent);color:#fff}

/* ═══════════════════════════════════════════
   RISK MANAGEMENT – v5 Additions
═══════════════════════════════════════════ */
/* Impact colors */
.impact-no-impact   { color:var(--green) }
.impact-derating    { color:var(--blue) }
.impact-shutdown-1  { color:var(--red) }
.impact-shutdown-2  { color:#111;font-weight:800 }
.impact-no-data     { color:var(--txt3) }

/* Availability chart wrapper */
.avail-chart-wrap{background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:12px}
.avail-chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.avail-unit-tabs{display:flex;gap:3px;background:var(--bg2);border-radius:var(--r);padding:2px}
.avail-unit-tab{padding:4px 12px;border-radius:3px;border:none;background:none;color:var(--txt2);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}
.avail-unit-tab.active{background:var(--accent);color:#fff}

/* Operation Risk grid */
.or-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-top:12px}
.or-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .15s;cursor:default}
.or-card:hover{border-color:var(--border2)}
.or-card-head{padding:9px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.or-card-name{font-size:11px;font-weight:700;color:var(--txt0);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.or-card-body{padding:8px 12px}
.or-aspect-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0;font-size:10px}
.or-aspect-label{color:var(--txt2);flex:1}
.or-impact-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-no-impact{background:var(--green)}.dot-derating{background:var(--blue)}.dot-shutdown-1{background:var(--red)}.dot-shutdown-2{background:#111}.dot-no-data{background:var(--border2)}

/* Overall status bar at top of OR card */
.or-status-bar{height:3px;width:100%}
.or-bar-no-impact{background:var(--green)}.or-bar-derating{background:var(--blue)}.or-bar-shutdown-1{background:var(--red)}.or-bar-shutdown-2{background:#111}.or-bar-no-data{background:var(--border2)}

/* Details input tabs */
.risk-detail-tabs{display:flex;gap:2px;flex-wrap:wrap;background:var(--bg2);border-radius:var(--r);padding:3px;margin-bottom:12px}
.risk-detail-tab{padding:5px 10px;border-radius:4px;border:none;background:none;color:var(--txt2);font-size:10px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap}
.risk-detail-tab.active{background:var(--bg1);color:var(--txt0);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* Pareto chart */
.pareto-wrap{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:10px}

/* Block builder */
.bb-canvas-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);min-height:500px;position:relative;overflow:hidden}
.bb-toolbar{display:flex;gap:6px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.bb-block{position:absolute;background:var(--bg1);border:2px solid var(--border2);border-radius:6px;padding:8px 12px;cursor:move;user-select:none;min-width:100px;text-align:center;font-size:11px;font-weight:600}
.bb-block.selected{border-color:var(--accent)}
.bb-block.status-ok{border-color:var(--green)}
.bb-block.status-fail{border-color:var(--red)}
.bb-block.status-partial{border-color:var(--yellow)}

/* ═══════════════════════════════════════════
   PLANNING & SCHEDULING – v3 Additions
═══════════════════════════════════════════ */
/* 52W Grid */
.plan-grid-wrap{overflow-x:auto;width:100%}
.plan-grid{border-collapse:collapse;font-size:11px;min-width:100%}
.plan-grid th,.plan-grid td{border:1px solid var(--border);padding:3px 5px;white-space:nowrap;vertical-align:middle}
.plan-grid thead tr:first-child th{background:var(--bg2);font-weight:700;text-align:center;position:sticky;top:0;z-index:2}
.plan-grid thead tr:last-child th{background:var(--bg3);font-size:10px;text-align:center;position:sticky;top:22px;z-index:2}
.plan-grid tbody td.fixed{background:var(--bg1);position:sticky;z-index:1}
.plan-grid tbody td.fixed:nth-child(1){left:0;min-width:30px}
.plan-grid tbody td.fixed:nth-child(2){left:30px;min-width:120px}
.plan-grid tbody td.fixed:nth-child(3){left:150px;min-width:130px}
.plan-grid tbody td.fixed:nth-child(4){left:280px;min-width:50px;text-align:center}
.plan-grid tbody td.fixed:nth-child(5){left:330px;min-width:40px;text-align:center}
.plan-grid tbody td.fixed:nth-child(6){left:370px;min-width:40px;text-align:center}
.plan-grid tbody td.fixed:nth-child(7){left:410px;min-width:50px;text-align:right;font-family:var(--mono)}
.plan-grid td.w-active{background:rgba(192,96,16,.18);font-weight:600;text-align:center;font-family:var(--mono);font-size:10px}
.plan-grid td.w-empty{text-align:center;color:var(--border)}
.plan-grid tr.summary-wo td{background:var(--bg3);font-weight:600;font-family:var(--mono);font-size:10px;text-align:center}
.plan-grid tr.summary-mh td{background:rgba(37,84,180,.06);font-family:var(--mono);font-size:10px;text-align:center}
.plan-grid tr.summary-util td{font-family:var(--mono);font-size:10px;text-align:center}
.util-ok{color:var(--green)}.util-warn{color:var(--yellow)}.util-over{color:var(--red)}

/* 4W Kanban board */
.week-board{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.week-col{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;min-height:400px}
.week-col-head{padding:8px 10px;background:var(--accent);color:#fff;font-size:11px;font-weight:700}
.week-col-head.t1{background:var(--red)}.week-col-head.t2{background:var(--orange)}.week-col-head.t3{background:var(--blue)}.week-col-head.t4{background:var(--green)}
.week-col-stats{display:flex;justify-content:space-between;padding:5px 8px;font-size:10px;color:var(--txt2);border-bottom:1px solid var(--border);background:var(--bg1)}
.week-items{padding:6px;display:flex;flex-direction:column;gap:5px;min-height:350px}
.sched-item{background:var(--bg1);border:1px solid var(--border);border-radius:4px;padding:7px 9px;cursor:pointer;transition:border-color .12s}
.sched-item:hover{border-color:var(--accent)}
.sched-item.pm{border-left:3px solid var(--green)}
.sched-item.cm{border-left:3px solid var(--red)}
.sched-item.pdm{border-left:3px solid var(--purple)}
.sched-item.eng{border-left:3px solid var(--cyan)}
.sched-item .si-title{font-size:11px;font-weight:600;color:var(--txt0);margin-bottom:2px}
.sched-item .si-meta{font-size:10px;color:var(--txt2)}
.sched-item .si-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}
.day-pill{display:inline-flex;gap:2px;flex-wrap:wrap;margin-top:3px}
.day-btn{width:22px;height:18px;border:1px solid var(--border2);border-radius:3px;background:var(--bg2);font-size:9px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}
.day-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.day-btn:hover:not(.active){border-color:var(--accent);color:var(--accent)}

/* Utilization bar mini */
.util-mini{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden;margin-top:3px}
.util-mini-fill{height:100%;border-radius:2px;transition:width .3s}
/* ── NEW v2: Alert bar ── */
.alert-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--r);font-size:12px;font-weight:500;margin-bottom:8px}
.alert-bar.danger{background:rgba(188,44,44,.08);border:1px solid rgba(188,44,44,.2);color:var(--red)}
.alert-bar.warning{background:rgba(154,104,0,.08);border:1px solid rgba(154,104,0,.2);color:var(--yellow)}
.alert-bar.info{background:rgba(37,84,180,.08);border:1px solid rgba(37,84,180,.2);color:var(--blue)}
.alert-ico{font-size:14px;flex-shrink:0}

/* ── NEW v2: WO type badge ── */
.b-cm{background:rgba(188,44,44,.1);color:var(--red);border:1px solid rgba(188,44,44,.25)}
.b-pm{background:rgba(26,122,66,.1);color:var(--green);border:1px solid rgba(26,122,66,.25)}
.b-pdm{background:rgba(110,48,204,.1);color:var(--purple);border:1px solid rgba(110,48,204,.25)}
.b-eng{background:rgba(8,118,160,.1);color:var(--cyan);border:1px solid rgba(8,118,160,.25)}

/* ── NEW v2: Timeline ── */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.tl-item:last-child{border-bottom:none}
.tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px}
.tl-body{flex:1;min-width:0}
.tl-title{font-size:12px;font-weight:600;color:var(--txt0)}
.tl-meta{font-size:11px;color:var(--txt2);margin-top:2px}

/* ── NEW v2: Status stepper ── */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:16px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:600;color:var(--txt3);position:relative}
.step.done{color:var(--green)}.step.active{color:var(--accent)}.step.pending{color:var(--txt3)}
.step-num{width:20px;height:20px;border-radius:50%;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.step-sep{width:24px;height:2px;background:var(--border);flex-shrink:0}
.step.done .step-sep{background:var(--green)}

/* ── NEW v2: Section divider ── */
.sec-divider{grid-column:1/-1;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--txt3);padding:8px 0 4px;border-bottom:1px solid var(--border);margin-top:6px}

/* ── NEW v2: KPI mini ── */
.kpi-mini{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-right:1px solid var(--border)}
.kpi-mini:last-child{border-right:none}
.kpi-mini-val{font-size:20px;font-weight:700;font-family:var(--mono);color:var(--txt0)}
.kpi-mini-lbl{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.4px}
.kpi-mini-row{display:flex;flex:1}

/* ── NEW v2: Permit badge ── */
.b-loto{background:rgba(190,78,8,.1);color:var(--orange);border:1px solid rgba(190,78,8,.25)}
.b-hotwork{background:rgba(188,44,44,.1);color:var(--red);border:1px solid rgba(188,44,44,.25)}
.b-confined{background:rgba(110,48,204,.1);color:var(--purple);border:1px solid rgba(110,48,204,.25)}

/* ── NEW v2: Stock level bar ── */
.stock-bar-wrap{display:flex;align-items:center;gap:8px;min-width:120px}
.stock-bar{flex:1;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.stock-bar-fill{height:100%;border-radius:2px}
.stock-ok .stock-bar-fill{background:var(--green)}
.stock-low .stock-bar-fill{background:var(--yellow)}
.stock-out .stock-bar-fill{background:var(--red)}

/* ── NEW v2: Inline badge row ── */
.badge-row{display:flex;gap:5px;flex-wrap:wrap;align-items:center}

/* ── NEW v2: Detail modal wide for WO ── */
.modal.xl{width:1100px}

/* ── NEW v2: Cost row ── */
.cost-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}
.cost-row:last-child{border-bottom:none;font-weight:700;padding-top:10px}
.cost-lbl{color:var(--txt2)}.cost-val{font-family:var(--mono);color:var(--txt0)}


/* ── Block Builder: minimal canvas & pane CSS ─────────── */
#page-block-builder .equipment-list-item {
  display:flex;justify-content:space-between;align-items:center;
  padding:6px 10px;font-size:11px;border-bottom:1px solid var(--border);
  cursor:default;
}
#page-block-builder .equipment-list-item:hover { background:var(--bg2); }
#page-block-builder .equipment-list-info { display:flex;flex-direction:column;gap:1px;flex:1;min-width:0 }
#page-block-builder .equipment-list-info .id { font-weight:700;font-size:11px;color:var(--txt0);font-family:var(--mono) }
#page-block-builder .equipment-list-info .name { font-size:10px;color:var(--txt2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap }
#page-block-builder .equipment-list-actions { flex-shrink:0;margin-left:6px }
#page-block-builder .equipment-list-actions .btn { padding:2px 8px;font-size:10px }
/* canvas toggle buttons */
#page-block-builder .info-btn {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background-color: #3498db;
    color: white;
    font-size: 10px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    user-select: none;
    transition: all 0.2s ease;
    font-family: 'Georgia', serif;
    font-style: italic;
}
#page-block-builder .info-btn:hover {
    background-color: #2980b9;
    transform: scale(1.1);
}

.details-table th.description-col,
.details-table td.description-col {
    /* Membuat kolom deskripsi fleksibel */
    min-width: 200px;
    max-width: 350px;
    white-space: normal; /* Izinkan teks untuk wrap */
    word-break: break-word; /* Paksa teks untuk wrap jika terlalu panjang */
}

.toggle-box {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 10px;
    font-weight: bold;
    cursor: pointer;
    transition: var(--transition);
    color: white;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(0,0,0,0.1);
    min-width: 35px; /* Pastikan lebar minimum konsisten */
    text-align: center;
}

.toggle-box.yes {
    background: var(--success);
}

.toggle-box.no {
    background: #9ca3af; /* Warna abu-abu */
    color: #374151;
    text-shadow: none;
}

.toggle-box:hover {
    transform: scale(1.05);
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

/* ATURAN BARU DITAMBAHKAN di bawahnya untuk mengontrol visibilitas */
#page-block-builder.active {
    display: flex;
}
#page-block-builder * {
	font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 11px;
}

#page-block-builder .top-bar {
	grid-area: top-bar;
	display: flex;
	gap: 2px;
	align-items: stretch;
}
#page-block-builder .top-section {
	background: rgba(255, 255, 255, 0.95);
	border-radius: 8px;
	padding: 8px;
	display: flex;
	align-items: center;
	gap: 15px;
}
#page-block-builder .top-section.left {
	flex-grow: 1;
	display: flex; /* Ditambahkan untuk memastikan flexbox aktif */
	justify-content: flex-end; /* Ditambahkan untuk mendorong konten ke kanan */
}

#page-block-builder .top-section.right {
	flex-grow: 1.2;
	justify-content: flex-start;
}
#page-block-builder .top-section.center {
	flex-shrink: 0;
	background: linear-gradient(45deg, #2c3e50, #34495e);
	color: white;
	flex-direction: column;
	justify-content: center;
	padding: 5px 15px;
}
#page-block-builder .top-section.center h1 {
	font-size: 16px;
	margin-bottom: 2px;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3);
}
#page-block-builder .top-section.center p {
	font-size: 9px;
	opacity: 0.9;
}
#page-block-builder .app-controls-group {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 5px;
}
#page-block-builder .canvas-area {
	grid-area: canvas;
	background: rgba(255, 255, 255, 0.98);
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	cursor: grab;
	box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.1);
}
#page-block-builder .canvas-area.pasting {
	cursor: crosshair;
}
#page-block-builder .section-title {
	font-size: 12px;
	font-weight: bold;
	color: #2c3e50;
	margin-bottom: 8px;
	padding-bottom: 4px;
	border-bottom: 1px solid #3498db;
	width: 100%;
}
#page-block-builder #selectionActions { display: none; }
#page-block-builder .form-group {
	margin-bottom: 8px;
}
#page-block-builder .form-group label {
	display: block;
	margin-bottom: 3px;
	font-weight: bold;
	color: #2c3e50;
}
#page-block-builder .form-group input, #page-block-builder .form-group select {
	width: 100%;
	padding: 6px;
	border: 1px solid #ddd;
	border-radius: 4px;
	transition: border-color 0.3s ease;
}
#page-block-builder .top-section.left .form-group input, #page-block-builder .top-section.left .form-group select {
	max-width: 150px;
}

#page-block-builder #addForm .btn-add {
	height: 29px;
}
#page-block-builder .form-group input:focus, #page-block-builder .form-group select:focus {
	outline: none;
	border-color: #3498db;
}
#page-block-builder .form-row {
	display: flex;
	gap: 5px;
	align-items: center;
}
#page-block-builder .form-row > select {
	flex-grow: 1;
}
#page-block-builder #selectionActions {
	display: none;
	border-left: 2px solid #ddd;
	padding-left: 15px;
	align-items: flex-end;
	flex-direction: row;
	gap: 10px;
}
#page-block-builder #selectionActions .form-group {
	margin-bottom: 0;
}
#page-block-builder .btn {
	padding: 6px 10px;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-weight: bold;
	font-size: 10px;
	transition: all 0.2s ease;
	text-align: center;
	color: white;
	flex-shrink: 0;
}
#page-block-builder .btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}
#page-block-builder .btn:hover:not(:disabled) {
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

#page-block-builder {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	height: 100%;
	/* display: flex; <-- Properti ini dipindahkan */
	flex-direction: column;
	font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 11px;
}

/* === REVISI BLOCK BUILDER LAYOUT START === */
#page-block-builder .main-container {
    height: 100%;
    display: grid;
    /* REVISI: Diubah menjadi satu kolom grid tunggal */
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    grid-template-areas: "main-content"; /* Hanya satu area utama */
    gap: 2px;
    padding: 5px;
    position: relative; /* ADDED: Important for absolute positioning of child elements */
    overflow: hidden; /* DITAMBAHKAN: Mencegah pane keluar dari container saat animasi */
}

/* Equipment pane hide/show */
#bbEquipmentPane.pane-hidden {
    width: 0 !important;
    min-width: 0 !important;
    overflow: hidden;
    border-right: none;
    padding: 0;
}
#bbEquipmentPane.pane-hidden #bbPaneResizer {
    display: none;
}


/* KODE BARU: Styling untuk pane equipment */
.equipment-pane {
    /* REVISI: grid-area dihapus, positioning diubah menjadi absolut */
    position: absolute;
    /* DIUBAH: top diturunkan (misal 88px) agar pane mulai tepat di bawah top-bar (sejajar canvas) */
    top: 120px;  
    left: 5px; /* Sesuaikan dengan padding container */
    bottom: 5px; /* Sesuaikan dengan padding container */
    width: 280px; /* Lebar default pane */
    z-index: 20; /* Pastikan pane berada di atas area konten utama */

    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.98); /* Sedikit lebih solid agar not transparan */
    border-radius: 8px;
    overflow: hidden;
    padding: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15); /* Tambahkan shadow agar terlihat melayang */
    
    /* REVISI: Transisi diubah untuk animasi transform (slide) */
    transition: transform 0.3s ease-in-out;
}
.pane-header {
	padding-bottom: 8px;
	margin-bottom: 8px;
	border-bottom: 1px solid #ddd;
}
#bbEquipmentSearch {
	width: 100%;
	padding: 6px;
	border: 1px solid #ddd;
	border-radius: 4px;
}
.equipment-list {
	flex-grow: 1;
	overflow-y: auto;
}
.equipment-list-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 6px 4px;
	border-bottom: 1px solid #f0f0f0;
	font-size: 10px;
}
.equipment-list-item:hover {
	background: #e9ecef;
}
.equipment-list-info {
	display: flex;
	flex-direction: column;
}
.equipment-list-info .id {
	font-weight: bold;
	color: #2c3e50;
}
.equipment-list-info .name {
	font-size: 9px;
	color: #7f8c8d;
}
.equipment-list-actions .btn {
	padding: 3px 8px;
	font-size: 9px;
}

/* KODE BARU: Styling untuk resizer pane */
.pane-resizer {
	position: absolute;
	top: 0;
	right: 0;
	width: 5px;
	height: 100%;
	cursor: col-resize;
	background: transparent;
	z-index: 10;
}

/* REVISI: Area konten utama sekarang menjadi sub-grid */
.main-content-area {
	grid-area: main-content;
	display: grid;
	grid-template-rows: auto 1fr;
	grid-template-columns: 1fr;
	grid-template-areas:
		"top-bar"
		"canvas";
	gap: 2px;
	min-width: 0; /* Mencegah overflow saat resizing */
}

/* REVISI: Styling untuk top bar */
#page-block-builder .top-bar {
	grid-area: top-bar;
	display: flex;
	gap: 2px;
	align-items: stretch;
}

/* REVISI: Hilangkan form lama dari layout */
#page-block-builder #addForm {
	display: none;
}

#page-block-builder .btn-sm { padding: 4px 8px; font-size: 9px; }
#page-block-builder .btn-add { background: linear-gradient(45deg, #27ae60, #2ecc71); }
#page-block-builder .btn-save { background: linear-gradient(45deg, #3498db, #2980b9); }
#page-block-builder .btn-action { background: linear-gradient(45deg, #9b59b6, #8e44ad); }
#page-block-builder .btn-clear { background: linear-gradient(45deg, #e74c3c, #c0392b); }
#page-block-builder .btn-edit { background: linear-gradient(45deg, #f39c12, #e67e22); }
#page-block-builder .btn-duplicate { background: linear-gradient(45deg, #1abc9c, #16a085); }
#page-block-builder .btn-group { display: flex; gap: 5px; flex-wrap: wrap; }
#page-block-builder .capacity-inputs {
	display: flex;
	gap: 15px;
	align-items: center;
	color: white;
	margin-top: 4px;
}
#page-block-builder .capacity-inputs label {
	font-size: 10px;
	font-weight: bold;
	margin-right: -10px;
}
#page-block-builder .capacity-inputs input {
	width: 60px;
	padding: 4px;
	border: 1px solid #bdc3c7;
	border-radius: 4px;
	font-size: 10px;
	text-align: right;
}
#page-block-builder .equipment-box {
	position: absolute;
	transform-origin: top left;
	background: linear-gradient(45deg, #27ae60, #2ecc71);
	border: 2px solid #2c3e50;
	border-radius: 6px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	color: white;
	font-weight: bold;
	text-align: center;
	padding: 8px 4px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
	transition: all 0.3s ease;
	user-select: none;
	z-index: 2;
}
#page-block-builder .equipment-box:hover { border-color: #f1c40f; }
#page-block-builder .equipment-box.selected { border-color: #e74c3c; box-shadow: 0 0 15px rgba(231, 76, 60, 0.5); border-width: 3px; }
#page-block-builder .equipment-box.failed { background: linear-gradient(45deg, #e74c3c, #c0392b); opacity: 0.8; }
#page-block-builder .equipment-box.cascade-failed { background: linear-gradient(45deg, #f39c12, #e67e22); opacity: 0.9; }
#page-block-builder .equipment-box.degraded-source { background: linear-gradient(45deg, #3498db, #2980b9); }
#page-block-builder .equipment-box.degraded-cascade { background: linear-gradient(45deg, #87ceeb, #5faade); opacity: 0.9; }
#page-block-builder .equipment-box.final-output { border-style: dashed; border-color: #9b59b6; border-width: 3px; }
#page-block-builder .equipment-info { display: flex; flex-direction: column; align-items: center; gap: 2px; width: 100%; padding: 0 5px; }
#page-block-builder .equipment-availability-display { font-size: 16px; font-weight: bold; color: white; text-shadow: 1px 1px 2px rgba(0,0,0,0.4); margin-bottom: 2px; }
#page-block-builder .name-label-main { font-size: 12px; font-weight: bold; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#page-block-builder .name-label-sub { font-size: 9px; opacity: 0.9; }
#page-block-builder .connection-point { position: absolute; width: 8px; height: 8px; background: #27ae60; border: 1px solid #fff; border-radius: 50%; cursor: crosshair; transition: all 0.2s ease; z-index: 5; }
#page-block-builder .connection-point:hover { transform: scale(1.3); background: #2ecc71; }
#page-block-builder .connection-point.input { left: -4px; top: 50%; transform: translateY(-50%); }
#page-block-builder .connection-point.output { right: -4px; top: 50%; transform: translateY(-50%); }
#page-block-builder .connection-point.top { top: -4px; left: 50%; transform: translateX(-50%); }
#page-block-builder .connection-point.bottom { bottom: -4px; left: 50%; transform: translateX(-50%); }
#page-block-builder .final-output-toggle { position: absolute; top: 3px; right: 3px; cursor: pointer; z-index: 10; accent-color: #9b59b6; transform: scale(0.8); }
#page-block-builder .toggles-container { display: flex; flex-wrap: wrap; gap: 4px; justify-content: center; padding: 4px 0; margin-top: 5px; width: 100%; }
#page-block-builder .canvas-toggle { width: 30px; height: 16px; border-radius: 8px; position: relative; cursor: pointer; transition: background-color 0.3s ease; border: 1px solid rgba(255, 255, 255, 0.5); display: flex; align-items: center; font-family: 'Segoe UI Symbol', sans-serif; color: white; font-size: 10px; font-weight: bold; }
#page-block-builder .canvas-toggle::before { content: ''; position: absolute; top: 1px; width: 12px; height: 12px; background-color: white; border-radius: 50%; transition: all 0.3s ease; }
#page-block-builder .canvas-toggle.is-run { background-color: #27ae60; }
#page-block-builder .canvas-toggle.is-run::before { content: '✓'; left: 15px; padding-left: 1px; color: #27ae60; }
#page-block-builder .canvas-toggle.is-down { background-color: #e74c3c; }
#page-block-builder .canvas-toggle.is-down::before { content: '✗'; left: 2px; padding-left: 1px; color: #e74c3c; }
#page-block-builder #canvas-container { position: relative; width: 100%; height: 100%; }
#page-block-builder #workspace-canvas { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#page-block-builder #outputsPanel { display: flex; gap: 10px; flex-wrap: nowrap; }
#page-block-builder .availability-display-wrapper { display: flex; flex-direction: column; }
#page-block-builder .availability-display { background: linear-gradient(45deg, #e74c3c, #c0392b); color: white; padding: 10px; border-radius: 6px; text-align: center; width: 120px; }
#page-block-builder .availability-display.high { background: linear-gradient(45deg, #27ae60, #2ecc71); }
#page-block-builder .availability-display.medium { background: linear-gradient(45deg, #f39c12, #e67e22); }
#page-block-builder .availability-display.degraded-output { background: linear-gradient(45deg, #3498db, #2980b9); }
#page-block-builder .availability-output-name { font-weight: bold; margin-bottom: 3px; }
#page-block-builder .availability-value { font-size: 18px; font-weight: bold; }
#page-block-builder .availability-mw { font-size: 12px; font-weight: normal; opacity: 0.9; margin-top: 2px; }
#page-block-builder .availability-unit-title { font-size: 12px; font-weight:bold; margin-bottom: 4px; color: #2c3e50; display: flex; justify-content: space-between; align-items: center; }
#page-block-builder .zoom-controls { display: flex; align-items: center; gap: 5px; background: rgba(255, 255, 255, 0.95); padding: 4px 8px; border-radius: 6px; }
#page-block-builder #zoomSlider { width: 100px; cursor: pointer; }
#page-block-builder #zoomValue { font-size: 10px; font-weight: bold; color: #34495e; width: 35px; text-align: right; }

/* ── Dual Modal side-by-side ── */
#bbDualContainer {
  display: none; position: fixed; inset: 0;
  background: rgba(29,27,23,.5); z-index: 6100;
  align-items: flex-start; justify-content: center;
  padding-top: 30px; gap: 12px; overflow-y: auto;
}
#bbDualContainer.open { display: flex; }
#bbDualMain {
  background: var(--bg1); border: 1px solid var(--border2); border-radius: 10px;
  width: 860px; max-width: 54vw; max-height: 88vh; overflow: hidden;
  display: flex; flex-direction: column; flex-shrink: 0;
  animation: mIn .18s ease; box-shadow: 0 16px 60px rgba(29,27,23,.18);
}
#bbDualSide {
  background: var(--bg1); border: 1px solid var(--border2); border-radius: 10px;
  width: 480px; max-width: 38vw; max-height: 88vh; overflow: hidden;
  display: flex; flex-direction: column; flex-shrink: 0;
  animation: mIn .18s ease; box-shadow: 0 16px 60px rgba(29,27,23,.18);
}
#bbDualMain .mhead, #bbDualSide .mhead {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:1px solid var(--border); flex-shrink:0;
}
#bbDualMain .mbody, #bbDualSide .mbody { overflow-y:auto; flex:1; padding:16px; }
#bbDualMain .mfoot, #bbDualSide .mfoot {
  display:flex; justify-content:flex-end; gap:8px;
  padding:10px 16px; border-top:1px solid var(--border); flex-shrink:0;
}
/* BB modal content CSS */
#bbDynModal .modal { max-width:900px; width:96vw; max-height:92vh; overflow:hidden; display:flex; flex-direction:column; }
#bbDynModal .mbody { overflow-y:auto; flex:1; padding:16px; }
#bbDynModal .alert { padding:10px 14px; border-radius:6px; margin-bottom:0; font-size:11px; }
#bbDynModal .alert-info { background:rgba(37,99,235,.07); border:1px solid rgba(37,99,235,.2); color:var(--txt1,#334155); }
#bbDynModal .details-table { width:100%; border-collapse:collapse; font-size:11px; }
#bbDynModal .details-table th { background:var(--bg2,#f1f5f9); color:var(--txt2,#64748b); font-weight:600; padding:6px 8px; text-align:left; border-bottom:2px solid var(--border,#e2e8f0); white-space:nowrap; }
#bbDynModal .details-table td { padding:5px 8px; border-bottom:1px solid var(--border,#e2e8f0); vertical-align:middle; font-size:11px; }
#bbDynModal .table-container { max-height:280px; overflow-y:auto; border:1px solid var(--border,#e2e8f0); border-radius:6px; }
#bbDynModal .status-badge { display:inline-block; padding:1px 6px; border-radius:10px; font-size:10px; font-weight:600; text-transform:uppercase; }
#bbDynModal .status-badge.DOWN, #bbDynModal .status-badge.down { background:rgba(239,68,68,.15); color:#dc2626; }
#bbDynModal .status-badge.STANDBY, #bbDynModal .status-badge.standby { background:rgba(100,116,139,.15); color:#475569; }
#bbDynModal .status-badge.RECOND_BREAKDOWN { background:rgba(234,179,8,.15); color:#92400e; }
#bbDynModal .status-badge.RECOND_OVERHAUL { background:rgba(59,130,246,.15); color:#1d4ed8; }
#bbDynModal .btn-sm { padding:2px 8px; font-size:10px; height:22px; line-height:18px; }
#bbDynModal .btn-success { background:#16a34a; color:white; border:none; }
#bbDynModal .btn-danger  { background:#dc2626; color:white; border:none; }
#bbDynModal .btn-info    { background:#2563eb; color:white; border:none; }
#bbDynModal .btn-secondary { background:var(--bg2,#f1f5f9); color:var(--txt1,#334155); border:1px solid var(--border); }
/* hilp-indicator */
.hilp-indicator { display:inline-block; padding:2px 6px; border-radius:12px; font-size:10px; font-weight:bold; text-transform:uppercase; margin-left:4px; color:white; }
.hilp-indicator.hilp     { background:linear-gradient(135deg,#dc2626,#b91c1c); border:1px solid #991b1b; }
.hilp-indicator.non-hilp { background:linear-gradient(135deg,#16a34a,#15803d); border:1px solid #166534; }
/* btn variants */
#page-block-builder .btn-success  { background:linear-gradient(45deg,#27ae60,#2ecc71); color:white; border:none; }
#page-block-builder .btn-secondary { background:var(--bg2); color:var(--txt1); border:1px solid var(--border); }
#page-block-builder .btn-danger   { background:linear-gradient(45deg,#e74c3c,#c0392b); color:white; border:none; }
#page-block-builder .btn-info     { background:linear-gradient(45deg,#3498db,#2980b9); color:white; border:none; }
#page-block-builder .btn-clear    { background:linear-gradient(45deg,#e74c3c,#c0392b); color:white; }


#page-block-builder .btn-view {
    background: linear-gradient(45deg, #c06010, #e07820);
    color: white;
    border: none;
    font-weight: 600;
}
#page-block-builder .btn-view:hover { background: linear-gradient(45deg, #a05010, #c06010); }


/* ── Block Builder Tabs ── */
#bbTabBar {
  display: flex;
  align-items: flex-end;
  gap: 0;
  padding: 0 8px;
  background: var(--bg2);
  border-bottom: 2px solid var(--border);
  overflow-x: auto;
  flex-shrink: 0;
  scrollbar-width: none;
  height: 32px;
}
#bbTabBar::-webkit-scrollbar { display: none; }
.bb-tab {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 10px;
  height: 28px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-bottom: none;
  border-radius: 5px 5px 0 0;
  cursor: pointer;
  font-size: 11px;
  color: var(--txt2);
  white-space: nowrap;
  user-select: none;
  position: relative;
  top: 2px;
  transition: background 0.15s;
  flex-shrink: 0;
}
.bb-tab:hover { background: var(--bg1); color: var(--txt0); }
.bb-tab.active {
  background: var(--bg1);
  color: var(--txt0);
  font-weight: 600;
  border-color: var(--border);
  border-bottom: 2px solid var(--bg1);
  z-index: 1;
}
.bb-tab-name {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bb-tab-name[contenteditable="true"] {
  outline: none;
  border-bottom: 1px solid var(--accent);
  min-width: 40px;
  padding: 0 2px;
}
.bb-tab-close {
  width: 14px; height: 14px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; line-height: 1;
  color: var(--txt3);
  cursor: pointer;
  flex-shrink: 0;
}
.bb-tab-close:hover { background: rgba(188,44,44,.15); color: var(--red); }
.bb-tab-add {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  font-size: 16px; line-height: 1;
  color: var(--txt3);
  cursor: pointer;
  border-radius: 50%;
  flex-shrink: 0;
  top: 2px;
  position: relative;
}
.bb-tab-add:hover { background: var(--bg1); color: var(--accent); }
.bb-tab-replicate {
  display: flex; align-items: center; gap: 3px;
  padding: 0 8px; height: 24px;
  font-size: 10px; font-weight: 600;
  color: var(--txt2);
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  top: 2px;
  position: relative;
  white-space: nowrap;
}
.bb-tab-replicate:hover { background: var(--accent); color: #fff; border-color: var(--accent); }



/* === Modal2 animation === */

@keyframes slideInRight { from{transform:translateX(20px);opacity:0} to{transform:translateX(0);opacity:1} }
#ov-modal2.open { display:flex; }

/* When modal2 is open: modal1 shifts left, modal2 appears right */
body.modal2-open .overlay.open {
  justify-content:flex-start;
  padding-left:40px;
  padding-right:460px;
  pointer-events:none;  /* modal1 non-interactive */
}
body.modal2-open .overlay.open .modal {
  pointer-events:none;
  opacity:.7;
  filter:brightness(.95);
  transition:all .2s;
}
#ov-modal2.open {
  pointer-events:auto;
}
