
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --void:#07090d;--deep:#0b0e14;--carbon:#121820;--plate:#18202e;--steel:#1e2838;
  --rim:#263042;--wire:#30404e;
  --muted:#9aaab8;--soft:#c4cfd8;--bright:#e6ecf4;--white:#f5f7fc;
  --gold:#ffd500;--gold2:#ffe040;--gold3:#fff099;--gf:rgba(255,213,0,0.08);--gg:rgba(255,213,0,0.18);
  --ember:#d45f2e;--jade:#2eab6f;--ice:#3b82c4;--crimson:#c03040;
  --r:8px;--r2:12px;--r3:16px;
  --nav-h:66px;--topbar-h:60px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}
html{background:var(--void);-webkit-text-size-adjust:100%}
body{background:var(--void);color:var(--bright);font-family:'Inter',sans-serif;font-size:15px;line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.is-ios-standalone{height:100dvh;min-height:100dvh;overflow:hidden;-webkit-overflow-scrolling:auto}

/* ── TOPBAR ── */
.topbar{
  position:fixed;top:0;left:0;right:0;
  height:calc(var(--topbar-h) + var(--safe-top));
  padding-top:var(--safe-top);
  background:rgba(8,10,13,0.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--rim);
  display:flex;align-items:center;justify-content:space-between;
  padding-left:16px;padding-right:16px;
  z-index:50;
}
.topbar-left{display:flex;align-items:center;gap:12px}
.hamburger{width:40px;height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:var(--r);background:var(--plate);border:1px solid var(--wire);cursor:pointer;flex-shrink:0}
.hamburger span{display:block;width:16px;height:1.5px;background:var(--soft);border-radius:2px;transition:all .25s}
.page-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;color:var(--gold);text-transform:uppercase;line-height:1}
.page-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:600;color:var(--white);line-height:1.1}
.topbar-right{display:flex;align-items:center;gap:8px}
.tb-btn{width:38px;height:38px;border-radius:var(--r);background:var(--plate);border:1px solid var(--wire);color:var(--soft);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:all .2s;flex-shrink:0}
.tb-btn:hover{border-color:var(--gold);color:var(--gold2)}
.tb-btn{position:relative}
.tb-dot{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--crimson);color:#fff;font-size:10px;line-height:17px;text-align:center;border:1px solid rgba(0,0,0,.4)}
.tb-btn.primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--void);border-color:transparent;font-weight:700}
/* Panel de notificaciones global */
.notif-panel{
  position:fixed;
  top:calc(var(--topbar-h) + var(--safe-top) + 8px);
  right:12px;
  width:min(380px,calc(100vw - 24px));
  max-height:65vh;
  background:rgba(11,15,20,.96);
  border:1px solid var(--wire);
  border-radius:12px;
  z-index:120;
  box-shadow:0 20px 40px rgba(0,0,0,.45);
  overflow:hidden;
}
.notif-panel-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--wire)}
.notif-panel-list{padding:8px;display:grid;gap:7px;max-height:52vh;overflow:auto}
.notif-item{border:1px solid var(--wire);border-radius:9px;padding:8px;background:rgba(255,255,255,.02)}
.notif-item.unread{border-color:rgba(255,213,0,.35);background:rgba(255,213,0,.06)}
.notif-item-title{font-size:12px;font-weight:700;color:var(--bright)}
.notif-item-msg{font-size:12px;color:var(--soft);margin-top:2px}
.notif-item-date{font-size:11px;color:var(--muted);margin-top:3px}

/* ── MAIN SCROLL ── */
.main-scroll{
  position:fixed;top:calc(var(--topbar-h) + var(--safe-top));
  left:0;right:0;
  bottom:calc(var(--nav-h) + var(--safe-bot));
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  background:var(--void);
}
body.is-ios-standalone .main-scroll{
  position:fixed;
  top:calc(var(--topbar-h) + var(--safe-top));
  left:0;right:0;
  bottom:calc(var(--nav-h) + var(--safe-bot));
  height:auto;
  margin-top:0;
  padding-bottom:18px;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}
.page{display:none;padding:16px 14px 24px;animation:pgIn .25s ease both}
.page.active{display:block}
@keyframes pgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── BOTTOM NAV ── */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  height:calc(var(--nav-h) + var(--safe-bot));
  padding-bottom:var(--safe-bot);
  background:rgba(5,6,8,0.97);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid var(--rim);
  display:flex;align-items:stretch;
  z-index:50;
}
body.is-ios-standalone .topbar,
body.is-ios-standalone .bottom-nav{
  transform:translate3d(0,0,0);
  -webkit-transform:translate3d(0,0,0);
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
body.is-ios-standalone .bottom-nav{
  position:fixed!important;
  left:0;right:0;bottom:0!important;
  width:100%;
  min-height:calc(var(--nav-h) + var(--safe-bot));
  overflow:hidden;
}
.nav-tab{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;cursor:pointer;position:relative;
  color:var(--muted);transition:color .2s;
  min-width:0;padding:8px 4px;
}
.nav-tab svg{width:20px;height:20px;stroke-width:1.75;flex-shrink:0;transition:stroke .2s}
.nav-tab span{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:0.3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;max-width:52px;text-overflow:ellipsis;text-align:center}
.nav-tab.active{color:var(--gold2)}
.nav-tab.active::after{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--gold);border-radius:0 0 2px 2px}
.nav-badge{position:absolute;top:6px;right:calc(50% - 18px);background:var(--crimson);color:#fff;font-size:14px;font-weight:700;padding:1px 4px;border-radius:10px;font-family:'Barlow Condensed',sans-serif;min-width:14px;text-align:center;line-height:14px;height:14px}
.nav-badge.gold{background:var(--gold);color:#0a0c10}

/* ── SIDEBAR DRAWER ── */
.sidebar-veil{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:80;display:none;opacity:0;transition:opacity .3s}
.sidebar-veil.open{display:block;opacity:1}
.sidebar{
  position:fixed;top:0;left:-280px;width:280px;height:100%;
  background:linear-gradient(180deg,var(--carbon) 0%,var(--deep) 100%);
  border-right:1px solid var(--wire);
  z-index:90;display:flex;flex-direction:column;
  transition:left .3s cubic-bezier(.22,1,.36,1);
  overflow:hidden;
}
.sidebar.open{left:0}
.sidebar::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.sb-head{padding:calc(20px + var(--safe-top)) 22px 20px;border-bottom:1px solid var(--rim)}
.sb-logo-eye{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:6px}
.sb-logo-name{font-family:'Inter',sans-serif;font-size:20px;font-weight:700;color:var(--white);line-height:1}
.sb-logo-name em{font-style:italic;color:var(--gold2)}
.sb-logo-sub{font-family:'Barlow Condensed',sans-serif;font-size:15px;letter-spacing:3px;color:var(--soft);text-transform:uppercase;margin-top:4px}
.sb-body{flex:1;overflow-y:auto;padding:12px 10px;scrollbar-width:none}
.sb-body::-webkit-scrollbar{display:none}
.sb-cat{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;color:var(--wire);text-transform:uppercase;padding:0 10px;margin:14px 0 5px}
.sb-cat:first-child{margin-top:4px}
.sb-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);cursor:pointer;color:var(--muted);font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:500;letter-spacing:.3px;transition:all .15s;border:1px solid transparent;margin-bottom:1px;position:relative;user-select:none}
.sb-item:active{background:var(--plate)}
.sb-item.active{color:var(--gold2);background:var(--gf);border-color:rgba(255,213,0,.15)}
.sb-item.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:2px;background:var(--gold);border-radius:0 2px 2px 0}
.sb-item svg{width:15px;height:15px;stroke-width:1.75;flex-shrink:0}
.sb-item.is-soon{opacity:.62;cursor:not-allowed}
.sb-item.is-soon:hover{background:transparent;border-color:transparent}
.sb-soon{margin-left:auto;padding:2px 6px;border-radius:999px;border:1px solid rgba(255,213,0,.28);background:rgba(255,213,0,.08);color:var(--gold2);font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;white-space:nowrap}
.sb-item.is-soon svg{opacity:.55}
.sb-badge{margin-left:auto;background:var(--crimson);color:#fff;font-size:14px;font-weight:700;padding:1px 5px;border-radius:10px;font-family:'Barlow Condensed',sans-serif}
.sb-badge.gold{background:var(--gold);color:var(--void)}
.sb-badge.jade{background:var(--jade);color:var(--void)}
.sb-foot{padding:14px 16px;border-top:1px solid var(--rim);padding-bottom:calc(14px + var(--safe-bot))}
.sb-user{display:flex;align-items:center;gap:10px}
.sb-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--ember));display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--void);flex-shrink:0}
.sb-uname{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;color:var(--bright)}
.sb-urole{font-size:14px;color:var(--soft);margin-top:1px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--jade);animation:lp 2.5s ease-in-out infinite;flex-shrink:0;margin-left:auto}
@keyframes lp{0%,100%{box-shadow:0 0 0 0 rgba(46,171,111,.5)}50%{box-shadow:0 0 0 5px rgba(46,171,111,0)}}
.sb-logout{margin-top:10px;width:100%;padding:9px;background:transparent;border:1px solid var(--wire);border-radius:var(--r);color:var(--soft);font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:1px;cursor:pointer;text-transform:uppercase;transition:all .2s}
.sb-logout:hover{border-color:var(--crimson);color:#e96070}

/* ── FAB ── */
.fab{
  position:fixed;bottom:calc(var(--nav-h) + var(--safe-bot) + 14px);right:16px;
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:var(--void);font-size:24px;font-weight:300;
  border:none;cursor:pointer;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(255,213,0,.45);
  z-index:40;transition:transform .15s;line-height:1;
}
.fab:active{transform:scale(.9)}
.fab.show{display:flex}

/* ── KPI STRIP ── */
.kpi-strip{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rim);border:1px solid var(--wire);border-radius:var(--r2);overflow:hidden;margin-bottom:16px}
.kpi-cell{background:var(--plate);padding:14px 13px;position:relative;overflow:hidden}
.kpi-cell:last-child:nth-child(odd){grid-column:1/-1}
.kpi-accent{height:2px;width:22px;border-radius:2px;margin-bottom:8px}
.kpi-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:2px;color:var(--soft);text-transform:uppercase;margin-bottom:4px}
.kpi-num{font-family:'Inter',sans-serif;font-size:28px;font-weight:700;line-height:1;margin-bottom:2px}
.kpi-sub{font-size:14px;color:var(--soft);font-weight:300}
.kc-jade .kpi-num{color:var(--jade)}.kc-jade .kpi-accent{background:var(--jade)}
.kc-gold .kpi-num{color:var(--gold2)}.kc-gold .kpi-accent{background:var(--gold)}
.kc-crimson .kpi-num{color:var(--crimson)}.kc-crimson .kpi-accent{background:var(--crimson)}
.kc-ice .kpi-num{color:var(--ice)}.kc-ice .kpi-accent{background:var(--ice)}
.kc-dim .kpi-num{color:var(--soft)}.kc-dim .kpi-accent{background:var(--wire)}
.kc-ember .kpi-num{color:var(--ember)}.kc-ember .kpi-accent{background:var(--ember)}

/* ── SECTION ROW ── */
.sec-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px;flex-wrap:wrap}
.sec-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:600;color:var(--white);display:flex;align-items:baseline;gap:8px}
.sec-count{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:500;letter-spacing:1px;color:var(--soft)}

/* ── FILTER SCROLL ── */
.filter-scroll{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.filter-scroll::-webkit-scrollbar{display:none}
.search-wrap{margin-bottom:10px}
.search-field{display:flex;align-items:center;gap:9px;background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:10px 13px;transition:border-color .2s}
.search-field:focus-within{border-color:rgba(255,213,0,.4)}
.search-field input{background:none;border:none;outline:none;color:var(--bright);font-family:'Inter',sans-serif;font-size:16px;width:100%;min-height:24px}
.search-field input::placeholder{color:var(--soft);font-size:14px}
.chip{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:100px;border:1px solid var(--wire);background:transparent;color:var(--soft);font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.chip.active{background:var(--gf);border-color:rgba(255,213,0,.35);color:var(--gold2)}
.chip-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}

/* ── CARDS ── */
.cards-list{display:flex;flex-direction:column;gap:8px}
.eq-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;cursor:pointer;transition:border-color .2s;position:relative;overflow:hidden}
.eq-card:active{background:var(--plate)}
.eq-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;gap:8px}
.eq-card-id{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;color:var(--gold);margin-bottom:2px}
.eq-card-name{font-family:'Inter',sans-serif;font-size:16px;font-weight:600;color:var(--white);line-height:1.1}
.eq-card-brand{font-size:15px;color:var(--soft);font-weight:300;margin-top:2px}
.eq-card-body{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.eq-card-meta{display:flex;align-items:center;gap:14px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(28,35,51,.7)}
.eq-card-loc{display:flex;align-items:center;gap:5px;font-size:15px;color:var(--soft);font-weight:300}
.eq-card-mant{font-family:'Barlow Condensed',sans-serif;font-size:15px;margin-left:auto}
/* ── EQ CARD QUICK LINKS ── */
.eq-card-links{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--wire)}
.eq-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border-radius:var(--r);border:1px solid var(--wire);background:var(--steel);color:var(--soft);font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.3px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;min-height:52px;position:relative}
.eq-link:active{opacity:.7}
.eq-link-active{border-color:rgba(255,213,0,.35);background:rgba(255,213,0,.07);color:var(--gold)}
.eq-link-warn{border-color:rgba(192,48,64,.35);background:rgba(192,48,64,.08);color:#e96070}
.eq-link-ghost{grid-column:span 4;border-color:var(--rim);background:transparent;color:var(--muted);flex-direction:row;min-height:36px;font-size:12px;justify-content:center}
.eq-link-ico{font-size:16px;line-height:1}
.eq-link-num{font-size:13px;font-weight:800;line-height:1}
.eq-link-lbl{font-size:10px;color:inherit;opacity:.85}
.eq-link-badge{position:absolute;top:4px;right:4px;background:var(--gold);color:#0a0c10;font-size:9px;font-weight:800;padding:1px 5px;border-radius:6px;line-height:1.5}
.eq-link-badge.warn{background:var(--crimson);color:#fff}


.cap-bar-w{width:40px;height:3px;background:var(--rim);border-radius:3px;overflow:hidden;flex-shrink:0}
.cap-fill{height:100%;border-radius:3px}
.cap-num{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;color:var(--bright)}

/* ── STATUS PILLS ── */
.spill{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:100px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.s-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.sp-op{background:rgba(46,171,111,.1);border:1px solid rgba(46,171,111,.2);color:#4fd49a}
.sp-op .s-dot{background:var(--jade);animation:sop 2s ease-in-out infinite}
@keyframes sop{0%,100%{box-shadow:0 0 0 0 rgba(46,171,111,.6)}50%{box-shadow:0 0 0 3px rgba(46,171,111,0)}}
.sp-maint{background:rgba(255,213,0,.08);border:1px solid rgba(255,213,0,.2);color:var(--gold3)}
.sp-maint .s-dot{background:var(--gold)}
.sp-fs{background:rgba(192,48,64,.1);border:1px solid rgba(192,48,64,.25);color:#e96070}
.sp-fs .s-dot{background:var(--crimson)}
.sp-sb{background:rgba(59,130,196,.1);border:1px solid rgba(59,130,196,.2);color:#6fb0e8}
.sp-sb .s-dot{background:var(--ice)}
.sp-pend{background:rgba(212,95,46,.1);border:1px solid rgba(212,95,46,.25);color:#e8895a}
.sp-pend .s-dot{background:var(--ember)}
.sp-comp{background:rgba(46,171,111,.1);border:1px solid rgba(46,171,111,.2);color:#4fd49a}
.sp-comp .s-dot{background:var(--jade)}

/* ── TABLE (desktop) ── */
.tframe{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r2);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead{background:var(--deep);border-bottom:1px solid var(--wire)}
thead th{padding:11px 14px;text-align:left;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:2.5px;color:var(--soft);text-transform:uppercase;white-space:nowrap}
tbody tr{border-bottom:1px solid rgba(28,35,51,.8);cursor:pointer;transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:active{background:var(--plate)}
td{padding:12px 14px;font-size:14px;color:var(--bright);vertical-align:middle}
.cell-id .eq-id{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:1.5px;color:var(--gold);display:block}
.cell-id .eq-name{font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--white)}

.mc{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:500}
.mc.over{color:var(--crimson)}.mc.soon{color:var(--gold2)}.mc.fine{color:var(--soft)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;transition:all .2s;justify-content:center;min-height:40px}
.btn-sm{padding:7px 12px;min-height:34px;border-radius:12px;font-size:12px;letter-spacing:1.1px;gap:5px;box-shadow:none}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0c10;box-shadow:0 4px 16px rgba(255,213,0,.25)}
.btn-gold:active{opacity:.85}
.btn-ghost{background:transparent;color:var(--soft);border:1px solid var(--wire)}
.btn-ghost:active{background:var(--plate)}
.btn-danger{background:rgba(192,48,64,.15);color:#e96070;border:1px solid rgba(192,48,64,.25)}
.btn-jade{background:rgba(46,171,111,.15);color:#4fd49a;border:1px solid rgba(46,171,111,.25)}
.btn-ice{background:rgba(59,130,196,.15);color:#7bbce8;border:1px solid rgba(59,130,196,.3)}
#tecnicoVeil .mfoot{justify-content:flex-end}
#tecnicoVeil .mfoot .btn{flex:0 0 auto;min-width:120px;padding:8px 14px;min-height:36px;font-size:13px;letter-spacing:1.1px}
#tecnicoVeil .mfoot .btn-ghost{min-width:108px}
.supply-inline-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px}
.supply-inline-btn{padding:7px 12px;min-height:34px;font-size:13px;letter-spacing:.4px;text-transform:none;border-radius:10px;justify-content:flex-start}
.supply-table-panel{padding:14px}
.supply-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.supply-table-heading{display:grid;gap:4px}
.supply-table-kicker{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;letter-spacing:1.5px;color:var(--bright);text-transform:uppercase}
.supply-table-sub{font-size:12px;color:var(--muted)}
.supply-table-search{min-width:min(420px,100%);flex:1 1 320px}
.supply-table-scroll{max-height:min(68vh,760px)}
.supply-workflow-table{min-width:1040px}
.supply-workflow-table td{vertical-align:top}
.supply-table-primary{font-size:11px;font-weight:700;color:var(--gold);margin-bottom:3px}
.supply-table-title{font-size:13px;font-weight:600;color:var(--bright);line-height:1.35}
.supply-table-meta{font-size:11px;color:var(--soft);margin-top:4px;line-height:1.45}
.supply-table-note{font-size:11px;color:var(--muted);margin-top:6px;line-height:1.45}
.supply-table-accent{color:var(--gold)}
.supply-table-chip{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.08);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--bright)}
.supply-table-actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.supply-compact-card{padding:10px 12px!important}
.supply-compact-head{margin-bottom:6px!important}
.supply-compact-actions{margin-top:6px!important}
.supply-compact-summary{margin-top:6px!important;padding:8px 10px!important}
.supply-compact-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.supply-compact-summary-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:6px}
.supply-dense-card{padding:9px 12px!important}
.supply-dense-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;margin-bottom:4px}
.supply-dense-title{display:flex;align-items:center;gap:8px;min-width:0}
.supply-dense-folio{font-size:11px;font-weight:700;color:var(--gold);white-space:nowrap}
.supply-dense-name{font-size:13px;font-weight:600;color:var(--bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.supply-dense-meta{font-size:11px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;min-width:0}
.supply-dense-summary{margin-top:4px;padding:6px 8px!important}
.supply-dense-summary-grid{display:grid;grid-template-columns:1.25fr .8fr .8fr auto;gap:8px;align-items:center}
.supply-dense-actions{margin-top:5px!important}
.supply-dense-actions .supply-inline-btn{padding:5px 10px;min-height:30px;font-size:12px}
@media (max-width: 900px){
  .supply-table-panel{padding:12px}
  .supply-table-search{min-width:100%}
  .supply-compact-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .supply-dense-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* ── MEDIA UPLOADER ── */
.media-uploader{margin-top:4px}
.media-drop{
  border:2px dashed var(--wire);border-radius:var(--r2);
  padding:22px 14px;text-align:center;cursor:pointer;
  transition:all .2s;background:var(--plate);
  position:relative;overflow:hidden;
  min-height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.media-drop:hover,.media-drop.drag-over{border-color:var(--gold);background:var(--gf)}
.media-drop:active{border-color:var(--gold);background:var(--gf)}
.media-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;font-size:16px}
.media-drop-ico{font-size:28px;margin-bottom:8px;line-height:1}
.media-drop-txt{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;color:var(--bright)}
.media-drop-sub{font-size:12px;color:var(--muted);margin-top:3px}
.media-previews{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.media-thumb{
  position:relative;width:90px;height:90px;
  border-radius:var(--r);overflow:hidden;
  border:1px solid var(--wire);flex-shrink:0;
  background:var(--steel);
}
.media-thumb img,.media-thumb video{width:100%;height:100%;object-fit:cover}
.media-thumb-del{
  position:absolute;top:3px;right:3px;
  width:20px;height:20px;border-radius:50%;
  background:rgba(0,0,0,.7);color:#fff;
  font-size:11px;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}
.media-thumb-type{
  position:absolute;bottom:3px;left:3px;
  font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:700;
  background:rgba(0,0,0,.6);color:#fff;
  padding:1px 4px;border-radius:3px;letter-spacing:.5px;
}
.media-count{font-family:'Barlow Condensed',sans-serif;font-size:10px;color:var(--muted);margin-top:6px}

/* Media gallery in cards/drawer */
.media-gallery{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.mg-item{
  width:88px;height:88px;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--wire);cursor:pointer;position:relative;
  background:var(--steel);flex-shrink:0;
}
.mg-item img,.mg-item video{width:100%;height:100%;object-fit:cover}
.mg-item:active{opacity:.8}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.95);
  z-index:500;display:none;align-items:center;justify-content:center;
  flex-direction:column;padding:20px;
}
.lightbox.open{display:flex}
.lightbox img,.lightbox video{max-width:100%;max-height:80vh;border-radius:var(--r);object-fit:contain}
.lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lightbox-cap{margin-top:12px;font-size:13px;color:var(--soft);text-align:center}

/* =========================================================
   PDF BITACORA GEG - CSS CORREGIDO / FULL BLEED A4
   ========================================================= */

@page{
  size:A4;
  margin:0;
}

/* Reset fuerte SOLO para exportacion/impresion */
@media print{
  html,body{
    width:210mm!important;
    min-height:297mm!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }

  body *{
    visibility:hidden!important;
  }

  #print-zone,
  #print-zone *,
  .btpdf,
  .btpdf *{
    visibility:visible!important;
  }

  #print-zone{
    display:block!important;
    position:absolute!important;
    inset:0 auto auto 0!important;
    width:210mm!important;
    min-height:297mm!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
    overflow:visible!important;
    color:#111!important;
    z-index:999999!important;
  }

  .topbar,.bottom-nav,.sidebar,.sidebar-veil,.fab,.toast,.veil,.dveil,.drawer,.lightbox{
    display:none!important;
  }
}

/* =========================================================
   BASE PDF
   ========================================================= */
.btpdf,
.btpdf *{
  box-sizing:border-box;
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}

.btpdf{
  width:210mm;
  max-width:none;
  margin:0;
  padding:0;
  color:#111827;
  background:#fff;
  font-family:Inter,Arial,Helvetica,sans-serif;
  text-rendering:geometricPrecision;
  -webkit-font-smoothing:antialiased;
}

.btpdf-page{
  position:relative;
  width:210mm;
  min-height:297mm;
  margin:0;
  padding:0;
  background:#fff;
  break-after:page;
  page-break-after:always;
}

.btpdf-page:last-child{
  break-after:auto;
  page-break-after:auto;
}

/* =========================================================
   PORTADA PREMIUM - SIN MARGENES BLANCOS
   ========================================================= */
.btpdf-cover{
  position:relative;
  display:flex;
  flex-direction:column;
  width:210mm;
  height:297mm;
  min-height:297mm;
  margin:0;
  padding:0;
  overflow:hidden;
  color:#f8fafc;
  background:
    radial-gradient(circle at 18% 10%,rgba(255,213,0,.14),transparent 24%),
    radial-gradient(circle at 82% 26%,rgba(214,173,66,.10),transparent 28%),
    linear-gradient(135deg,#010203 0%,#050608 42%,#090b0e 100%);
}

.btpdf-cover::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:9mm;
  background:linear-gradient(90deg,#8f6a12 0%,#ffd500 42%,#fff3a6 52%,#d6ad42 100%);
}

.btpdf-cover::after{
  content:'';
  position:absolute;
  right:-34mm;
  bottom:-46mm;
  width:150mm;
  height:150mm;
  border-radius:50%;
  border:1px solid rgba(255,213,0,.16);
  background:radial-gradient(circle,rgba(255,213,0,.08),transparent 62%);
}

.btpdf-cover-top{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:4pt;
  width:100%;
  padding:20mm 18mm 0;
  text-align:center;
}

.btpdf-cover-kicker{
  font-family:'Barlow Condensed',Inter,Arial,sans-serif;
  font-size:8.5pt;
  font-weight:800;
  letter-spacing:2.4px;
  text-transform:uppercase;
  color:#f4d77f;
}

.btpdf-cover-side{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6pt;
}

.btpdf-cover-logo{
  width:60mm;
  height:auto;
  display:block;
  object-fit:contain;
  margin:0 0 12pt;
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.38));
}

.btpdf-cover-brand{
  font-family:'Barlow Condensed',Inter,Arial,sans-serif;
  font-size:7.4pt;
  font-weight:800;
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:#f4d77f;
  text-align:center;
}

.btpdf-cover-main{
  position:relative;
  z-index:2;
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:210mm;
  padding:8mm 18mm 26mm;
  text-align:center;
}

.btpdf-cover-main > *{
  margin-left:auto;
  margin-right:auto;
}

.btpdf-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6pt 12pt;
  border-radius:999px;
  border:1px solid rgba(255,213,0,.38);
  background:rgba(255,213,0,.08);
  color:#ffe68a;
  font-size:7pt;
  font-weight:900;
  letter-spacing:2.2px;
  text-transform:uppercase;
}

.btpdf-cover-rule{
  width:54mm;
  height:2px;
  margin:10pt 0 14pt;
  background:linear-gradient(90deg,#ffd500,rgba(255,213,0,.18),transparent);
  border-radius:999px;
}

.btpdf-cover-code{
  font-family:'Barlow Condensed',Inter,Arial,sans-serif;
  font-size:21pt;
  line-height:1;
  font-weight:900;
  letter-spacing:1.4px;
  color:#ffd500;
  text-transform:uppercase;
}

.btpdf-cover-title{
  max-width:142mm;
  margin:7pt 0 8pt;
  color:#fff;
  font-size:24pt;
  line-height:1.06;
  font-weight:900;
  letter-spacing:-.4pt;
}

.btpdf-cover-sub{
  max-width:138mm;
  color:#aab4c5;
  font-size:9.2pt;
  line-height:1.35;
}

.btpdf-status{
  display:inline-flex;
  margin-top:12pt;
  padding:6pt 12pt;
  border-radius:999px;
  background:#dcfce7;
  color:#166534;
  border:1px solid #bbf7d0;
  font-size:7pt;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
}

.btpdf-status.sp-op{
  background:rgba(46,171,111,.16)!important;
  border-color:rgba(46,171,111,.35)!important;
  color:#9ef2cc!important;
}

.btpdf-status.sp-maint{
  background:rgba(255,213,0,.16)!important;
  border-color:rgba(255,213,0,.35)!important;
  color:#ffe68a!important;
}

.btpdf-status.sp-fs{
  background:rgba(192,48,64,.22)!important;
  border-color:rgba(192,48,64,.55)!important;
  color:#ffd3d8!important;
}

.btpdf-status.sp-sb{
  background:rgba(59,130,196,.18)!important;
  border-color:rgba(59,130,196,.4)!important;
  color:#cfe6ff!important;
}

.btpdf-status.sp-pend{
  background:rgba(212,95,46,.18)!important;
  border-color:rgba(212,95,46,.42)!important;
  color:#ffd8c1!important;
}

.btpdf-cover-meta,
.btpdf-cover-grid{
  width:100%;
  display:grid;
  gap:8pt;
  margin-top:14pt;
  align-items:stretch;
}

.btpdf-cover-meta{grid-template-columns:repeat(4,1fr)}
.btpdf-cover-grid{grid-template-columns:repeat(3,1fr)}

.btpdf-cover-card{
  min-height:46pt;
  padding:8pt 10pt;
  border:1px solid rgba(255,255,255,.10);
  border-radius:11pt;
  background:rgba(255,255,255,.052);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
  text-align:left;
  display:grid;
  grid-template-rows:auto 1fr;
  align-content:stretch;
  gap:3pt;
}

.btpdf-cover-label{
  display:block;
  margin:0;
  color:#8994a8;
  font-size:6.2pt;
  font-weight:900;
  letter-spacing:1.3px;
  line-height:1.12;
  text-transform:uppercase;
}

.btpdf-cover-value{
  display:flex;
  align-items:center;
  color:#f8fafc;
  font-size:8.5pt;
  font-weight:800;
  line-height:1.2;
  word-break:break-word;
  overflow-wrap:anywhere;
  text-wrap:pretty;
}

.btpdf-cover-footer{
  position:absolute;
  z-index:2;
  left:18mm;
  right:18mm;
  bottom:12mm;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12pt;
  padding-top:8pt;
  border-top:1px solid rgba(255,213,0,.25);
  color:#aab4c5;
  font-size:7pt;
}

/* =========================================================
   HOJAS INTERIORES
   ========================================================= */
.btpdf-sheet{
  width:210mm;
  min-height:297mm;
  margin:0;
  padding:12mm 10mm 10mm;
  background:#fff;
  color:#111827;
  display:flex;
  flex-direction:column;
}

.btpdf-sheet-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12pt;
  margin-bottom:9pt;
}

.btpdf-sheet-top-copy{min-width:0}

.btpdf-sheet-top-kicker,
.btpdf-kicker{
  font-family:'Barlow Condensed',Inter,Arial,sans-serif;
  margin-bottom:4pt;
  color:#7c8798;
  font-size:7.6pt;
  font-weight:900;
  letter-spacing:2.6px;
  text-transform:uppercase;
}

.btpdf-sheet-top-title{
  color:#0f172a;
  font-size:11pt;
  font-weight:900;
  line-height:1.18;
}

.btpdf-sheet-top-meta{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6pt;
  flex-wrap:wrap;
}

.btpdf-page-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38pt;
  padding:4pt 8pt;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:6.8pt;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.btpdf-sheet-divider{
  height:2px;
  margin-bottom:12pt;
  border-radius:999px;
  background:linear-gradient(90deg,#ffd500 0%,#d6ad42 24%,#1f2937 58%,#e5e7eb 100%);
}

.btpdf-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10pt;
  margin-bottom:12pt;
  padding-bottom:8pt;
  border-bottom:1.4pt solid #1f2937;
}

.btpdf-header-copy{min-width:0}

.btpdf-title{
  margin:0 0 2pt;
  color:#0f172a;
  font-size:20pt;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.2pt;
}

.btpdf-subtitle{
  color:#64748b;
  font-size:9.2pt;
  line-height:1.35;
}

.btpdf-header-date{
  text-align:right;
  color:#64748b;
  font-size:8.5pt;
  font-weight:800;
  white-space:nowrap;
}

.btpdf-doc-band{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10pt;
  margin-bottom:12pt;
  padding:8pt 10pt;
  border:1pt solid #dbe3ef;
  border-left:3pt solid #d6ad42;
  border-radius:10pt;
  background:#f8fafc;
}

.btpdf-doc-main{
  color:#475569;
  font-size:7pt;
  font-weight:900;
  letter-spacing:1.8px;
  text-transform:uppercase;
}

.btpdf-doc-meta{
  color:#64748b;
  font-size:8pt;
  line-height:1.35;
  text-align:right;
}

/* KPIs */
.btpdf-kpis{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:7pt;
  margin-bottom:14pt;
}

.btpdf-kpi{
  position:relative;
  overflow:hidden;
  padding:10pt 7pt;
  border:1pt solid #dbe3ef;
  border-radius:12pt;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  text-align:center;
}

.btpdf-kpi::before{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:2pt;
  background:#d6ad42;
}

.btpdf-kpi-num{
  color:#111827;
  font-size:18pt;
  line-height:1;
  font-weight:900;
}

.btpdf-kpi-label{
  margin-top:5pt;
  color:#7c8798;
  font-size:6.7pt;
  font-weight:900;
  letter-spacing:1.6px;
  text-transform:uppercase;
}

/* Secciones */
.btpdf-section{
  margin-top:12pt;
  break-inside:avoid;
  page-break-inside:avoid;
}

.btpdf-section-title{
  position:relative;
  margin-bottom:9pt;
  padding-bottom:4pt;
  border-bottom:1pt solid #e5eaf2;
  color:#64748b;
  font-family:'Barlow Condensed',Inter,Arial,sans-serif;
  font-size:8.6pt;
  font-weight:900;
  letter-spacing:2.2px;
  text-transform:uppercase;
}

.btpdf-section-title::after{
  content:'';
  position:absolute;
  left:0;
  bottom:-1pt;
  width:28mm;
  height:2px;
  border-radius:999px;
  background:#d6ad42;
}

.btpdf-specs{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:7pt;
}

.btpdf-spec{
  padding:8pt 9pt;
  border:1pt solid #dbe3ef;
  border-top:2pt solid #d6ad42;
  border-radius:10pt;
  background:#fff;
  break-inside:avoid;
  page-break-inside:avoid;
}

.btpdf-spec--wide{grid-column:1 / -1}

.btpdf-label,
.btpdf-value{display:block}

.btpdf-label{
  margin-bottom:3pt;
  color:#7c8798;
  font-size:6.7pt;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
}

.btpdf-value{
  color:#111827;
  font-size:9.8pt;
  line-height:1.34;
  word-break:break-word;
}

/* Tablas */
.btpdf-table-shell{
  width:100%;
  overflow:hidden;
  border:1pt solid #dbe3ef;
  border-radius:11pt;
  background:#fff;
}

.btpdf-table{
  width:100%;
  table-layout:fixed;
  border-collapse:collapse;
  font-size:8.5pt;
}

.btpdf-table thead{display:table-header-group}
.btpdf-table tfoot{display:table-footer-group}

.btpdf-table th{
  padding:6pt 6pt;
  border:1pt solid #e2e8f0;
  background:#f1f5f9;
  color:#475569;
  text-align:left;
  font-size:6.5pt;
  line-height:1.15;
  font-weight:900;
  letter-spacing:.9px;
  text-transform:uppercase;
  white-space:normal;
}

.btpdf-table td{
  padding:6pt 6pt;
  border:1pt solid #e2e8f0;
  color:#1f2937;
  font-size:8.1pt;
  line-height:1.28;
  vertical-align:top;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.btpdf-table tr{
  break-inside:avoid;
  page-break-inside:avoid;
}

.btpdf-table tr:nth-child(even) td{background:#f8fafc}

.btpdf-empty-row td{
  padding:14pt 12pt!important;
  color:#7c8798!important;
  text-align:center!important;
  font-style:italic;
}

/* Anchos de tablas: ajustados para que no se revienten */
.btpdf-table--ots .btpdf-col-folio{width:11%}
.btpdf-table--ots .btpdf-col-desc{width:28%}
.btpdf-table--ots .btpdf-col-tipo{width:11%}
.btpdf-table--ots .btpdf-col-prio{width:10%}
.btpdf-table--ots .btpdf-col-asig{width:15%}
.btpdf-table--ots .btpdf-col-fecha{width:12%}
.btpdf-table--ots .btpdf-col-estado{width:13%}

.btpdf-table--fallas .btpdf-col-folio{width:10%}
.btpdf-table--fallas .btpdf-col-desc{width:24%}
.btpdf-table--fallas .btpdf-col-sistema{width:12%}
.btpdf-table--fallas .btpdf-col-sev{width:10%}
.btpdf-table--fallas .btpdf-col-reporta{width:14%}
.btpdf-table--fallas .btpdf-col-fecha{width:15%}
.btpdf-table--fallas .btpdf-col-ot{width:7%}
.btpdf-table--fallas .btpdf-col-estado{width:8%}

.btpdf-table--refs .btpdf-col-folio{width:10%}
.btpdf-table--refs .btpdf-col-ref{width:25%}
.btpdf-table--refs .btpdf-col-parte{width:13%}
.btpdf-table--refs .btpdf-col-ot{width:9%}
.btpdf-table--refs .btpdf-col-cant{width:8%}
.btpdf-table--refs .btpdf-col-costo{width:12%}
.btpdf-table--refs .btpdf-col-estado{width:12%}
.btpdf-table--refs .btpdf-col-fecha{width:11%}

.btpdf-table--horas .btpdf-col-fecha{width:16%}
.btpdf-table--horas .btpdf-col-horas{width:10%}
.btpdf-table--horas .btpdf-col-operador{width:18%}
.btpdf-table--horas .btpdf-col-estado{width:14%}
.btpdf-table--horas .btpdf-col-comentario{width:42%}

.btpdf-table td:nth-child(4),
.btpdf-table td:nth-child(7),
.btpdf-table td:nth-child(8){
  text-align:center;
  vertical-align:middle;
}

/* Badges compactos para que no rompan columnas */
.btpdf-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  max-width:100%;
  padding:4pt 6pt;
  border-radius:999px;
  font-size:6.2pt;
  line-height:1.1;
  font-weight:900;
  text-align:center;
  text-transform:uppercase;
  white-space:normal;
  overflow-wrap:anywhere;
}

.btpdf-badge.op,
.btpdf-badge.completado,
.btpdf-badge.baja{background:#dcfce7;color:#166534}
.btpdf-badge.maint,
.btpdf-badge.media{background:#fef3c7;color:#92400e}
.btpdf-badge.fuera,
.btpdf-badge.alta,
.btpdf-badge.critica,
.btpdf-badge.pendiente{background:#fee2e2;color:#991b1b}
.btpdf-badge.proceso{background:#dbeafe;color:#1e3a8a}

.btpdf-footer,
.btpdf-page-footer{
  margin-top:auto;
  padding-top:8pt;
  border-top:1pt solid #e5eaf2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12pt;
  color:#7c8798;
  font-size:7.4pt;
  letter-spacing:.2px;
}

/* =========================================================
   JS RECOMENDADO PARA EXPORTAR CON html2pdf
   Usa esto si hoy estas usando window.print() y quieres evitar margenes blancos.
   Requiere html2pdf.bundle.min.js cargado en tu proyecto.
   ========================================================= */

/*
async function exportarBitacoraPDF(nombreArchivo = 'bitacora-geg.pdf'){
  const element = document.querySelector('.btpdf') || document.getElementById('print-zone');

  if(!element){
    console.error('No encontre .btpdf ni #print-zone para generar el PDF');
    return;
  }

  if(typeof html2pdf === 'undefined'){
    console.warn('html2pdf no esta cargado. Abro impresion como respaldo.');
    window.print();
    return;
  }

  document.body.classList.add('is-exporting-btpdf');

  const opt = {
    margin:[0,0,0,0],
    filename:nombreArchivo,
    image:{ type:'jpeg', quality:0.98 },
    html2canvas:{
      scale:2,
      useCORS:true,
      allowTaint:true,
      backgroundColor:'#ffffff',
      scrollX:0,
      scrollY:0,
      windowWidth:794
    },
    jsPDF:{
      unit:'mm',
      format:'a4',
      orientation:'portrait',
      compress:true
    },
    pagebreak:{
      mode:['css','legacy'],
      before:'.btpdf-page:not(:first-child)',
      avoid:['.btpdf-kpi','.btpdf-spec','.btpdf-section','tr']
    }
  };

  try{
    await html2pdf().set(opt).from(element).save();
  }finally{
    document.body.classList.remove('is-exporting-btpdf');
  }
}
*/

/* ── BOTTOM SHEET (modal) ── */
.veil{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:100;display:none;align-items:flex-end;justify-content:center}
.veil.open{display:flex;animation:veilIn .2s ease}
@keyframes veilIn{from{opacity:0}to{opacity:1}}
.mbox{
  background:var(--plate);
  border:1px solid var(--wire);
  border-bottom:none;
  border-radius:16px 16px 0 0;
  width:100%;
  max-height:90vh;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  animation:sheetUp .3s cubic-bezier(.22,1,.36,1);
  padding-bottom:var(--safe-bot);
}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-handle{width:36px;height:4px;background:var(--wire);border-radius:2px;margin:12px auto 0}
.mtop{padding:18px 20px 14px;border-bottom:1px solid var(--rim);display:flex;align-items:flex-start;justify-content:space-between}
.mey{display:block;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;line-height:1.15;color:var(--gold);text-transform:uppercase;margin-bottom:4px;padding-top:1px}
.mttl{font-family:'Inter',sans-serif;font-size:17px;font-weight:600;color:var(--white)}
.xbtn{width:32px;height:32px;border-radius:var(--r);background:var(--plate);border:1px solid var(--wire);color:var(--soft);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:12px}
.mbody{padding:18px 20px}
.mfoot{padding:14px 20px;border-top:1px solid var(--rim);display:flex;gap:8px}
.mfoot .btn{flex:1}

/* ── OPERADORES: ASIGNACION EQUIPOS ── */
.ops-assign-overlay{
  position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.78);
  display:flex;align-items:center;justify-content:center;padding:18px;
}
.ops-assign-modal{
  width:min(1080px,96vw);max-height:92vh;overflow:auto;
  background:#111826;border:1px solid #263042;border-radius:14px;
}
.ops-assign-head{padding:14px 16px;border-bottom:1px solid var(--wire);display:flex;align-items:flex-start;justify-content:space-between}
.ops-assign-body{padding:14px 16px;display:grid;gap:12px}
.ops-assign-form{display:grid;gap:10px}
.ops-assign-shell{border:1px solid var(--wire);border-radius:12px;background:rgba(255,255,255,.015);padding:10px;display:grid;gap:8px}
.ops-assign-tools{display:grid;gap:8px}
.ops-assign-filters{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ops-assign-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ops-assign-actions label{font-size:12px;color:var(--soft);display:flex;align-items:center;gap:6px}
.ops-assign-alert{background:rgba(192,48,64,.12);border:1px solid rgba(192,48,64,.3);border-radius:8px;padding:8px 10px;font-size:12px;color:#ffb9c1}
.ops-assign-tree{max-height:38vh;overflow:auto;display:grid;gap:10px;padding-right:4px}
.ops-group-title{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;color:var(--gold2);text-transform:uppercase;margin-bottom:6px}
.ops-subgroup{display:grid;gap:6px}
.ops-subgroup-title{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.ops-eq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.ops-eq-item{
  text-align:left;border:1px solid var(--wire);background:var(--plate);border-radius:10px;padding:8px;cursor:pointer;
  display:grid;gap:3px;color:var(--bright);transition:all .15s;
}
.ops-eq-item:hover{border-color:rgba(255,213,0,.3)}
.ops-eq-item.active{border-color:rgba(255,213,0,.45);background:rgba(255,213,0,.08)}
.ops-eq-item.assigned{border-color:rgba(192,48,64,.25)}
.ops-eq-top{display:flex;align-items:center;justify-content:space-between;gap:6px}
.ops-eq-code{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--gold2);letter-spacing:1px}
.ops-eq-tag{font-size:10px;background:rgba(192,48,64,.2);color:#ffd6db;border:1px solid rgba(192,48,64,.35);padding:1px 6px;border-radius:999px}
.ops-eq-name{font-size:13px;font-weight:600;color:var(--white);line-height:1.2}
.ops-eq-meta{font-size:11px;color:var(--muted)}
.ops-eq-assigned-to{font-size:10px;color:#f7b7bf}
.ops-assign-empty{border:1px dashed var(--wire);border-radius:8px;padding:14px;text-align:center;color:var(--muted);font-size:12px}
.ops-assign-preview{border:1px solid var(--wire);border-radius:12px;background:rgba(255,255,255,.015);padding:10px;display:grid;gap:8px}
.ops-assign-preview-title{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;color:var(--gold2);text-transform:uppercase}
.ops-assign-summary{font-size:12px;color:var(--soft)}
.ops-assign-chips{display:flex;flex-wrap:wrap;gap:6px}
.ops-chip{font-size:11px;color:var(--bright);background:var(--steel);border:1px solid var(--wire);padding:4px 8px;border-radius:999px}
.ops-empty-chip{font-size:11px;color:var(--muted)}
.ops-assign-foot{padding:12px 16px;border-top:1px solid var(--wire);display:flex;gap:8px}
.ops-assign-foot .btn{flex:1}
.ops-field-error{border-color:rgba(192,48,64,.9)!important;box-shadow:0 0 0 3px rgba(192,48,64,.16)!important}

@media(max-width:767px){
  .ops-assign-overlay{padding:10px}
  .ops-assign-modal{width:100%;max-height:96vh}
  .ops-eq-grid{grid-template-columns:1fr}
  .ops-assign-filters{grid-template-columns:1fr}
  .ops-assign-tree{max-height:34vh}
}

/* Header de detalle de falla */
.falla-sheet{
  width:min(920px,94vw);
  max-width:min(920px,94vw);
  border-radius:16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  animation:fallaSheetIn .16s cubic-bezier(.2,.9,.25,1);
}
@keyframes fallaSheetIn{
  from{opacity:0;transform:translateY(10px) scale(.992)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.falla-body{
  flex:1;
  min-height:0;
  padding:14px 18px 8px;
  overflow-y:auto;
  overscroll-behavior:contain;
}
.falla-sheet .sheet-handle,
.falla-sheet .falla-top,
.falla-sheet .mfoot{
  flex-shrink:0;
}
.falla-top{
  padding:14px 18px 12px!important;
  border-bottom:1px solid rgba(255,255,255,.08)!important;
  align-items:center;
}
.falla-top-main{flex:1;min-width:0}
.falla-top-nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:6px;
}
.falla-back-btn{
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
}
.falla-top-breadcrumb{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:.14em;
  color:rgba(154,170,184,.88);
  text-transform:uppercase;
}
.falla-top-breadcrumb strong{
  color:var(--gold2);
  font-weight:600;
}
.falla-sheet .mfoot{
  position:relative;
  z-index:1;
  background:linear-gradient(180deg,rgba(17,24,35,.96),rgba(12,18,28,.98));
}
.falla-top-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.falla-top #fld-folio{
  margin-bottom:0;
  font-size:12px!important;
  letter-spacing:.06em!important;
  color:var(--muted);
  padding-top:0;
}
.falla-top-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:24px!important;
  font-weight:600;
  line-height:1;
  letter-spacing:.02em;
}
.falla-top #fld-sistema{
  margin-top:5px!important;
  font-size:12px!important;
  color:var(--muted)!important;
  line-height:1.25;
}
.falla-hero{
  margin-bottom:12px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(18,25,37,.9),rgba(15,21,31,.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.falla-hero #fld-desc{
  font-size:14px!important;
  line-height:1.5!important;
}
.falla-section-kicker{
  margin-bottom:6px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--soft);
}
.falla-section-kicker-danger{color:#ff8e99}
.falla-section-kicker-ice{color:var(--ice)}
.falla-section-kicker-muted{color:var(--muted)}
.falla-info-grid{
  gap:10px!important;
}
.falla-info-card{
  min-width:0;
  padding:9px 10px;
  border:1px solid rgba(255,255,255,.05);
  border-radius:12px;
  background:rgba(255,255,255,.018);
}
.falla-mini-label{
  margin-bottom:4px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.falla-panel{
  margin-bottom:12px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.05);
  border-radius:14px;
  background:rgba(255,255,255,.018);
}
.falla-panel-ice{
  border-color:rgba(72,176,232,.16);
  background:rgba(72,176,232,.035);
}
.falla-panel-content{
  padding:10px 11px;
  border:1px solid rgba(255,255,255,.05);
  border-radius:12px;
  background:rgba(13,19,28,.46);
}
.falla-panel-content-clickable{
  transition:border-color .16s ease, background .16s ease, transform .16s ease;
}
.falla-panel-content-clickable:hover{
  border-color:rgba(72,176,232,.26);
  background:rgba(72,176,232,.06);
  transform:translateY(-1px);
}
.falla-panel-head{
  margin-bottom:4px;
}
.falla-media-uploader{
  margin-top:6px!important;
}
.falla-media-uploader .media-drop{
  min-height:92px;
  padding:12px 10px;
  border-radius:12px;
  border-color:rgba(255,255,255,.06);
  background:rgba(255,255,255,.01);
}
.falla-media-uploader .media-drop-ico{
  font-size:22px;
  margin-bottom:5px;
  opacity:.7;
}
.falla-media-uploader .media-drop-txt{
  font-size:12px;
  letter-spacing:.04em;
}
.falla-media-uploader .media-drop-sub{
  font-size:11px;
  margin-top:2px;
}
.falla-media-uploader .media-previews{
  gap:6px;
  margin-top:8px;
}
.falla-top-close{
  width:38px;
  height:38px;
  border-radius:12px;
  margin-left:14px;
  background:rgba(15,22,33,.7);
  border-color:rgba(103,149,198,.22);
}
#fallaDetailVeil.from-ot{
  background:rgba(3,8,18,.56);
  backdrop-filter:blur(5px);
}

@media(max-width:767px){
  #fallaDetailVeil{
    align-items:flex-start;
    padding-top:max(12px, var(--safe-top));
    padding-bottom:max(8px, var(--safe-bot));
  }
  .falla-sheet{
    width:100%;
    max-width:100%;
    border-radius:16px 16px 0 0;
  }
  .falla-top{padding:12px 16px 10px!important}
  .falla-body{padding:12px 16px 6px}
  .falla-hero,
  .falla-panel{padding:12px}
  .falla-info-card{padding:9px 10px}
  .falla-panel-content{padding:10px}
  .falla-top-main{padding-right:4px}
  .falla-top-nav{gap:8px;margin-bottom:5px}
  .falla-back-btn{min-height:26px;padding:0 10px;font-size:10.5px}
  .falla-top-pills{gap:6px}
  .falla-top-breadcrumb{font-size:10px;letter-spacing:.12em}
  .falla-top-pills .spill{font-size:12px;letter-spacing:.6px;padding:3px 7px}
  .falla-top-pills .mey{font-size:10px!important;letter-spacing:.1em!important}
  .falla-top-title{font-size:17px!important;line-height:1.1}
  .falla-top #fld-sistema{font-size:11px!important;line-height:1.3}
  .falla-top-close{width:30px;height:30px;font-size:13px;margin-left:8px}
  .falla-info-grid{grid-template-columns:1fr!important}
  .falla-section-kicker{font-size:12px}
  .falla-media-uploader .media-drop{min-height:84px}
  #fallaDetailVeil .falla-sheet{
    max-height:calc(100dvh - max(12px, var(--safe-top)) - max(8px, var(--safe-bot)) - 8px)!important;
    margin-top:0!important;
  }
}

/* ── FORM ── */
.fgrid{display:flex;flex-direction:column;gap:12px}
.fg{display:flex;flex-direction:column;gap:6px}
.fl{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:2px;color:var(--soft);text-transform:uppercase}
.fi,.fsel{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:11px 13px;color:var(--bright);font-family:'Inter',sans-serif;font-size:16px;outline:none;transition:all .2s;-webkit-appearance:none;appearance:none;width:100%;min-height:44px}
.fi:focus,.fsel:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,213,0,.08)}
.fsel option{background:var(--plate);color:var(--bright)}
.fgrid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fdiv{height:1px;background:linear-gradient(90deg,var(--rim),transparent)}
.maint-plan-mbox{
  width:min(1120px,96vw);
  max-height:90vh;
  border-radius:18px;
  border-bottom:1px solid var(--wire);
}
.maint-plan-body{display:grid;gap:14px}
.maint-plan-grid{display:grid;gap:14px}
.maint-plan-card{
  background:linear-gradient(180deg,rgba(30,40,56,.92),rgba(24,32,46,.96));
  border:1px solid rgba(59,72,90,.9);
  border-radius:14px;
  padding:14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.maint-plan-card.full{grid-column:1 / -1}
.maint-plan-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.maint-plan-card-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:700;color:var(--white)}
.maint-plan-card-sub{font-size:12px;color:var(--muted);margin-top:2px}
.maint-plan-tools{display:grid;gap:8px}
.maint-picker-box{
  border:1px solid var(--wire);
  background:rgba(9,12,18,.32);
  border-radius:12px;
  padding:10px;
}
.maint-picker-hint{font-size:11px;color:var(--muted);line-height:1.45}
.maint-picker-results,.maint-picker-selected{display:grid;gap:8px}
.maint-picker-results{max-height:220px;overflow:auto;padding-right:2px}
.maint-picker-selected{max-height:260px;overflow:auto;padding-right:2px}
.maint-picker-group-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
  margin-top:2px;
}
.maint-picker-group-label.catalogo{color:var(--gold2)}
.maint-picker-group-label.zoho{color:#86c4ff}
.maint-picker-empty{
  border:1px dashed rgba(154,170,184,.26);
  border-radius:12px;
  padding:12px;
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.015);
}
.maint-picker-item{
  width:100%;
  border:1px solid var(--wire);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  padding:10px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  color:inherit;
  cursor:pointer;
}
.maint-picker-item:hover{border-color:rgba(255,213,0,.26);background:rgba(255,255,255,.04)}
.maint-picker-item-main{min-width:0;flex:1}
.maint-picker-item-title{font-size:13px;font-weight:700;color:var(--bright);line-height:1.3;word-break:break-word}
.maint-picker-item-meta{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.35;word-break:break-word}
.maint-picker-item-action{
  color:var(--ice);
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  white-space:nowrap;
}
.maint-picker-item.catalogo .maint-picker-item-action{color:var(--gold2)}
.maint-ref-table-wrap{
  border:1px solid var(--wire);
  border-radius:12px;
  overflow:auto;
  background:rgba(255,255,255,.015);
}
.maint-ref-table{
  width:100%;
  border-collapse:collapse;
  min-width:620px;
}
.maint-ref-table th,
.maint-ref-table td{
  padding:10px 12px;
  border-bottom:1px solid rgba(59,72,90,.75);
  text-align:left;
  vertical-align:top;
}
.maint-ref-table th{
  position:sticky;
  top:0;
  z-index:1;
  background:rgba(17,24,36,.96);
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-ref-table tr:last-child td{border-bottom:none}
.maint-ref-name{
  font-size:13px;
  font-weight:700;
  color:var(--bright);
  line-height:1.35;
}
.maint-ref-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:4px;
  line-height:1.35;
}
.maint-ref-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:76px;
  padding:4px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  border:1px solid var(--wire);
  background:rgba(255,255,255,.03);
  color:var(--soft);
}
.maint-ref-tag.catalogo{
  border-color:rgba(255,213,0,.3);
  background:rgba(255,213,0,.08);
  color:var(--gold2);
}
.maint-ref-tag.zoho{
  border-color:rgba(59,130,196,.3);
  background:rgba(59,130,196,.08);
  color:#86c4ff;
}
.maint-ref-table .fi{
  min-height:38px;
  padding:8px 10px;
  font-size:14px;
}
.maint-ref-table .btn{
  min-height:36px;
  white-space:nowrap;
}
.maint-ref-table .qty-cell{width:110px}
.maint-ref-table .action-cell{width:112px}
.maint-selected-card{
  border:1px solid rgba(59,72,90,.9);
  border-radius:12px;
  background:rgba(7,10,16,.28);
  padding:12px;
  display:grid;
  gap:10px;
}
.maint-selected-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.maint-selected-title{font-size:14px;font-weight:700;color:var(--white);line-height:1.35}
.maint-selected-meta{font-size:11px;color:var(--soft);margin-top:4px;line-height:1.4;word-break:break-word}
.maint-selected-fields{display:grid;grid-template-columns:minmax(0,120px) minmax(0,1fr);gap:10px}
.maint-plan-stack{display:grid;gap:14px}
.maint-plan-textarea{min-height:180px !important}
.maint-plan-textarea.sm{min-height:110px !important}
.maint-plan-foot{
  position:sticky;
  bottom:0;
  background:rgba(24,32,46,.96);
  backdrop-filter:blur(10px);
}
.maint-plan-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.maint-summary-pill{
  border:1px solid var(--wire);
  background:rgba(255,255,255,.02);
  border-radius:12px;
  padding:10px 12px;
}
.maint-summary-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.maint-summary-value{font-size:14px;font-weight:700;color:var(--bright)}
.maint-plan-intro{
  padding:0 2px;
}
.maint-plan-intro-title{
  font-size:16px;
  font-weight:700;
  color:var(--white);
}
.maint-plan-intro-sub{
  font-size:13px;
  color:var(--muted);
  margin-top:4px;
  max-width:760px;
}
.maint-plan-definition-grid,
.maint-plan-metrics-grid,
.maint-plan-main-grid,
.maint-plan-side-stack,
.maint-dual-list{
  display:grid;
  gap:12px;
}
.maint-plan-definition-grid{
  margin-top:2px;
}
.maint-plan-metrics-grid{
  margin-top:12px;
}
.maint-span-2{
  grid-column:span 2;
}
.maint-section-tools{
  display:grid;
  gap:10px;
}
.maint-plan-hint{
  font-size:12px;
  color:var(--muted);
  line-height:1.45;
}
.maint-list-panel{
  border:1px solid var(--wire);
  border-radius:14px;
  background:rgba(9,12,18,.32);
  overflow:hidden;
}
.maint-list-panel-head{
  padding:12px 14px;
  border-bottom:1px solid rgba(59,72,90,.8);
  background:rgba(255,255,255,.02);
}
.maint-list-panel-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
}
.maint-list-panel-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
}
.maint-list-body{
  display:grid;
  gap:10px;
  padding:12px;
  max-height:310px;
  overflow:auto;
}
.maint-list-group{
  display:grid;
  gap:8px;
}
.maint-list-group-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-list-group-label.catalogo{color:var(--gold2)}
.maint-list-group-label.zoho{color:#86c4ff}
.maint-work-item{
  border:1px solid rgba(59,72,90,.9);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  padding:12px;
  display:grid;
  gap:10px;
}
.maint-work-item.selected{
  background:rgba(7,10,16,.28);
}
.maint-work-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.maint-work-main{
  min-width:0;
  flex:1;
}
.maint-work-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.35;
}
.maint-work-meta{
  font-size:11px;
  color:var(--soft);
  line-height:1.45;
  margin-top:4px;
  word-break:break-word;
}
.maint-work-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-source-pill{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  border:1px solid var(--wire);
  background:rgba(255,255,255,.03);
  color:var(--soft);
}
.maint-source-pill.catalogo{
  border-color:rgba(255,213,0,.3);
  background:rgba(255,213,0,.08);
  color:var(--gold2);
}
.maint-source-pill.zoho{
  border-color:rgba(59,130,196,.3);
  background:rgba(59,130,196,.08);
  color:#86c4ff;
}
.maint-soft-pill{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  color:var(--muted);
  background:rgba(255,255,255,.03);
  border:1px solid rgba(59,72,90,.9);
}
.maint-inline-fields{
  display:grid;
  grid-template-columns:minmax(0,120px) minmax(0,1fr);
  gap:10px;
}
.maint-inline-fields .fi{
  min-height:38px;
  padding:8px 10px;
  font-size:14px;
}
.maint-work-empty{
  border:1px dashed rgba(154,170,184,.26);
  border-radius:12px;
  padding:14px;
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.015);
}
.maint-v2{
  display:grid;
  gap:18px;
}
.maint-v2-hero{
  padding:2px 2px 0;
}
.maint-v2-hero-title{
  font-size:18px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.maint-v2-hero-sub{
  font-size:13px;
  color:var(--muted);
  margin-top:5px;
  max-width:820px;
}
.maint-v2-step{
  display:grid;
  gap:10px;
}
.maint-v2-step-head{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.maint-v2-step-num{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,213,0,.14);
  border:1px solid rgba(255,213,0,.2);
  color:var(--gold2);
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:700;
  letter-spacing:1px;
  flex-shrink:0;
}
.maint-v2-step-title{
  font-size:16px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.maint-v2-step-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.45;
}
.maint-v2-card{
  background:linear-gradient(180deg,rgba(27,37,53,.96),rgba(19,26,39,.98));
  border:1px solid rgba(59,72,90,.9);
  border-radius:16px;
  padding:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
  display:grid;
  gap:14px;
}
.maint-v2-card-title{
  font-size:15px;
  font-weight:700;
  color:var(--white);
}
.maint-v2-card-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.45;
}
.maint-v2-form-grid,
.maint-v2-rule-grid,
.maint-v2-rule-strip,
.maint-v2-content-grid,
.maint-v2-side-grid,
.maint-v2-pickers{
  display:grid;
  gap:12px;
}
.maint-v2-span-2{
  grid-column:span 2;
}
.maint-v2-rule-card{
  border:1px solid rgba(59,72,90,.8);
  border-radius:14px;
  background:rgba(255,255,255,.02);
  padding:12px;
  display:grid;
  gap:10px;
}
.maint-v2-rule-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-v2-textarea.lg{min-height:220px !important}
.maint-v2-textarea.sm{min-height:130px !important}
.maint-v2-toolbar{
  display:grid;
  gap:10px;
}
.maint-v2-toolbar-main{
  display:grid;
  gap:8px;
}
.maint-v2-hint{
  font-size:12px;
  color:var(--muted);
  line-height:1.45;
}
.maint-v2-panel{
  border:1px solid rgba(59,72,90,.9);
  border-radius:16px;
  overflow:hidden;
  background:rgba(8,12,18,.34);
  min-height:260px;
  display:grid;
  grid-template-rows:auto 1fr;
}
.maint-v2-panel-head{
  padding:12px 14px;
  border-bottom:1px solid rgba(59,72,90,.8);
  background:rgba(255,255,255,.02);
}
.maint-v2-panel-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
}
.maint-v2-panel-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
}
.maint-v2-panel-body{
  padding:12px;
  display:grid;
  gap:10px;
  overflow:auto;
}
.maint-v2-group{
  display:grid;
  gap:8px;
}
.maint-v2-group-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-v2-group-label.catalogo{color:var(--gold2)}
.maint-v2-group-label.zoho{color:#86c4ff}
.maint-v2-item{
  border:1px solid rgba(59,72,90,.9);
  border-radius:14px;
  background:rgba(255,255,255,.02);
  padding:12px;
  display:grid;
  gap:10px;
}
.maint-v2-item.selected{
  background:rgba(7,10,16,.28);
}
.maint-v2-item-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.maint-v2-item-main{
  min-width:0;
  flex:1;
}
.maint-v2-item-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.35;
}
.maint-v2-item-meta{
  font-size:11px;
  color:var(--soft);
  line-height:1.45;
  margin-top:4px;
  word-break:break-word;
}
.maint-v2-item-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-v2-pill{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  border:1px solid rgba(59,72,90,.9);
  background:rgba(255,255,255,.03);
  color:var(--soft);
}
.maint-v2-pill.catalogo{
  border-color:rgba(255,213,0,.3);
  background:rgba(255,213,0,.08);
  color:var(--gold2);
}
.maint-v2-pill.zoho{
  border-color:rgba(59,130,196,.3);
  background:rgba(59,130,196,.08);
  color:#86c4ff;
}
.maint-v2-pill.soft{
  font-family:'Inter',sans-serif;
  font-weight:500;
  letter-spacing:0;
  text-transform:none;
  color:var(--muted);
}
.maint-v2-item-fields{
  display:grid;
  grid-template-columns:minmax(0,120px) minmax(0,1fr);
  gap:10px;
}
.maint-v2-item-fields .fi{
  min-height:38px;
  padding:8px 10px;
  font-size:14px;
}
.maint-v2-empty{
  border:1px dashed rgba(154,170,184,.26);
  border-radius:14px;
  padding:14px;
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.015);
  line-height:1.45;
}
.maint-wizard-mbox{
  width:min(1340px,97vw);
  max-width:1340px;
}
.maint-wizard-top{
  padding-bottom:14px;
}
.maint-wizard-body{
  display:grid;
  gap:0;
  padding:0;
}
.maint-wizard-stepper{
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(0,1.2fr) minmax(0,.78fr) minmax(0,1.06fr) minmax(0,1fr);
  gap:10px;
  padding:16px 18px 14px;
  border-top:1px solid rgba(59,72,90,.75);
  border-bottom:1px solid rgba(59,72,90,.75);
  background:rgba(6,10,18,.42);
  overflow:visible;
  align-items:start;
  position:relative;
}
.maint-step-chip{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:58px;
  padding:10px 16px 10px 12px;
  border-radius:16px;
  border:1px solid transparent;
  background:transparent;
  color:var(--soft);
  text-align:left;
  transition:.18s ease;
  position:relative;
  z-index:1;
  overflow:visible;
}
.maint-step-chip:hover{
  border-color:rgba(255,213,0,.16);
  background:rgba(255,255,255,.02);
}
.maint-step-chip-num{
  width:26px;
  height:26px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:700;
  background:rgba(132,171,88,.18);
  color:#bddf88;
  flex-shrink:0;
}
.maint-step-chip-copy{
  display:grid;
  gap:2px;
  min-width:0;
  padding-right:4px;
  overflow:visible;
}
.maint-step-chip-title{
  display:block;
  font-size:13px;
  font-weight:700;
  color:#d6e4b2;
  line-height:1.15;
  padding-right:2px;
  white-space:nowrap;
  overflow-wrap:normal;
}
.maint-step-chip-sub{
  display:block;
  font-size:11px;
  color:var(--muted);
  line-height:1.2;
  padding-right:2px;
  white-space:nowrap;
  overflow-wrap:normal;
}
.maint-step-chip.is-active{
  border-color:rgba(255,198,92,.34);
  background:linear-gradient(180deg,rgba(255,198,92,.10),rgba(255,198,92,.03));
  box-shadow:inset 0 0 0 1px rgba(255,198,92,.06);
}
.maint-step-chip.is-active .maint-step-chip-num{
  background:rgba(255,198,92,.95);
  color:#1c1608;
}
.maint-step-chip.is-active .maint-step-chip-title{
  color:#ffd885;
}
.maint-step-chip.is-complete .maint-step-chip-num{
  background:rgba(132,171,88,.9);
  color:#0d1606;
}
.maint-step-chip.is-complete .maint-step-chip-title{
  color:#d6e4b2;
}
.maint-wizard-shell{
  display:grid;
  grid-template-columns:minmax(0,1.58fr) 312px;
  min-height:620px;
}
.maint-wizard-main{
  padding:20px;
  border-right:1px solid rgba(59,72,90,.75);
}
.maint-wizard-side{
  padding:16px;
  display:grid;
  gap:14px;
  align-content:start;
  background:linear-gradient(180deg,rgba(5,9,16,.66),rgba(7,11,18,.52));
}
.maint-pane{
  display:none;
  gap:12px;
}
.maint-pane.is-active{
  display:grid;
}
.maint-pane-callout{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 15px;
  border-radius:16px;
  border:1px solid rgba(255,198,92,.18);
  background:linear-gradient(180deg,rgba(255,198,92,.07),rgba(255,198,92,.025));
  max-width:760px;
}
.maint-pane-icon{
  width:32px;
  height:32px;
  border-radius:11px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  background:rgba(255,198,92,.18);
  color:#ffd885;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;
}
.maint-pane-title{
  font-size:16px;
  font-weight:700;
  color:var(--white);
  line-height:1.2;
}
.maint-pane-sub{
  font-size:12.5px;
  color:var(--muted);
  margin-top:4px;
  line-height:1.45;
}
.maint-wizard-card{
  display:grid;
  gap:12px;
  padding:14px 16px 16px;
  border-radius:16px;
  border:1px solid rgba(59,72,90,.8);
  background:linear-gradient(180deg,rgba(10,15,24,.74),rgba(8,12,20,.88));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.maint-wizard-card .fg{
  gap:7px;
}
.maint-wizard-card .fl{
  font-size:12px;
  letter-spacing:1.4px;
  color:#a7b7c9;
}
.maint-wizard-card .fi,
.maint-wizard-card .fsel{
  min-height:46px;
  padding:10px 12px;
  font-size:15px;
  border-radius:12px;
  background:rgba(11,16,26,.9);
  border-color:rgba(59,72,90,.9);
}
.maint-wizard-card .fi:focus,
.maint-wizard-card .fsel:focus{
  border-color:rgba(255,198,92,.35);
  box-shadow:0 0 0 3px rgba(255,198,92,.08);
}
.maint-wizard-card textarea.fi{
  line-height:1.45;
}
.maint-wizard-grid,
.maint-rule-grid,
.maint-trigger-grid,
.maint-task-builder{
  display:grid;
  gap:12px;
}
.maint-wizard-grid.cols-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.maint-col-span-2{
  grid-column:span 2;
}
.maint-wizard-textarea.md{min-height:88px !important}
.maint-wizard-textarea.sm{min-height:120px !important}
.maint-trigger-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  align-items:stretch;
}
.maint-trigger-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:5px;
  min-height:96px;
  padding:15px 14px;
  border-radius:16px;
  border:1px solid rgba(59,72,90,.85);
  background:rgba(255,255,255,.02);
  text-align:left;
  color:var(--soft);
  transition:.18s ease;
}
.maint-trigger-card:hover{
  border-color:rgba(255,198,92,.22);
}
.maint-trigger-card.is-active{
  border-color:rgba(255,198,92,.44);
  background:linear-gradient(180deg,rgba(255,198,92,.14),rgba(255,198,92,.05));
  box-shadow:inset 0 0 0 1px rgba(255,198,92,.08);
}
.maint-trigger-title{
  font-size:16px;
  font-weight:700;
  color:var(--white);
  line-height:1.18;
}
.maint-trigger-sub{
  font-size:11px;
  color:var(--muted);
}
.maint-rule-box{
  display:grid;
  gap:10px;
  padding:13px;
  border-radius:16px;
  border:1px solid rgba(59,72,90,.8);
  background:rgba(255,255,255,.02);
  align-content:start;
}
.maint-rule-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.35px;
  text-transform:uppercase;
  color:var(--soft);
  min-height:32px;
  display:flex;
  align-items:flex-start;
  line-height:1.2;
}
.maint-rule-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:start;
}
.maint-rule-grid .fg{
  height:100%;
  display:grid;
  grid-template-rows:34px minmax(46px,auto);
  align-content:start;
}
.maint-rule-grid .fl{
  min-height:34px;
  display:flex;
  align-items:flex-start;
  margin-bottom:6px;
}
.maint-task-builder{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
}
.maint-task-list{
  display:grid;
  gap:8px;
}
.maint-task-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(59,72,90,.8);
  background:rgba(255,255,255,.02);
}
.maint-task-row-main{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-width:0;
}
.maint-task-grip{
  color:var(--muted);
  font-size:16px;
  line-height:1;
  padding-top:2px;
}
.maint-task-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.35;
}
.maint-task-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
}
.maint-task-empty{
  border:1px dashed rgba(154,170,184,.26);
  border-radius:16px;
  padding:16px;
  font-size:12px;
  color:var(--muted);
  background:rgba(255,255,255,.015);
}
.maint-toolbar{
  display:grid;
  gap:8px;
}
.maint-toolbar-hint{
  font-size:11.5px;
  color:var(--muted);
  line-height:1.45;
  max-width:760px;
}
.maint-picker-panel{
  display:grid;
  grid-template-rows:auto 1fr;
  min-height:330px;
  border:1px solid rgba(59,72,90,.85);
  border-radius:18px;
  overflow:hidden;
  background:rgba(255,255,255,.015);
}
.maint-picker-head{
  padding:12px 14px;
  border-bottom:1px solid rgba(59,72,90,.8);
  background:rgba(255,255,255,.02);
}
.maint-picker-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
}
.maint-picker-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
}
.maint-picker-body{
  padding:10px;
  display:grid;
  gap:8px;
  overflow:auto;
}
.maint-parts-card{
  gap:14px;
}
.maint-parts-intro{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border:1px solid rgba(255,198,92,.18);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,198,92,.07),rgba(255,198,92,.02));
}
.maint-parts-intro-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,198,92,.15);
  flex-shrink:0;
}
.maint-parts-intro-title{
  font-size:15px;
  font-weight:700;
  color:var(--white);
}
.maint-parts-intro-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
}
.maint-parts-search .fi{
  min-height:48px;
}
.sref-flow-section{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid rgba(59,72,90,.72);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(10,16,26,.9),rgba(7,12,20,.96));
}
.sref-flow-section + .sref-flow-section{
  margin-top:12px;
}
.sref-flow-search{
  border-color:rgba(79,118,170,.34);
}
.sref-flow-selected{
  border-color:rgba(255,198,92,.28);
  box-shadow:inset 0 0 0 1px rgba(255,198,92,.06);
}
.sref-flow-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(59,72,90,.55);
}
.sref-flow-kicker{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:var(--soft);
}
.sref-flow-title{
  margin-top:2px;
  font-size:14px;
  font-weight:700;
  color:var(--white);
}
.sref-flow-status{
  flex-shrink:0;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid rgba(59,72,90,.85);
  background:rgba(255,255,255,.02);
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--muted);
}
.sref-flow-status.is-accent{
  border-color:rgba(255,198,92,.24);
  color:#ffd885;
}
.maint-parts-results{
  max-height:220px;
  overflow:auto;
  border:1px solid rgba(59,72,90,.82);
  border-radius:16px;
  background:rgba(9,14,22,.84);
}
.maint-parts-selected{
  display:grid;
  gap:10px;
}
.maint-parts-empty{
  padding:16px;
  font-size:12px;
  color:var(--muted);
  border:1px dashed rgba(154,170,184,.22);
  border-radius:14px;
  background:rgba(255,255,255,.015);
}
.maint-parts-group{
  display:grid;
}
.maint-parts-group + .maint-parts-group{
  border-top:1px solid rgba(59,72,90,.68);
}
.maint-parts-group-label{
  padding:10px 14px 8px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-parts-group-label.catalogo{color:#b9da83}
.maint-parts-group-label.zoho{color:#86c4ff}
.maint-part-result{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border-top:1px solid rgba(59,72,90,.45);
}
.maint-part-result:first-of-type{
  border-top:none;
}
.maint-part-result-main{
  min-width:0;
}
.maint-part-result-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.maint-part-result-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.35;
}
.maint-part-result-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-part-chip{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
}
.maint-part-chip.catalogo{
  background:rgba(132,171,88,.16);
  color:#c8e49d;
}
.maint-part-chip.zoho{
  background:rgba(56,122,196,.18);
  color:#a7d3ff;
}
.maint-part-chip.soft{
  background:rgba(255,255,255,.05);
  color:var(--soft);
}
.maint-part-selected{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) 76px 86px 40px;
  gap:10px;
  align-items:center;
  padding:12px 14px;
  border:1px solid rgba(59,72,90,.85);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(6,10,18,.92),rgba(8,12,20,.96));
}
.maint-part-selected-main{
  min-width:0;
}
.maint-part-selected-title{
  font-size:15px;
  font-weight:700;
  color:var(--white);
  line-height:1.2;
}
.maint-part-selected-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
  line-height:1.35;
}
.maint-part-selected-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-part-inline{
  display:flex;
  align-items:center;
  gap:8px;
}
.maint-part-inline .fi,
.maint-part-inline .fsel{
  min-height:40px;
  padding:8px 10px;
  border-radius:10px;
  font-size:14px;
}
.maint-part-inline .fi{
  text-align:center;
}
.maint-part-action{
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(59,72,90,.85);
  background:rgba(255,255,255,.02);
  color:var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.maint-part-action:hover{
  border-color:rgba(255,198,92,.34);
  color:#ffd885;
}
.maint-fleet-card{
  gap:14px;
}
.maint-fleet-section{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid rgba(59,72,90,.72);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(10,16,26,.92),rgba(7,12,20,.96));
}
.maint-fleet-section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(59,72,90,.55);
}
.maint-fleet-section-kicker{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.7px;
  text-transform:uppercase;
  color:#ffd885;
}
.maint-fleet-section-title{
  font-size:13px;
  font-weight:700;
  color:var(--white);
}
.maint-fleet-intro{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border:1px solid rgba(255,198,92,.18);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,198,92,.07),rgba(255,198,92,.02));
}
.maint-fleet-intro-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,198,92,.15);
  flex-shrink:0;
}
.maint-fleet-intro-title{
  font-size:15px;
  font-weight:700;
  color:var(--white);
}
.maint-fleet-intro-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
}
.maint-fleet-search .fi{
  min-height:48px;
}
.maint-fleet-results{
  max-height:240px;
  overflow:auto;
  border:1px solid rgba(59,72,90,.82);
  border-radius:16px;
  background:rgba(9,14,22,.84);
}
.maint-fleet-selected{
  display:grid;
  gap:10px;
}
.maint-fleet-empty{
  padding:16px;
  font-size:12px;
  color:var(--muted);
  border:1px dashed rgba(154,170,184,.22);
  border-radius:14px;
  background:rgba(255,255,255,.015);
}
.maint-fleet-section .maint-fleet-empty{
  background:rgba(255,255,255,.02);
}
.maint-fleet-result{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border-top:1px solid rgba(59,72,90,.45);
}
.maint-fleet-result:first-child{
  border-top:none;
}
.maint-fleet-result-main{
  min-width:0;
}
.maint-fleet-result-title{
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.maint-fleet-result-sub{
  font-size:11px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.35;
}
.maint-fleet-result-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-fleet-chip{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  background:rgba(255,255,255,.05);
  color:var(--soft);
}
.maint-fleet-selected-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border:1px solid rgba(59,72,90,.85);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(6,10,18,.92),rgba(8,12,20,.96));
}
.maint-fleet-selected-main{
  min-width:0;
}
.maint-fleet-selected-title{
  font-size:15px;
  font-weight:700;
  color:var(--white);
  line-height:1.2;
}
.maint-fleet-selected-sub{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
  line-height:1.35;
}
.maint-fleet-selected-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.tec-vendor-selected{
  margin-top:10px;
}
.tec-vendor-picked{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border:1px solid rgba(209,177,75,.34);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(33,28,18,.98),rgba(19,18,15,.98));
}
.tec-vendor-picked-main{
  min-width:0;
}
.tec-vendor-picked-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--gold);
}
.tec-vendor-picked-title{
  margin-top:4px;
  font-size:14px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.tec-vendor-picked-meta{
  margin-top:4px;
  font-size:11px;
  color:var(--soft);
}
.tec-vendor-results{
  display:grid;
  gap:0;
  margin-top:10px;
  max-height:220px;
  overflow:auto;
  border:1px solid rgba(59,72,90,.82);
  border-radius:16px;
  background:rgba(9,14,22,.88);
}
.tec-vendor-result{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  width:100%;
  padding:12px 14px;
  border:none;
  border-top:1px solid rgba(59,72,90,.45);
  background:transparent;
  color:inherit;
  text-align:left;
  cursor:pointer;
  transition:background .18s ease,border-color .18s ease;
}
.tec-vendor-result:first-child{
  border-top:none;
}
.tec-vendor-result:hover{
  background:rgba(255,255,255,.03);
}
.tec-vendor-result-main{
  min-width:0;
  display:grid;
  gap:3px;
}
.tec-vendor-result-title{
  font-size:13px;
  font-weight:700;
  color:var(--white);
  line-height:1.25;
}
.tec-vendor-result-meta{
  font-size:11px;
  color:var(--muted);
}
.tec-vendor-result-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:78px;
  padding:6px 10px;
  border:1px solid rgba(209,177,75,.28);
  border-radius:11px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.15px;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(209,177,75,.06);
}
.tec-vendor-empty{
  padding:14px;
  font-size:12px;
  color:var(--muted);
}
.maint-side-card{
  display:grid;
  gap:10px;
  padding:14px;
  border-radius:16px;
  border:1px solid rgba(59,72,90,.82);
  background:linear-gradient(180deg,rgba(19,29,46,.96),rgba(12,19,31,.96));
}
.maint-side-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.7px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-side-name{
  font-size:20px;
  font-weight:700;
  color:var(--white);
  line-height:1.15;
}
.maint-side-badge{
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:700;
  letter-spacing:.8px;
  color:#ffd885;
}
.maint-side-metrics{
  display:grid;
  gap:8px;
}
.maint-side-row{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  align-items:start;
  gap:12px;
  padding-top:8px;
  border-top:1px dashed rgba(59,72,90,.9);
  font-size:13px;
  color:var(--soft);
}
.maint-side-row strong{
  color:var(--white);
  text-align:right;
  line-height:1.35;
  font-size:13px;
}
.maint-progress-list{
  display:grid;
  gap:9px;
}
.maint-progress-row{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--muted);
}
.maint-progress-dot{
  width:17px;
  height:17px;
  border-radius:999px;
  border:1px solid rgba(154,170,184,.32);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  color:var(--muted);
  flex-shrink:0;
}
.maint-progress-row.active{
  color:#ffd885;
}
.maint-progress-row.active .maint-progress-dot{
  border-color:rgba(255,198,92,.48);
  color:#ffd885;
}
.maint-progress-row.done{
  color:#d6e4b2;
}
.maint-progress-row.done .maint-progress-dot{
  border-color:rgba(132,171,88,.5);
  background:rgba(132,171,88,.15);
  color:#d6e4b2;
}
.maint-tip-card{
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(56,122,196,.26);
  background:rgba(16,41,68,.32);
  color:#c8def6;
  font-size:12px;
  line-height:1.5;
}
.maint-wizard-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.maint-foot-step{
  font-size:13px;
  color:var(--muted);
}
.maint-foot-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.maint-foot-actions .btn[disabled]{
  opacity:.45;
  pointer-events:none;
}
.maint-v2-group{
  display:grid;
  gap:8px;
}
.maint-v2-group-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
}
.maint-v2-group-label.catalogo{color:var(--gold2)}
.maint-v2-group-label.zoho{color:#86c4ff}
.maint-v2-item{
  border:1px solid rgba(59,72,90,.9);
  border-radius:16px;
  background:rgba(255,255,255,.02);
  padding:11px 12px;
  display:grid;
  gap:8px;
}
.maint-v2-item.selected{
  background:rgba(7,10,16,.28);
}
.maint-v2-item-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.maint-v2-item-main{
  min-width:0;
  flex:1;
}
.maint-v2-item-title{
  font-size:13.5px;
  font-weight:700;
  color:var(--white);
  line-height:1.35;
}
.maint-v2-item-meta{
  font-size:10.5px;
  color:var(--soft);
  line-height:1.45;
  margin-top:4px;
  word-break:break-word;
}
.maint-v2-item-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:6px;
}
.maint-v2-pill{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  border:1px solid rgba(59,72,90,.9);
  background:rgba(255,255,255,.03);
  color:var(--soft);
}
.maint-v2-pill.catalogo{
  border-color:rgba(255,213,0,.3);
  background:rgba(255,213,0,.08);
  color:var(--gold2);
}
.maint-v2-pill.zoho{
  border-color:rgba(59,130,196,.3);
  background:rgba(59,130,196,.08);
  color:#86c4ff;
}
.maint-v2-pill.soft{
  font-family:'Inter',sans-serif;
  font-weight:500;
  letter-spacing:0;
  text-transform:none;
  color:var(--muted);
}
.maint-v2-item-fields{
  display:grid;
  grid-template-columns:minmax(0,120px) minmax(0,1fr);
  gap:8px;
}
.maint-v2-item-fields .fi{
  min-height:36px;
  padding:7px 9px;
  font-size:13px;
}
.maint-v2-empty{
  border:1px dashed rgba(154,170,184,.26);
  border-radius:14px;
  padding:13px;
  font-size:11.5px;
  color:var(--muted);
  background:rgba(255,255,255,.015);
  line-height:1.45;
}
.falla-equipo-fixed{
  background:linear-gradient(180deg, rgba(255,213,0,.08), rgba(255,213,0,.04));
  border:1px solid rgba(255,213,0,.22);
  border-radius:var(--r);
  padding:12px 14px;
}
.falla-equipo-fixed-code{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:3px;
}
.falla-equipo-fixed-name{
  font-size:14px;
  font-weight:600;
  color:var(--bright);
  line-height:1.35;
}
.falla-equipo-fixed-sub{
  margin-top:4px;
  font-size:12px;
  color:var(--muted);
}

/* ── DETAIL DRAWER ── */
.dveil{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:90;display:none}
.dveil.open{display:block}
.drawer{
  position:fixed;top:0;right:-100%;width:100%;height:100%;
  background:linear-gradient(180deg,var(--carbon) 0%,var(--deep) 100%);
  border-left:1px solid var(--rim);
  z-index:91;overflow-y:auto;
  transition:right .3s cubic-bezier(.22,1,.36,1);
  padding-bottom:calc(20px + var(--safe-bot));
}
.drawer.open{right:0}
.dhero{padding:calc(20px + var(--safe-top)) 20px 18px;border-bottom:1px solid var(--rim);background:linear-gradient(135deg,var(--plate),var(--carbon))}
.dherotop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.dey{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:4px}
.dname{font-family:'Inter',sans-serif;font-size:22px;font-weight:700;color:var(--white);line-height:1.1}
.dbrand{font-size:15px;color:var(--soft);font-weight:300;margin-top:2px}
.dsec{padding:16px 20px;border-bottom:1px solid rgba(28,35,51,.6)}
.dstitle{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;color:var(--soft);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.dstitle::after{content:'';flex:1;height:1px;background:var(--rim)}
.specgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.speci label{display:block;font-family:'Barlow Condensed',sans-serif;font-size:14px;letter-spacing:2px;color:var(--soft);text-transform:uppercase;margin-bottom:2px}
.speci value{font-size:15px;color:var(--bright)}
.nbox{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:12px 14px;font-size:14px;color:var(--soft);font-weight:300;line-height:1.6;font-style:italic}
.hentry{display:flex;gap:11px;padding:9px 0;border-bottom:1px solid rgba(28,35,51,.5)}
.hentry:last-child{border-bottom:none}
.hline{display:flex;flex-direction:column;align-items:center;flex-shrink:0;padding-top:2px}
.hcircle{width:8px;height:8px;border-radius:50%;border:1px solid;flex-shrink:0}
.htail{width:1px;flex:1;background:var(--rim);margin-top:3px;min-height:8px}
.hevent{font-size:14px;color:var(--bright);margin-bottom:2px}
.hmeta{font-family:'Barlow Condensed',sans-serif;font-size:14px;color:var(--soft)}

/* ── EMPTY ── */
.empty{text-align:center;padding:50px 20px}
.empty-ico{font-size:40px;opacity:.15;margin-bottom:12px}
.empty-title{font-family:'Inter',sans-serif;font-size:18px;color:var(--soft);margin-bottom:6px}
.empty-sub{font-size:14px;color:var(--soft)}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:calc(var(--nav-h) + var(--safe-bot) + 12px);
  left:14px;right:14px;
  background:var(--plate);border:1px solid var(--wire);border-left:3px solid var(--jade);
  border-radius:var(--r);padding:12px 16px;font-size:15px;color:var(--bright);
  z-index:300;display:none;box-shadow:0 16px 48px rgba(0,0,0,.5);
}
.toast.show{display:flex;align-items:center;gap:10px;animation:tin .25s ease}
.toast.warn{border-left-color:var(--gold)}.toast.err{border-left-color:var(--crimson)}
@keyframes tin{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── OT CARD ── */
.ot-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px;cursor:pointer;transition:border-color .15s}
.ot-card:active{border-color:rgba(255,213,0,.3)}
.ot-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.ot-folio{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:1.5px;color:var(--gold)}
.ot-eq{font-size:15px;color:var(--soft);margin-top:1px}
.ot-desc{font-size:15px;color:var(--bright);line-height:1.4;margin-bottom:8px}
.ot-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ot-date{font-family:'Barlow Condensed',sans-serif;font-size:14px;color:var(--soft);margin-left:auto}
.ot-table-shell{border-radius:18px}
.ot-table-scroll{
  overflow:auto;
  max-height:min(70vh, 780px);
}
.ot-table{
  min-width:980px;
  border-collapse:separate;
  border-spacing:0;
}
.ot-table thead th{
  padding:0;
  font-size:13px;
  letter-spacing:2px;
  position:sticky;
  top:0;
  z-index:2;
  background:rgba(12,17,26,.96);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(74,87,108,.5);
}
.ot-table tbody tr{
  background:rgba(10,14,22,.45);
}
.ot-table tbody tr:hover{
  background:rgba(255,255,255,.025);
}
.ot-table td{
  padding:12px 14px;
  font-size:13px;
  border-top:1px solid rgba(74,87,108,.18);
}
.ot-sort-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border:0;
  background:transparent;
  color:var(--soft);
  font:inherit;
  font-size:13px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
}
.ot-sort-btn:hover{
  color:var(--gold2);
  background:rgba(255,255,255,.025);
}
.ot-sort-btn.is-active{color:var(--bright)}
.ot-sort-indicator{
  min-width:14px;
  text-align:center;
  font-size:12px;
  color:inherit;
}
.ot-table-folio{
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:700;
  letter-spacing:1.3px;
  color:var(--gold);
  white-space:nowrap;
}
.ot-table-meta{
  margin-top:3px;
  font-size:10px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:1.1px;
}
.ot-table-eq,
.ot-table-tech{
  color:var(--bright);
  line-height:1.35;
}
.ot-table-desc{
  color:var(--soft);
  line-height:1.4;
  min-width:260px;
}
.ot-cell-status{width:150px}
.ot-table-status{
  font-size:11px;
  white-space:nowrap;
}
.ot-table-empty{
  padding:18px 20px;
  font-size:13px;
  color:var(--muted);
}
.ot-search-wrap{margin-top:2px}
.ot-search-wrap .search-field span{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
  flex-shrink:0;
}
.ot-pagination-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:12px;
  flex-wrap:wrap;
}
.ot-pagination-info{
  font-size:12px;
  color:var(--muted);
}
.ot-pagination-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.ot-page-btn{
  min-height:34px;
  min-width:34px;
  padding:7px 11px;
  border-radius:10px;
  border:1px solid var(--wire);
  background:rgba(255,255,255,.02);
  color:var(--soft);
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  cursor:pointer;
}
.ot-page-btn:hover{border-color:rgba(255,213,0,.28);color:var(--gold2)}
.ot-page-btn.is-active{
  background:rgba(255,213,0,.1);
  border-color:rgba(255,213,0,.35);
  color:var(--gold2);
}
.ot-page-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}
.ot-page-gap{
  color:var(--muted);
  font-size:14px;
  padding:0 2px;
}
@media (max-width:900px){
  .ot-table-scroll{max-height:none}
}

/* ── USERS TABLE ── */
#usuariosList.users-list-table{
  display:block;
}
.users-panel{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.users-toolbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding:16px 18px;
  border:1px solid rgba(255,213,0,.16);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,213,0,.05), rgba(255,255,255,.02));
}
.users-toolbar-main{
  min-width:min(100%, 360px);
}
.users-toolbar-kicker{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
  color:var(--gold2);
}
.users-toolbar-title{
  margin-top:4px;
  font-size:22px;
  font-weight:800;
  color:var(--bright);
}
.users-toolbar-sub{
  margin-top:4px;
  max-width:720px;
  font-size:12px;
  color:var(--muted);
  line-height:1.45;
}
.users-toolbar-side{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.users-stat-pill{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:92px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(74,87,108,.42);
  background:rgba(12,17,26,.72);
}
.users-stat-pill strong{
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px;
  font-weight:700;
  line-height:1;
  color:var(--bright);
}
.users-stat-pill span{
  font-size:10px;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--muted);
}
.users-search-wrap{
  max-width:520px;
}
.users-search-wrap .search-field span{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:var(--soft);
  flex-shrink:0;
}
.users-table-shell{
  overflow:hidden;
}
.users-table-scroll{
  overflow:auto;
}
.users-table{
  min-width:1040px;
}
.users-table td{
  vertical-align:top;
}
.users-user{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-width:260px;
}
.users-avatar{
  width:38px;
  height:38px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--ember));
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:700;
  color:#111;
}
.users-user-main{
  min-width:0;
}
.users-user-name{
  font-size:13px;
  font-weight:700;
  color:var(--bright);
  line-height:1.35;
}
.users-user-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:5px;
}
.users-mini-tag{
  display:inline-flex;
  align-items:center;
  padding:3px 7px;
  border-radius:999px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.8px;
  text-transform:uppercase;
  background:rgba(74,87,108,.18);
  color:var(--soft);
}
.users-mini-tag.is-self{
  background:rgba(255,213,0,.12);
  color:var(--gold2);
}
.users-mini-tag.is-pending{
  background:rgba(232,131,49,.12);
  color:#f2b36a;
}
.users-user-meta{
  margin-top:6px;
  font-size:11px;
  color:var(--ice);
}
.users-role-pill{
  font-size:11px;
}
.users-contact-primary,
.users-date-primary{
  color:var(--bright);
  line-height:1.4;
}
.users-contact-secondary,
.users-date-secondary{
  margin-top:3px;
  font-size:11px;
  color:var(--muted);
}
.users-state-badge{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid rgba(74,87,108,.38);
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.1px;
  text-transform:uppercase;
  white-space:nowrap;
}
.users-state-badge.is-active{
  color:#8be0b3;
  background:rgba(79,212,154,.08);
  border-color:rgba(79,212,154,.2);
}
.users-state-badge.is-pending{
  color:var(--gold2);
  background:rgba(255,213,0,.08);
  border-color:rgba(255,213,0,.22);
}
.users-cell-actions{
  min-width:260px;
}
.users-row-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.users-row-actions .btn{
  min-height:30px;
  padding:6px 10px;
  font-size:11px;
}
.users-btn-warn{
  background:rgba(255,213,0,.1);
  border-color:rgba(255,213,0,.28);
  color:var(--gold);
}
.users-btn-info{
  background:rgba(72,176,232,.12);
  border-color:rgba(72,176,232,.3);
  color:var(--ice);
}
.users-btn-danger{
  background:rgba(192,48,64,.12);
  border-color:rgba(192,48,64,.3);
  color:var(--crimson);
}
.users-inline-note{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  font-size:11px;
  color:var(--muted);
}
.users-empty-row td{
  padding:22px 18px;
  font-size:13px;
  color:var(--muted);
  text-align:center;
}
.users-empty-state{
  padding:30px 18px;
  text-align:center;
}
.users-empty-icon{
  width:54px;
  height:54px;
  margin:0 auto 10px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,213,0,.08);
  color:var(--gold2);
  font-family:'Barlow Condensed',sans-serif;
  font-size:24px;
  font-weight:700;
}
.users-empty-title{
  font-size:15px;
  font-weight:700;
  color:var(--bright);
}
.users-empty-copy{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
}
@media (max-width:900px){
  .users-toolbar{
    padding:14px;
    border-radius:14px;
  }
  .users-toolbar-title{
    font-size:19px;
  }
  .users-search-wrap{
    max-width:none;
  }
  .users-table{
    min-width:920px;
  }
}

/* ── FALLA CARD ── */
.falla-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px;position:relative;overflow:hidden}
.falla-card.critica{border-left:3px solid var(--crimson)}
.falla-card.alta{border-left:3px solid var(--ember)}
.falla-card.media{border-left:3px solid var(--gold)}
.falla-card.baja{border-left:3px solid var(--jade)}
.falla-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.falla-id{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:1.5px;color:var(--soft)}
.falla-eq{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--gold)}
.falla-desc{font-size:15px;color:var(--bright);line-height:1.4;margin-bottom:8px}
.falla-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.falla-by{font-size:15px;color:var(--soft)}
.falla-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(28,35,51,.7)}

/* ── MAINT CARD ── */
.maint-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px}
.maint-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.maint-eq{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:1.5px;color:var(--gold)}
.maint-desc{font-size:15px;color:var(--bright);line-height:1.4;margin-bottom:8px}
.maint-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ── REF CARD ── */
.ref-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:13px 15px;margin-bottom:8px}
.ref-card.critico{border-left:3px solid var(--crimson)}
.ref-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.ref-nombre{font-size:15px;font-weight:500;color:var(--bright)}
.ref-parte{font-family:'Barlow Condensed',sans-serif;font-size:14px;letter-spacing:1px;color:var(--gold)}
.ref-stock-big{font-family:'Inter',sans-serif;font-size:28px;font-weight:600;line-height:1}
.ref-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid rgba(28,35,51,.7)}

/* ── DASH CARD ── */
.dash-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r2);padding:16px;margin-bottom:12px}
.dash-card-title{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:2.5px;color:var(--soft);text-transform:uppercase;margin-bottom:14px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar-label{font-size:15px;color:var(--soft);width:110px;flex-shrink:0;font-weight:300;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:5px;background:var(--rim);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;transition:width .6s ease}
.bar-val{font-family:'Barlow Condensed',sans-serif;font-size:15px;color:var(--bright);font-weight:600;width:32px;text-align:right;flex-shrink:0}
.pie-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.pie-item{display:flex;align-items:center;gap:6px}
.pie-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.pie-label{font-size:15px;color:var(--soft);font-weight:300}
.pie-pct{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;color:var(--bright);margin-left:2px}
.alert-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(28,35,51,.6)}
.alert-item:last-child{border-bottom:none}
.alert-ico{font-size:14px;flex-shrink:0;margin-top:1px}
.alert-title{font-size:14px;color:var(--bright);margin-bottom:2px}
.alert-meta{font-family:'Barlow Condensed',sans-serif;font-size:15px;color:var(--soft);letter-spacing:.5px}


/* ── Drawer section highlight on scroll-to ── */
.dsec.highlight{animation:secFlash .8s ease}
@keyframes secFlash{
  0%{background:rgba(255,213,0,.12)}
  100%{background:transparent}
}
/* ── DRAWER ITEM (OTs, fallas, horas dentro del drawer) ── */
.di{background:var(--steel);border:1px solid var(--wire);border-radius:var(--r);padding:10px 12px;margin-bottom:6px}
.di:last-child{margin-bottom:0}
.di-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}
.di-folio{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:1.5px;color:var(--gold)}
.di-title{font-size:14px;color:var(--bright);line-height:1.3;margin-bottom:4px}
.di-meta{font-size:14px;color:var(--soft);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.di-empty{font-size:15px;color:var(--soft);font-style:italic;padding:6px 0}
.di.falla-critica{border-left:3px solid var(--crimson)}
.di.falla-alta{border-left:3px solid var(--ember)}
.di.falla-media{border-left:3px solid var(--gold)}
.di.falla-baja{border-left:3px solid var(--jade)}
.di.ot-closed{opacity:.65}
.person-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px}
.person-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.person-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--steel),var(--rim));border:2px solid var(--wire);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--soft);flex-shrink:0}
.person-name{font-family:'Inter',sans-serif;font-size:16px;font-weight:500;color:var(--white)}
.person-sub{font-size:15px;color:var(--soft);font-weight:300;margin-top:1px}

/* ── CHECKLIST ITEM ── */
.ck-item{display:flex;align-items:center;gap:12px;background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:12px 13px;margin-bottom:6px;cursor:pointer}
.ck-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--jade);cursor:pointer;flex-shrink:0}
.ck-item label{font-size:15px;color:var(--bright);cursor:pointer;flex:1}
.ck-mbox{width:min(1120px,96vw)!important;max-width:min(1120px,96vw)!important;display:flex;flex-direction:column;overflow:hidden}
.ck-mbody{padding:18px 20px 28px;flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ck-layout{display:flex;flex-direction:column;gap:12px}
.ck-signature-card{background:rgba(255,255,255,.02);border:1px solid var(--wire);border-radius:12px;padding:12px}
.ck-modal-foot{
  background:rgba(18,24,32,.98);
  border-top:1px solid var(--rim);
  box-shadow:0 -12px 24px rgba(0,0,0,.28);
  position:relative;
  z-index:2;
}
.ck-top-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.ck-summary-card{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr);gap:12px;border:1px solid var(--wire);border-radius:12px;padding:12px;background:rgba(255,255,255,.02)}
.ck-items-list{display:grid;gap:10px}
.ck-group-card{border:1px solid var(--wire);border-radius:14px;padding:12px;background:rgba(255,255,255,.02)}
.ck-group-title{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:1.8px;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.ck-point-card{border:1px solid var(--wire);border-radius:12px;padding:12px;background:rgba(255,255,255,.02);transition:border-color .2s, background .2s}
.ck-point-card.is-falla{border-color:rgba(192,48,64,.35);background:rgba(192,48,64,.06)}
.ck-point-card.is-na{border-color:rgba(154,170,184,.25);background:rgba(154,170,184,.04)}
.ck-point-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.ck-point-copy{flex:1;min-width:0}
.ck-point-text{font-size:15px;font-weight:600;color:var(--bright);line-height:1.35}
.ck-point-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ck-state-group{display:grid;grid-template-columns:repeat(3,minmax(100px,1fr));gap:8px;min-width:360px}
.ck-state-btn{border:1px solid var(--wire);background:var(--plate);color:var(--soft);border-radius:10px;min-height:46px;padding:10px 12px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .18s}
.ck-state-btn.is-active{color:var(--white)}
.ck-state-btn.is-active[data-state="correcto"]{border-color:rgba(46,171,111,.45);background:rgba(46,171,111,.12);box-shadow:0 0 0 3px rgba(46,171,111,.08)}
.ck-state-btn.is-active[data-state="con_falla"]{border-color:rgba(192,48,64,.45);background:rgba(192,48,64,.14);box-shadow:0 0 0 3px rgba(192,48,64,.08)}
.ck-state-btn.is-active[data-state="no_aplica"]{border-color:rgba(154,170,184,.35);background:rgba(154,170,184,.10)}
.ck-hallazgo-wrap{margin-top:12px;border-top:1px solid var(--wire);padding-top:12px}
.ck-hallazgo-grid{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:10px;align-items:start}
.ck-hallazgo-note{font-size:11px;color:var(--muted);margin-top:6px}
.ck-summary-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}
.ck-summary-pill{border-radius:12px;padding:10px 10px;border:1px solid var(--wire);background:rgba(255,255,255,.02);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:84px;text-align:center}
.ck-summary-pill span{font-size:22px;font-weight:700;line-height:1}
.ck-summary-pill small{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;line-height:1.2;white-space:normal;overflow-wrap:anywhere}
.ck-summary-ok span{color:var(--jade)}
.ck-summary-bad span{color:#e96070}
.ck-summary-na span{color:var(--soft)}
.ck-summary-pending span{color:var(--ice)}
.ck-summary-total span{color:var(--gold2)}
.ck-mobile-step{display:grid;gap:12px}
.ck-mobile-progress{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.ck-mobile-step-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.8px;color:var(--gold);text-transform:uppercase}
.ck-mobile-step-cat{font-size:13px;color:var(--soft);margin-top:4px}
.ck-mobile-step-pct{font-size:24px;font-weight:700;color:var(--gold2);line-height:1}
.ck-mobile-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.ck-mobile-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold2))}
.ck-mobile-card{border:1px solid var(--wire);border-radius:16px;padding:16px;background:rgba(255,255,255,.02)}
.ck-mobile-card.is-falla{border-color:rgba(192,48,64,.35);background:rgba(192,48,64,.06)}
.ck-mobile-card.is-na{border-color:rgba(154,170,184,.25);background:rgba(154,170,184,.04)}
.ck-mobile-question{font-size:21px;font-weight:700;line-height:1.28;color:var(--white)}
.ck-mobile-hint{font-size:13px;color:var(--muted);margin-top:8px}
.ck-state-group-mobile{grid-template-columns:1fr!important;min-width:0!important;margin-top:14px}
.ck-mobile-nav{display:flex;gap:8px}
.ck-mobile-nav .btn{flex:1}
.ck-mobile-nav .btn[disabled],.ck-state-btn[disabled]{opacity:.45;cursor:not-allowed}

@media(max-width:767px){
  #checkVeil{align-items:stretch}
  .ck-mbox{
    width:100%!important;
    max-width:100%!important;
    min-height:100dvh;
    max-height:100dvh;
    border-radius:0!important;
    border-left:none!important;
    border-right:none!important;
    border-bottom:none!important;
  }
  #checkVeil .sheet-handle{display:none}
  #checkVeil .mtop{
    position:sticky;
    top:0;
    z-index:3;
    background:rgba(24,32,46,.96);
    backdrop-filter:blur(12px);
    padding:14px 16px 12px;
  }
  .ck-mbody{padding:12px 12px 24px}
  .ck-top-grid{grid-template-columns:1fr}
  .ck-summary-card{grid-template-columns:1fr;padding:10px}
  .ck-point-head{flex-direction:column}
  .ck-point-text{font-size:16px}
  .ck-point-sub{font-size:11px}
  .ck-state-group{
    min-width:0;
    width:100%;
    grid-template-columns:1fr 1fr 1fr;
  }
  .ck-state-btn{
    min-height:48px;
    padding:10px 6px;
    font-size:14px;
    border-radius:12px;
  }
  .ck-mobile-question{font-size:22px}
  .ck-hallazgo-wrap{
    background:rgba(255,255,255,.02);
    border-radius:12px;
    padding:12px;
    margin-top:10px;
  }
  .ck-hallazgo-grid{grid-template-columns:1fr}
  .ck-summary-strip{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  .ck-summary-pill{
    min-height:72px;
    padding:8px;
  }
  .ck-summary-pill:last-child:nth-child(odd){
    grid-column:1 / -1;
  }
  #checkVeil .ck-modal-foot{
    padding:10px 12px calc(10px + var(--safe-bot));
    backdrop-filter:blur(12px);
  }
}

/* ── SELECT STATE INLINE ── */
.inline-sel{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:5px 8px;color:var(--bright);font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}

/* ── LOGIN ── */
#loginScreen{position:fixed;inset:0;background:var(--void);z-index:999;display:none;align-items:center;justify-content:center;padding:20px}
#loginScreen::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(255,213,0,0.06),transparent 60%)}
.login-box{width:100%;max-width:380px;position:relative;z-index:1}
.login-logo{text-align:center;margin-bottom:32px}
.login-eye{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:4px;color:var(--gold);text-transform:uppercase;margin-bottom:8px}
.login-name{font-family:'Inter',sans-serif;font-size:28px;font-weight:700;color:var(--white);line-height:1}
.login-name em{font-style:italic;color:var(--gold2)}
.login-sub{font-family:'Barlow Condensed',sans-serif;font-size:15px;letter-spacing:3px;color:var(--soft);margin-top:6px;text-transform:uppercase}
.login-card{background:var(--plate);border:1px solid var(--wire);border-radius:12px;padding:28px;box-shadow:0 40px 80px rgba(0,0,0,.5)}
.login-card::before{content:'';display:block;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:-28px -28px 24px;border-radius:12px 12px 0 0}

/* ── TEC PANEL ── */
#tecPanel{display:none;position:fixed;inset:0;background:var(--void);z-index:200;overflow-y:auto}
.tec-topbar{background:rgba(8,10,13,.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--wire);padding:calc(16px + var(--safe-top)) 16px 14px;position:sticky;top:0;z-index:10}
.tec-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.tec-name{font-family:'Inter',sans-serif;font-size:18px;font-weight:600;color:var(--white)}
.tec-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:2px}
.tec-body{padding:16px 14px calc(20px + var(--safe-bot))}
.tec-section-title{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;letter-spacing:3px;color:var(--soft);text-transform:uppercase;margin:20px 0 12px;display:flex;align-items:center;gap:8px}
.tec-section-title::after{content:'';flex:1;height:1px;background:var(--rim)}
.tec-ot-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px}
.tec-ot-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.tec-ot-folio{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:1.5px;color:var(--gold)}
.tec-ot-eq{font-family:'Inter',sans-serif;font-size:15px;font-weight:600;color:var(--white);margin-top:2px}
.tec-ot-desc{font-size:14px;color:var(--soft);margin:4px 0 10px;line-height:1.4}
.tec-ot-actions{display:flex;gap:6px;flex-wrap:wrap}

/* ── QUICK ACTIONS (Home) ── */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.quick-btn{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:16px 14px;cursor:pointer;transition:border-color .15s;display:flex;flex-direction:column;gap:8px;align-items:flex-start;position:relative;overflow:hidden}
.quick-btn:active{border-color:rgba(255,213,0,.3);background:var(--plate)}
.quick-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.quick-btn.jade::before{background:var(--jade)}
.quick-btn.gold::before{background:var(--gold)}
.quick-btn.crimson::before{background:var(--crimson)}
.quick-btn.ice::before{background:var(--ice)}
.quick-btn.ember::before{background:var(--ember)}
.quick-icon{font-size:22px;line-height:1}
.quick-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;color:var(--bright);line-height:1.2}
.quick-sub{font-size:14px;color:var(--soft);font-weight:300}

/* ── REPORT CARDS ── */
.report-card{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:14px 15px;margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:14px}
.report-card:active{border-color:rgba(255,213,0,.25)}
.report-card-ico{width:40px;height:40px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.report-card-body{flex:1;min-width:0}
.report-card-title{font-size:15px;font-weight:500;color:var(--bright);margin-bottom:2px}
.report-card-sub{font-size:15px;color:var(--soft);font-weight:300}
.report-card-meta{font-family:'Barlow Condensed',sans-serif;font-size:15px;letter-spacing:1px;color:var(--soft);margin-top:4px}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:var(--wire);border-radius:2px}


/* ══════════════════════════════════
   EQUIPO — PÁGINA DE DETALLE
══════════════════════════════════ */
.eq-page-hero{
  background:linear-gradient(135deg,var(--plate) 0%,var(--carbon) 100%);
  border:1px solid var(--wire);border-radius:var(--r3);
  padding:20px;margin-bottom:16px;position:relative;overflow:hidden;
}
.eq-page-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2),transparent)}
.eq-page-breadcrumb{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:1px;margin-bottom:12px}
.eq-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.eq-page-title-block{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.eq-page-actions-top{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.eq-page-kicker{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2.4px;
  color:var(--muted);text-transform:uppercase;margin-bottom:2px;
}
.eq-page-id{
  display:block;
  font-family:'Barlow Condensed',sans-serif;font-size:42px;font-weight:800;letter-spacing:1.4px;
  color:var(--gold2);line-height:.92;
  margin-bottom:4px;
}
.eq-page-name{font-family:'Inter',sans-serif;font-size:24px;font-weight:700;color:var(--white);line-height:1.08}
.eq-page-sub{font-size:14px;color:var(--soft);font-weight:300;margin-top:2px}
.eq-page-kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:16px}
.eq-kpi{background:rgba(0,0,0,.2);border:1px solid var(--wire);border-radius:var(--r);padding:12px 14px}
.eq-kpi-lbl{font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:600;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
.eq-kpi-val{font-family:'Inter',sans-serif;font-size:26px;font-weight:600;line-height:1}
.eq-kpi-sub{font-size:11px;color:var(--soft);margin-top:2px}

/* Action cards grid */
.eq-page-actions-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}
.eq-action-card{
  background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);
  min-height:130px;padding:11px 12px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:6px;
}
.eq-action-card:active,.eq-action-card:hover{border-color:rgba(255,213,0,.3);background:var(--steel)}
.eq-action-card:focus-visible{
  outline:none;border-color:rgba(255,213,0,.55);
  box-shadow:0 0 0 3px rgba(255,213,0,.16);
}
.eq-action-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.eq-action-card.ac-gold::before{background:var(--gold)}
.eq-action-card.ac-crimson::before{background:var(--crimson)}
.eq-action-card.ac-jade::before{background:var(--jade)}
.eq-action-card.ac-ice::before{background:var(--ice)}
.eq-action-card.ac-ember::before{background:var(--ember)}
.eq-action-card.ac-dim::before{background:var(--wire)}
.eq-ac-head{display:flex;align-items:center;gap:10px}
.eq-ac-badge{
  position:absolute;top:14px;right:14px;
  background:var(--crimson);color:#fff;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  padding:2px 8px;border-radius:10px;
}
.eq-ac-badge.gold{background:var(--gold);color:var(--void)}
.eq-ac-badge.jade{background:var(--jade);color:var(--void)}
.eq-ac-code{
  width:34px;height:34px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:800;letter-spacing:1px;
}
.eq-ac-meta{
  min-width:0;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:#95a3b5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.eq-ac-body{display:flex;flex-direction:column;gap:3px;min-height:0}
.eq-ac-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:650;color:var(--white);line-height:1.2}
.eq-ac-desc{
  font-size:11px;color:#b0bccb;font-weight:350;line-height:1.28;
  display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.eq-ac-actions{display:flex;align-items:center;gap:6px;margin-top:auto}
.eq-ac-btn{
  border-radius:10px;padding:6px 8px;border:1px solid transparent;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  transition:all .15s ease;
}
.eq-ac-btn--primary{background:var(--gf);border-color:rgba(255,213,0,.35);color:var(--gold2)}
.eq-ac-btn--primary:hover{background:rgba(255,213,0,.16)}
.eq-ac-btn--ghost{background:transparent;border-color:var(--wire);color:var(--soft)}
.eq-ac-btn--ghost:hover{border-color:rgba(255,255,255,.2);color:var(--bright)}
.eq-ac-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(255,213,0,.2);
}

/* Tabs */
.eq-page-tabs{display:flex;gap:4px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.eq-page-tabs::-webkit-scrollbar{display:none}
.eq-tab{
  flex-shrink:0;padding:9px 16px;border-radius:var(--r);
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;
  color:var(--soft);background:var(--plate);border:1px solid var(--wire);
  cursor:pointer;transition:all .15s;
}
.eq-tab.active{background:var(--gf);border-color:rgba(255,213,0,.3);color:var(--gold2)}
.eq-tab:active{background:var(--steel)}

/* Tab content */
.eq-tab-section{margin-bottom:10px}
.eq-tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.eq-tab-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:500;color:var(--white)}

/* Info ficha */
.eq-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.eq-info-item{background:var(--plate);border:1px solid var(--wire);border-radius:var(--r);padding:12px 14px}
.eq-info-item label{display:block;font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:600;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
.eq-info-item value{font-size:15px;color:var(--bright)}

.eq-tech-shell{display:flex;flex-direction:column;gap:14px}
.eq-tech-hero{
  display:grid;grid-template-columns:1.6fr 1fr;gap:12px;
  padding:18px;border:1px solid var(--wire);border-radius:var(--r3);
  background:linear-gradient(135deg,rgba(255,213,0,.08),rgba(59,130,196,.06) 52%,rgba(18,24,32,.96));
}
.eq-tech-kicker{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;
  color:var(--gold2);text-transform:uppercase;margin-bottom:8px;
}
.eq-tech-name-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.eq-tech-id{
  font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;
  color:var(--gold);margin-bottom:3px;
}
.eq-tech-name{font-family:'Inter',sans-serif;font-size:24px;font-weight:700;color:var(--white);line-height:1.08}
.eq-tech-sub{margin-top:8px;font-size:14px;color:var(--soft)}
.eq-tech-hero-side{display:grid;grid-template-columns:1fr;gap:10px}
.eq-tech-hero-card{
  min-height:88px;padding:14px 15px;border-radius:var(--r2);
  border:1px solid rgba(255,255,255,.08);background:rgba(7,9,13,.38);
  display:flex;flex-direction:column;justify-content:center;
}
.eq-tech-hero-label{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.8px;
  color:var(--muted);text-transform:uppercase;margin-bottom:6px;
}
.eq-tech-hero-value{font-size:17px;font-weight:600;color:var(--bright);line-height:1.2}
.eq-tech-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.eq-tech-kpi{
  background:var(--plate);border:1px solid var(--wire);border-radius:var(--r2);
  padding:14px 15px;
}
.eq-tech-kpi-label{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:1.8px;
  color:var(--muted);text-transform:uppercase;margin-bottom:6px;
}
.eq-tech-kpi-value{font-size:26px;font-weight:700;color:var(--bright);line-height:1}
.eq-tech-kpi-value.is-gold,.eq-tech-cell.is-gold .eq-tech-value{color:var(--gold2)}
.eq-tech-kpi-value.is-warn{color:#ff9d67}
.eq-tech-sections{display:flex;flex-direction:column;gap:12px}
.eq-tech-section{
  background:var(--plate);border:1px solid var(--wire);border-radius:var(--r3);padding:16px;
}
.eq-tech-section-title{
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;
  color:var(--gold2);text-transform:uppercase;margin-bottom:12px;
}
.eq-tech-grid{display:grid;gap:10px}
.eq-tech-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.eq-tech-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.eq-tech-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.eq-tech-cell{
  min-width:0;padding:13px 14px;border-radius:var(--r2);
  background:rgba(7,9,13,.34);border:1px solid rgba(255,255,255,.06);
}
.eq-tech-label{
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.8px;
  color:var(--muted);text-transform:uppercase;margin-bottom:6px;
}
.eq-tech-value{font-size:15px;font-weight:600;color:var(--bright);line-height:1.3;word-break:break-word}
.eq-tech-cell.is-code .eq-tech-value{font-family:Consolas,'Courier New',monospace;font-size:13px}
.eq-tech-note{
  padding:14px 15px;border-radius:var(--r2);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  color:var(--soft);font-size:14px;line-height:1.55;
}

@media(max-width:767px){
  .eq-page-id{font-size:34px}
  .eq-page-name{font-size:21px}
  .eq-page-actions-grid{grid-template-columns:1fr 1fr;gap:8px}
  .eq-action-card{min-height:124px;padding:10px 11px}
  .eq-ac-title{font-size:14px}
  .eq-ac-desc{font-size:10.5px}
  .eq-tech-hero{grid-template-columns:1fr}
  .eq-tech-name{font-size:21px}
  .eq-tech-name-row{flex-direction:column}
  .eq-tech-kpis{grid-template-columns:repeat(2,1fr)}
  .eq-tech-grid.cols-2,
  .eq-tech-grid.cols-3,
  .eq-tech-grid.cols-4{grid-template-columns:1fr}
}

@media(min-width:768px){
  .eq-page-kpis{grid-template-columns:repeat(4,1fr)}
  .eq-page-actions-grid{grid-template-columns:repeat(3,1fr)}
  .eq-info-grid{grid-template-columns:repeat(3,1fr)}
}

/* ══════════════════════════════════════════
   DESKTOP — layout completo, no mobile
══════════════════════════════════════════ */
@media(min-width:768px){

  /* Reset mobile shell */
  body{overflow:auto;height:auto}

  /* Topbar — fijo, pero solo del ancho sin sidebar */
  .topbar{
    position:fixed;top:0;left:260px;right:0;
    height:64px;padding-left:32px;padding-right:24px;
    background:rgba(11,14,20,0.96);
  }
  .topbar-left .hamburger{display:none}

  /* Sidebar — fijo izquierda, ancho completo */
  .sidebar{
    position:fixed;top:0;left:0;width:260px;height:100vh;
    transform:none!important;
  }
  .sidebar-veil{display:none!important}

  /* Main scroll — margen izquierdo = sidebar, arriba = topbar */
  .main-scroll{
    position:static;
    margin-left:260px;
    margin-top:64px;
    height:auto;
    overflow:visible;
    padding-bottom:0;
  }

  /* Pages */
  .page{padding:28px 32px 48px}

  /* Hide mobile-only */
  .bottom-nav{display:none!important}
  .fab{display:none!important}

  /* KPI strip — 5 columnas */
  .kpi-strip{grid-template-columns:repeat(5,1fr)}
  .kpi-cell:last-child:nth-child(odd){grid-column:auto}
  .kpi-cell{padding:18px 20px}
  .kpi-num{font-size:36px}

  /* Cards: 2 col grid */
  .cards-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .cards-list .eq-card{margin-bottom:0}

  /* Drawer: panel lateral fijo */
  .dveil{display:none!important}
  .drawer{
    position:fixed;top:64px;right:0;
    width:520px;height:calc(100vh - 64px);
    border-radius:0;
    transform:translateX(100%);
    transition:transform .3s cubic-bezier(.22,1,.36,1);
  }
  .drawer.open{transform:translateX(0)}

  /* Modals: center floating */
  .veil{align-items:center;justify-content:center}
  .mbox{
    width:780px;max-width:92vw;
    border-radius:14px;border:1px solid var(--wire);
    max-height:88vh;
  }
  #modal-reportar-falla-1 .mbox{
    width:860px;
    max-width:94vw;
  }
  @keyframes sheetUp{
    from{opacity:0;transform:scale(.96) translateY(12px)}
    to{opacity:1;transform:scale(1) translateY(0)}
  }

  /* Form grids on desktop */
  .fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .fgrid .fg{margin-bottom:0}
  .fgrid-2{grid-template-columns:1fr 1fr}
  .maint-wizard-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-rule-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-v2-form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .maint-v2-rule-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-v2-rule-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-v2-content-grid{grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr)}
  .maint-v2-side-grid{grid-template-columns:1fr}
  .maint-v2-pickers{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-plan-stack{grid-template-columns:repeat(2,minmax(0,1fr))}
  .maint-plan-definition-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .maint-plan-metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .maint-plan-main-grid{grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr)}
  .maint-dual-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  #checkVeil .ck-layout{display:flex;flex-direction:column}
  #checkVeil .ck-top-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  #checkVeil .ck-summary-card{grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr)}
  #checkVeil .ck-items-list{display:grid;grid-template-columns:1fr}

  /* Quick actions */
  .quick-grid{grid-template-columns:repeat(4,1fr)}

  /* Dash */
  .dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}

  /* Toast bottom right */
  .toast{left:auto;right:24px;bottom:24px;width:320px}
}

/* ═══════════════════════════════════════════════════════
   MODAL OT PREMIUM - v2
═══════════════════════════════════════════════════════ */

.ot-mbox-premium {
  display: flex;
  flex-direction: column;
  max-height: 95vh;
  padding: 0;
}

/* HEADER STICKY */
.ot-header-sticky {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 22px;
  background: var(--steel);
  border-bottom: 1px solid var(--wire);
}

.ot-header-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: rgba(255, 213, 0, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}

.ot-header-text {
  flex: 1;
  min-width: 0;
}

.ot-header-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.ot-header-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--bright);
  line-height: 1.2;
  margin-bottom: 4px;
}

.ot-header-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--muted);
}

.ot-meta-sep {
  color: var(--wire);
}

.ot-meta-val {
  color: var(--soft);
  font-weight: 600;
}

.ot-meta-val-muted {
  color: var(--muted);
  font-style: italic;
  font-weight: 500;
}

/* BODY SCROLLABLE */
.ot-body-premium {
  flex: 1;
  overflow-y: auto;
  padding: 18px 22px 18px;
}

.ot-detail-layout {
  display: block;
}

.ot-detail-main,
.ot-detail-side {
  min-width: 0;
}

.otd-eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}

.otd-top {
  padding: 14px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  align-items: center;
}

.otd-top-main {
  flex: 1;
  min-width: 0;
}

.otd-top-pills {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.otd-top-folio {
  margin-bottom: 0;
  padding-top: 0;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  color: var(--muted);
}

.otd-top-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1;
  letter-spacing: .02em;
}

.otd-top-subtitle {
  margin-top: 5px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.25;
}

.otd-top-close {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  margin-left: 14px;
  background: rgba(15,22,33,.7);
  border-color: rgba(103,149,198,.22);
}

.otd-alert {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  border-bottom: 1px solid rgba(192,48,64,.28);
  background: linear-gradient(180deg, rgba(192,48,64,.14), rgba(192,48,64,.08));
  color: #ffb8bf;
  font-size: 12.5px;
  font-weight: 500;
}

.otd-alert-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid rgba(255,184,191,.32);
  font-size: 12px;
  color: #ffd7db;
}

.otd-alert-sep {
  color: rgba(255,255,255,.46);
}

.otd-body {
  padding: 14px 18px 8px;
}

.otd-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(280px, 1fr);
  gap: 18px;
  align-items: start;
}

.otd-primary {
  min-width: 0;
}

.otd-control-col {
  min-width: 0;
}

.otd-support-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
}

.otd-support-card {
  margin-bottom: 0;
  background: rgba(16,22,32,.28);
  border-color: rgba(255,255,255,.05);
}

.otd-support-card-full {
  grid-column: 1 / -1;
}

.otd-control-panel {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.otd-panel,
.otd-section {
  background: rgba(18,25,36,.42);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px;
  padding: 14px;
  margin-bottom: 12px;
}

.otd-panel-kicker,
.otd-section-kicker {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tx2, var(--soft));
}

.otd-panel-subkicker {
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 3px;
}

.otd-section-kicker-danger {
  color: var(--crimson);
}

.otd-panel-title {
  margin-top: 8px;
  font-size: 15px;
  color: var(--bright);
  line-height: 1.55;
}

.otd-panel-note {
  font-size: 13px;
  color: var(--soft);
  white-space: pre-line;
}

.otd-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.otd-section-meta,
.otd-section-subline,
.otd-section-side-note {
  font-size: 11.5px;
  color: var(--muted);
}

.otd-section-side-note {
  white-space: nowrap;
}

.otd-inline-form {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.otd-thin-progress {
  height: 4px;
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  overflow: hidden;
}

.otd-thin-progress-bar {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold), #f7df71);
  transition: width .25s ease;
}

.otd-top-pills .spill {
  gap: 6px;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .02em;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.otd-top-pills .s-dot {
  width: 6px;
  height: 6px;
}

.otd-top-pills .sp-op {
  color: #8ecbff;
  border-color: rgba(72,176,232,.28);
  background: rgba(72,176,232,.10);
}

.otd-top-pills .sp-maint {
  color: #ffe57b;
  border-color: rgba(255,213,0,.28);
  background: rgba(255,213,0,.08);
}

.otd-top-pills .sp-fs {
  color: #ffb0ba;
  border-color: rgba(192,48,64,.24);
  background: rgba(192,48,64,.10);
}

.otd-top-pills .sp-sb {
  color: #9fdcff;
  border-color: rgba(72,176,232,.22);
  background: rgba(72,176,232,.08);
}

.otd-top-pills .sp-pend {
  color: #c9d4e7;
  border-color: rgba(201,212,231,.18);
  background: rgba(201,212,231,.06);
}

.otd-top-pills .sp-comp {
  color: #8fe0b4;
  border-color: rgba(46,171,111,.24);
  background: rgba(46,171,111,.10);
}

.otd-eyebrow-gold {
  color: var(--gold);
}

.otd-timer-shell {
  background: rgba(24,35,58,.96);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 0;
  align-items: stretch;
  justify-content: flex-start;
  flex-direction: column;
  gap: 8px;
  text-align: center;
}

.otd-timer-main {
  min-width: 0;
  flex: 1;
}

.otd-timer-display {
  font-family: var(--mono, ui-monospace, monospace);
  font-size: 32px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .02em;
  line-height: 1;
}

.otd-timer-status {
  font-size: 11.5px;
  color: var(--tx3, var(--muted));
  margin-top: 0;
}

.otd-timer-actions,
.otd-manual-actions,
.otd-state-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.otd-timer-actions {
  width: 100%;
  justify-content: stretch;
}

.otd-action-btn {
  min-width: 0;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 8px;
}

.otd-action-btn-primary {
  flex: 1;
  width: 100%;
}

.otd-manual-time-wrap {
  display: none;
  background: rgba(255,213,0,.05);
  border: 1px solid rgba(255,213,0,.18);
  border-radius: 10px;
  padding: 12px;
  margin: -2px 0 12px;
}

.otd-manual-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(110px, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

.otd-manual-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.otd-manual-actions {
  justify-content: flex-end;
  margin-top: 10px;
}

.otd-progress-card,
.otd-control-meta {
  background: rgba(24,35,58,.96);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 11px 12px;
}

.otd-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 5px;
}

.otd-progress-label {
  font-size: 11.5px;
  color: var(--tx2, var(--soft));
  font-weight: 500;
}

.otd-progress-estimate {
  font-size: 11.5px;
  color: var(--muted);
}

.otd-progress-summary {
  font-size: 11px;
  color: var(--tx3, var(--muted));
  font-weight: 400;
  margin-bottom: 8px;
}

.otd-control-meta {
  padding: 0;
  overflow: hidden;
}

.otd-control-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.otd-control-meta-row:last-child {
  border-bottom: 0;
}

.otd-control-meta-row-clickable {
  cursor: pointer;
}

.otd-control-meta-key {
  font-size: 12.5px;
  color: var(--muted);
}

.otd-control-meta-value {
  font-size: 12.5px;
  color: var(--bright);
  font-weight: 500;
  text-align: right;
}

.otd-control-meta-value-gold {
  color: var(--gold);
  font-weight: 600;
}

.otd-side-btn,
.otd-validate-btn {
  width: 100%;
  min-height: 42px;
}

.otd-validate-wrap {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.otd-validate-btn {
  min-height: 40px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
}

.otd-validate-btn:disabled {
  opacity: .45;
  box-shadow: none;
}

.otd-main-action-hint {
  font-size: 11px;
  color: var(--muted);
  text-align: center;
}

.otd-more-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}

.otd-more-actions-footer {
  align-items: flex-start;
}

.otd-more-actions-toggle {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: underline;
}

.otd-more-actions-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 4px;
}

.otd-more-action-item,
.otd-more-action-empty {
  width: 100%;
  min-height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--soft);
  font-size: 11.5px;
  font-weight: 600;
  padding: 0 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.otd-more-action-item {
  cursor: pointer;
}

.otd-more-action-item.is-danger {
  color: #ff9ca7;
  border-color: rgba(192,48,64,.25);
  background: rgba(192,48,64,.08);
}

.otd-more-action-empty {
  color: var(--muted);
}

.otd-secondary-zone {
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
}

.otd-secondary-zone #otd-pausas-sec,
.otd-secondary-zone #otd-related-sec,
.otd-secondary-zone #otd-reasig-log {
  margin-bottom: 12px;
}

.ot-related-section {
  margin-top: 0;
}

.ot-related-total-badge {
  color: var(--ice);
  background: rgba(72,176,232,.14);
}

.ot-related-group {
  margin-top: 10px;
}

.ot-related-group:first-child {
  margin-top: 0;
}

.ot-related-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

.ot-related-group-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--soft);
}

.ot-related-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 20px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.06);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: var(--bright);
}

.ot-related-scroll {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
  max-height: 140px;
  overflow-y: auto;
  padding-right: 4px;
}

.ot-related-scroll::-webkit-scrollbar,
.ot-activity-scroll::-webkit-scrollbar {
  width: 8px;
}

.ot-related-scroll::-webkit-scrollbar-thumb,
.ot-activity-scroll::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.14);
  border-radius: 999px;
}

.ot-related-card {
  position: relative;
  background: rgba(8,12,18,.26);
  border: 1px solid rgba(255,255,255,.04);
  border-left: 2px solid var(--gold);
  border-radius: 12px;
  padding: 8px 9px;
  cursor: pointer;
  transition: transform .14s ease, border-color .14s ease, background .14s ease;
}

.ot-related-card:hover {
  transform: translateY(-1px);
  border-color: rgba(255,213,0,.12);
  background: rgba(13,18,26,.42);
}

.ot-related-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.ot-related-card-main {
  min-width: 0;
}

.ot-related-card-folio {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.2px;
  color: var(--gold);
  text-transform: uppercase;
}

.ot-related-card-desc {
  font-size: 12px;
  font-weight: 600;
  color: var(--bright);
  line-height: 1.3;
  margin-top: 2px;
}

.ot-related-card-meta {
  font-size: 10px;
  color: var(--muted);
  line-height: 1.35;
  margin-top: 4px;
}

.otd-falla-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.otd-falla-card {
  position: relative;
  border: 0;
  border-left: 3px solid rgba(255,255,255,.1);
  border-radius: 0;
  background: rgba(24,35,58,.94);
  padding: 11px 13px;
  cursor: pointer;
  transition: background .2s ease, opacity .2s ease;
}

.otd-falla-card.is-critica {
  border-left-color: #e24b4a;
}

.otd-falla-card.is-alta {
  border-left-color: #f5a623;
}

.otd-falla-card.is-media,
.otd-falla-card.is-baja {
  border-left-color: rgba(255,255,255,.22);
}

.otd-falla-card.state-en_proceso {
  border-left-color: #f5c518;
  background: rgba(245,197,24,.06);
}

.otd-falla-card.state-pausada {
  opacity: .92;
}

.otd-falla-card.state-completada {
  border-left-color: #2ecc8f;
  background: rgba(46,204,143,.07);
}

.otd-falla-card.state-completada .otd-falla-title {
  color: var(--soft);
  text-decoration: line-through;
}

.otd-falla-card.state-completada .otd-falla-time {
  color: #7fe3bc;
}

.otd-falla-card-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.otd-falla-card-main {
  min-width: 0;
}

.otd-falla-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  margin-bottom: 4px;
}

.otd-falla-folio {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--muted);
}

.otd-falla-title {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--bright);
  line-height: 1.32;
}

.otd-falla-meta {
  margin-top: 2px;
  font-size: 11px;
  color: var(--soft);
}

.otd-falla-card-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 9px;
}

.otd-falla-select {
  width: 100%;
  min-height: 34px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(30,42,68,.96);
  color: var(--bright);
  padding: 0 10px;
  font-size: 12.5px;
}

.otd-falla-ia-link {
  border: 0;
  background: transparent;
  color: var(--ice);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}

.otd-falla-ia-hint {
  margin-top: 8px;
  font-size: 12px;
  color: var(--ice);
}

.otd-falla-tools {
  display: flex;
  gap: 8px;
  margin-top: 9px;
}

.otd-falla-tool-btn {
  flex: 1;
  min-height: 34px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(30,42,68,.96);
  color: var(--soft);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
}

.otd-falla-tool-btn:hover {
  background: rgba(255,255,255,.08);
}

.otd-falla-tool-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
}

.otd-falla-tool-btn.has {
  color: var(--bright);
}

.otd-falla-tool-btn-accent {
  color: #90e2c1;
  border-color: rgba(46,204,143,.34);
  background: rgba(46,204,143,.14);
}

.otd-falla-tool-btn-accent.has {
  background: rgba(46,204,143,.18);
}

.otd-falla-ref {
  margin-top: 8px;
}

.otd-falla-ref-head {
  width: 100%;
  min-height: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.08);
  border-left: 2px solid #e87722;
  border-radius: 0 6px 6px 0;
  background: rgba(30,42,68,.96);
  color: var(--tx2, var(--soft));
  padding: 0 10px;
  cursor: pointer;
}

.otd-falla-ref-head-main {
  color: var(--bright);
  font-size: 11.5px;
  font-weight: 500;
}

.otd-falla-ref-head-side {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.otd-ref-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 18px;
  padding: 1px 7px;
  border-radius: 5px;
  font-size: 10px;
  font-weight: 500;
}

.otd-ref-pill.is-pending {
  background: rgba(245,166,35,.16);
  color: #f6c77a;
}

.otd-ref-pill.is-transit {
  background: rgba(53,138,221,.16);
  color: #7fb6f0;
}

.otd-ref-pill.is-received {
  background: rgba(46,204,143,.16);
  color: #7fe3bc;
}

.otd-falla-ref-chevron {
  color: var(--muted);
  transition: transform .2s ease;
}

.otd-falla-ref-chevron.open {
  transform: rotate(90deg);
}

.otd-falla-ref-list {
  max-height: 0;
  overflow: hidden;
  transition: max-height .22s ease, margin-top .22s ease;
}

.otd-falla-ref-list.open {
  max-height: 220px;
  margin-top: 4px;
  overflow-y: auto;
}

.otd-ref-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 10px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  font-size: 11px;
  color: var(--soft);
}

.otd-ref-row:last-child {
  border-bottom: 0;
}

.otd-ref-row-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.otd-ref-row-status {
  flex-shrink: 0;
  font-weight: 600;
}

.otd-ref-row-status.is-pending {
  color: #f6c77a;
}

.otd-ref-row-status.is-transit {
  color: #7fb6f0;
}

.otd-ref-row-status.is-received {
  color: #7fe3bc;
}

.otd-falla-card-side {
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  gap: 0;
  flex-wrap: nowrap;
  justify-content: flex-start;
}

.otd-falla-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.otd-falla-action-btn {
  min-width: 94px;
}

.otd-falla-time {
  font-family: var(--mono, ui-monospace, monospace);
  font-size: 15px;
  font-weight: 700;
  color: var(--bright);
  letter-spacing: .02em;
}

.otd-falla-expand-wrap {
  display: flex;
  justify-content: flex-end;
}

.otd-falla-detail {
  margin-top: 12px;
}

.otd-add-falla-btn {
  width: 100%;
  margin-top: 10px;
  border: 1px dashed var(--wire);
  color: var(--gold);
  font-size: 12.5px;
}

.ot-detail-foot {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: space-between;
}

.ot-detail-foot-tools {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.otd-footer-tool {
  min-height: 34px;
  padding: 6px 12px;
  font-size: 11px;
  color: var(--muted);
  border-color: rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}

.ot-fallas-table-wrap {
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(9,14,22,.42);
}

.ot-fallas-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.ot-fallas-table thead th {
  text-align: left;
  padding: 10px 12px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.ot-fallas-table tbody td {
  padding: 10px 12px;
  font-size: 13px;
  color: var(--bright);
  border-bottom: 1px solid rgba(255,255,255,.05);
  vertical-align: middle;
}

.ot-fallas-table tbody tr:last-child td {
  border-bottom: 0;
}

.ot-falla-row {
  cursor: pointer;
}

.ot-falla-row:hover {
  background: rgba(255,255,255,.025);
}

.ot-falla-col-main {
  min-width: 0;
}

.ot-falla-main-title {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.ot-falla-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #f5c518;
  flex-shrink: 0;
}

.ot-falla-main-text {
  min-width: 0;
}

.ot-falla-main-folio {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--soft);
  letter-spacing: 1px;
}

.ot-falla-main-desc {
  font-size: 13px;
  font-weight: 600;
  color: var(--bright);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ot-falla-main-meta {
  margin-top: 3px;
  font-size: 11px;
  color: var(--muted);
}

.ot-falla-chip {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 2px 7px;
  border-radius: 5px;
  border: 0;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--bright);
}

.ot-falla-chip.is-main {
  border-color: rgba(255,213,0,.16);
  color: var(--gold);
  background: rgba(255,213,0,.06);
}

.ot-falla-chip.is-new {
  border-color: rgba(72,176,232,.16);
  color: var(--ice);
  background: rgba(72,176,232,.06);
}

.ot-falla-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.ot-falla-actions .btn {
  min-width: auto;
}

.ot-falla-detail-row td {
  padding: 0;
  background: rgba(255,255,255,.02);
}

.ot-falla-detail-inner {
  padding: 12px;
}

.ot-detail-foot {
  justify-content: flex-end;
  gap: 10px;
}

.ot-detail-foot .btn {
  flex: 0 0 auto;
  min-height: 40px;
  padding: 9px 18px;
  font-size: 13px;
  letter-spacing: 1px;
}

.ot-detail-foot-secondary {
  min-width: 128px;
}

.ot-detail-foot-primary {
  min-width: 210px;
}

.ot-related-card .spill {
  flex-shrink: 0;
}

.ot-activity-scroll {
  max-height: 320px;
  overflow-y: auto;
  padding-right: 4px;
}

/* BANNER IA */
.ot-ia-banner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255, 213, 0, 0.07);
  border: 1px solid rgba(255, 213, 0, 0.25);
  border-left: 3px solid var(--gold);
  border-radius: var(--r);
  margin-bottom: 18px;
}

.ot-ia-banner-icon {
  font-size: 18px;
  line-height: 1;
  flex-shrink: 0;
  padding-top: 2px;
}

.ot-ia-banner-content {
  flex: 1;
  min-width: 0;
}

.ot-ia-banner-title {
  font-size: 12px;
  color: var(--bright);
  line-height: 1.5;
  font-weight: 500;
}

.ot-ia-banner-hint {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.4;
  margin-top: 4px;
  font-style: italic;
}

/* SECCIONES */
.ot-section {
  margin-bottom: 22px;
}

.ot-section-head {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 12px;
}

.ot-section-num {
  width: 22px;
  height: 22px;
  border-radius: 11px;
  background: rgba(255, 213, 0, 0.18);
  color: var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

.ot-section-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--bright);
  letter-spacing: 0.2px;
}

.ot-section-optional {
  font-size: 11px;
  font-weight: 400;
  color: var(--muted);
  font-style: italic;
}

/* GRIDS */
.ot-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 10px;
}

.ot-grid-2:last-child {
  margin-bottom: 0;
}

.ot-grid-2-asym {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 12px;
}

/* Mobile */
@media (max-width: 640px) {
  .otd-alert,
  .otd-top {
    padding: 12px 16px 10px;
  }
  .otd-top {
    align-items: flex-start;
  }
  .otd-body {
    padding: 12px 16px 6px;
  }
  .otd-workspace {
    grid-template-columns: 1fr;
  }
  .otd-support-grid {
    grid-template-columns: 1fr;
  }
  .otd-control-panel {
    position: static;
  }
  .otd-top-title {
    white-space: normal;
  }
  .otd-top-close {
    width: 34px;
    height: 34px;
    margin-left: 10px;
  }
  .otd-top-pills .spill {
    min-height: 28px;
    padding: 0 10px;
  }
  .otd-timer-shell {
    flex-direction: column;
    align-items: stretch;
  }
  .otd-timer-actions,
  .otd-manual-actions,
  .otd-state-actions {
    justify-content: stretch;
  }
  .otd-falla-card-row {
    grid-template-columns: 1fr;
  }
  .otd-falla-card-side {
    justify-content: flex-start;
    align-items: flex-start;
  }
  .otd-falla-card-controls,
  .otd-falla-tools,
  .ot-detail-foot,
  .ot-detail-foot-tools {
    flex-direction: column;
    align-items: stretch;
  }
  .otd-more-actions-footer {
    align-items: stretch;
  }
  .otd-timer-actions .btn,
  .otd-manual-actions .btn,
  .otd-state-actions .btn {
    flex: 1;
    min-width: 0;
  }
  .otd-manual-grid {
    grid-template-columns: 1fr;
  }
  .ot-grid-2,
  .ot-grid-2-asym {
    grid-template-columns: 1fr;
  }
  .ot-related-scroll,
  .ot-activity-scroll {
    max-height: none;
  }
  .ot-detail-foot {
    justify-content: stretch;
  }
  .ot-detail-foot .btn {
    flex: 1;
    min-width: 0;
  }
}

@media (max-width: 900px){
  .maint-plan-mbox{
    width:100%;
    max-height:92vh;
    border-radius:16px 16px 0 0;
  }
  .maint-wizard-mbox{
    width:100%;
    max-width:none;
  }
  .maint-wizard-stepper{
    grid-template-columns:1fr;
    padding:12px 14px;
  }
  .maint-wizard-shell{
    grid-template-columns:1fr;
  }
  .maint-wizard-main{
    border-right:none;
    border-bottom:1px solid rgba(59,72,90,.75);
    padding:14px;
  }
  .maint-wizard-side{
    padding:14px;
  }
  .maint-wizard-grid.cols-2,
  .maint-rule-grid,
  .maint-trigger-grid,
  .maint-v2-form-grid,
  .maint-v2-rule-strip,
  .maint-v2-rule-grid,
  .maint-v2-content-grid,
  .maint-v2-side-grid,
  .maint-v2-pickers,
  .maint-v2-item-fields{
    grid-template-columns:1fr;
  }
  .maint-task-builder{
    grid-template-columns:1fr;
  }
  .maint-col-span-2,
  .maint-v2-form-grid,
  .maint-v2-span-2{
    grid-column:auto;
  }
  .maint-plan-grid,
  .maint-plan-main-grid,
  .maint-plan-definition-grid,
  .maint-plan-metrics-grid,
  .maint-dual-list,
  .maint-plan-stack,
  .maint-plan-summary,
  .maint-selected-fields,
  .maint-inline-fields{
    grid-template-columns:1fr;
  }
  .maint-span-2{
    grid-column:auto;
  }
  .maint-plan-card{padding:12px}
  .maint-wizard-card,
  .maint-v2-card{padding:14px}
  .maint-wizard-foot{
    flex-direction:column;
    align-items:stretch;
  }
  .maint-foot-actions{
    justify-content:stretch;
  }
  .maint-foot-actions .btn{
    width:100%;
  }
  .maint-picker-item,
  .maint-selected-head,
  .maint-work-top,
  .maint-v2-item-top{align-items:flex-start}
}

/* MARCADOR IA */
.ot-ai-mark {
  display: inline-block;
  margin-left: 4px;
  font-size: 11px;
  color: var(--gold);
  vertical-align: baseline;
}

.ot-ai-chip {
  font-size: 11px;
  color: var(--gold);
  font-weight: 500;
  padding: 3px 8px;
  background: rgba(255, 213, 0, 0.1);
  border-radius: 10px;
}

/* Campos con valor IA tienen borde sutil */
.fi.ot-filled-ai,
.fsel.ot-filled-ai {
  border-color: rgba(255, 213, 0, 0.3);
  background: rgba(255, 213, 0, 0.04);
}

/* DESCRIPCIÓN DE FALLA (debajo de selectores) */
.ot-falla-desc-wrap {
  margin-top: 10px;
}

.ot-falla-desc-wrap #ot-falla-desc-text {
  padding: 10px 14px;
  background: rgba(192, 48, 64, 0.05);
  border: 1px solid rgba(192, 48, 64, 0.2);
  border-left: 3px solid var(--crimson);
  border-radius: var(--r);
  font-size: 12px;
  color: var(--soft);
  line-height: 1.5;
  font-style: italic;
}

/* TEXTAREA */
.ot-textarea {
  resize: vertical;
  min-height: 70px;
  font-family: inherit;
  line-height: 1.5;
}

/* TAREAS */
.ot-tareas-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.ot-tareas-list {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--wire);
  border-radius: var(--r);
  padding: 4px;
  margin-bottom: 8px;
  min-height: 40px;
}

.ot-tareas-list:empty::before {
  content: "Sin tareas — agrega pasos específicos abajo";
  display: block;
  padding: 12px;
  font-size: 12px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
}

.ot-tarea-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.ot-tarea-item:last-child {
  border-bottom: none;
}

/* ═══════════════════════════════════════════════════════
   MOBILE UX PACK — OTs / Fallas / Listas principales
═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .page {
    padding: 14px 12px calc(96px + env(safe-area-inset-bottom, 0px));
  }

  .sec-row {
    margin-bottom: 10px;
    gap: 8px;
  }

  .sec-title {
    font-size: 15px;
    line-height: 1.25;
  }

  .chip {
    min-height: 38px;
    padding: 8px 11px;
    font-size: 12px;
    letter-spacing: 0.7px;
  }

  .kpi-strip {
    margin-bottom: 12px;
    border-radius: 12px;
  }

  .kpi-cell {
    padding: 12px 11px;
  }

  .kpi-label {
    font-size: 12px;
    letter-spacing: 1.4px;
  }

  .kpi-num {
    font-size: 24px;
  }

  .kpi-sub {
    font-size: 12px;
  }

  #otList,
  #fallasList,
  #flotaList,
  #tecnicosList {
    display: grid;
    gap: 10px;
  }

  .ot-card,
  .falla-card {
    margin-bottom: 0;
    padding: 13px 12px;
    border-radius: 12px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .ot-card-head,
  .falla-head {
    gap: 8px;
    margin-bottom: 7px;
  }

  .ot-folio,
  .falla-id {
    font-size: 13px;
    letter-spacing: 1px;
    line-height: 1.25;
  }

  .ot-eq,
  .falla-eq {
    font-size: 12px;
    line-height: 1.3;
  }

  .ot-desc,
  .falla-desc {
    font-size: 14px;
    line-height: 1.45;
    margin-bottom: 7px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  .ot-foot,
  .falla-meta {
    gap: 6px;
  }

  .ot-date,
  .falla-by {
    font-size: 12px;
    margin-left: 0;
    width: 100%;
  }

  .spill {
    font-size: 12px !important;
    padding: 4px 8px !important;
  }

  .falla-actions .btn,
  .ot-card .btn {
    min-height: 38px;
  }
}

/* ═══════════════════════════════════════════════════════
   PÁGINA VALIDACIONES (B2) — Pulido desktop + mobile
═══════════════════════════════════════════════════════ */

.sb-badge.crimson {
  background: var(--crimson);
  color: white;
}

#page-validaciones {
  max-width: 1200px;
  margin: 0 auto;
  padding-bottom: 120px; /* espacio para botones sticky */
}

/* ─── Filtros ─── */
.val-filtros {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin-bottom: 24px;
  padding-bottom: 4px;
  scrollbar-width: none;
  flex-wrap: wrap;
}

.val-filtros::-webkit-scrollbar { display: none; }

.val-chip {
  flex-shrink: 0;
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--wire);
  border-radius: 20px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  transition: all 0.15s;
}

.val-chip:hover {
  color: var(--soft);
  border-color: var(--soft);
}

.val-chip.active {
  background: rgba(255, 213, 0, 0.12);
  border-color: var(--gold);
  color: var(--gold);
}

.val-chip-count {
  font-size: 10px;
  padding: 1px 7px;
  background: rgba(255,255,255,0.08);
  border-radius: 8px;
  font-weight: 700;
}

.val-chip.active .val-chip-count {
  background: rgba(255, 213, 0, 0.2);
  color: var(--gold);
}

/* ─── Badges de prioridad ─── */
.val-prio-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  white-space: nowrap;
}

.val-prio-critica {
  background: rgba(233, 69, 96, 0.15);
  color: var(--crimson);
  border: 1px solid rgba(233, 69, 96, 0.35);
}

.val-prio-alta {
  background: rgba(232, 131, 49, 0.12);
  color: #F5C0A0;
  border: 1px solid rgba(232, 131, 49, 0.3);
}

.val-prio-media {
  background: rgba(255, 213, 0, 0.1);
  color: var(--gold);
  border: 1px solid rgba(255, 213, 0, 0.3);
}

.val-prio-baja {
  background: rgba(97, 196, 89, 0.1);
  color: var(--jade);
  border: 1px solid rgba(97, 196, 89, 0.3);
}

/* ─── Grid de cards ─── */
#val-lista {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 900px) {
  #val-lista {
    grid-template-columns: 1fr 1fr;
  }
}

.val-card {
  background: var(--steel);
  border: 1px solid var(--wire);
  border-radius: var(--r2);
  padding: 18px;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  flex-direction: column;
}

.val-card:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--gold);
  transform: translateY(-1px);
}

.val-card.por_validar { border-left: 3px solid var(--gold); }
.val-card.rechazada { border-left: 3px solid var(--crimson); }
.val-card.completado { border-left: 3px solid var(--jade); }

.val-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.val-card-title-block {
  flex: 1;
  min-width: 0;
}

.val-card-folio {
  font-size: 15px;
  color: var(--bright);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 2px;
}

.val-card-equipo {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.5px;
}

.val-card-badges {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-end;
}

.val-card-desc {
  font-size: 13px;
  color: var(--soft);
  margin-bottom: 14px;
  line-height: 1.4;
  flex: 1;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.val-card-meta {
  display: flex;
  gap: 14px;
  font-size: 11px;
  color: var(--muted);
  flex-wrap: wrap;
  padding-top: 10px;
  border-top: 1px solid var(--wire);
}

.val-card-meta span {
  display: flex;
  align-items: center;
  gap: 4px;
}

.val-tiempo-pill {
  padding: 3px 8px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.val-vacio {
  text-align: center;
  padding: 80px 20px;
  color: var(--muted);
  grid-column: 1 / -1;
}

.val-vacio-icon {
  font-size: 56px;
  margin-bottom: 16px;
  opacity: 0.3;
}

.val-table-wrap {
  grid-column: 1 / -1;
  width: 100%;
  overflow-x: auto;
  background: var(--steel);
  border: 1px solid var(--wire);
  border-radius: var(--r2);
}

.val-table {
  width: 100%;
  min-width: 860px;
  border-collapse: collapse;
}

.val-table thead {
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--wire);
}

.val-table th {
  padding: 12px 14px;
  text-align: left;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.6px;
  color: var(--muted);
  text-transform: uppercase;
  white-space: nowrap;
}

.val-table tbody tr {
  border-bottom: 1px solid rgba(28,35,51,.8);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}

.val-table tbody tr:last-child {
  border-bottom: none;
}

.val-table tbody tr:hover {
  background: rgba(255,255,255,0.03);
}

.val-table td {
  padding: 14px;
  font-size: 13px;
  color: var(--soft);
  vertical-align: top;
}

.val-td-main {
  font-weight: 700;
  color: var(--bright);
}

.val-td-sub {
  margin-top: 3px;
  font-size: 11px;
  color: var(--muted);
}

.val-td-desc {
  max-width: 360px;
  color: var(--soft);
  line-height: 1.4;
}

.val-table-prio {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
}

/* ═══ Vista detalle ═══ */
#val-vista-detalle {
  max-width: 1200px;
  margin: 0 auto;
  padding-bottom: 120px;
}

.val-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--wire);
  gap: 20px;
}

.val-back-btn {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--wire);
  color: var(--soft);
  font-size: 13px;
  cursor: pointer;
  font-weight: 500;
  padding: 9px 16px;
  border-radius: 8px;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  gap: 6px;
}

.val-back-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(255, 213, 0, 0.08);
}

.val-detail-title {
  text-align: center;
  flex: 1;
}

.val-detail-eyebrow {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.val-detail-folio {
  font-size: 20px;
  color: var(--bright);
  font-weight: 700;
  line-height: 1.2;
}

.val-detail-equipo {
  display: block;
  font-size: 12px;
  color: var(--muted);
  font-weight: 500;
  letter-spacing: 0.5px;
  margin-top: 4px;
}

/* ─── Banner ─── */
.val-banner {
  background: rgba(255, 213, 0, 0.08);
  border: 1px solid rgba(255, 213, 0, 0.25);
  border-radius: var(--r2);
  padding: 18px 22px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 18px;
}

.val-banner.completado {
  background: rgba(97, 196, 89, 0.08);
  border-color: rgba(97, 196, 89, 0.25);
}

.val-banner.rechazada {
  background: rgba(233, 69, 96, 0.08);
  border-color: rgba(233, 69, 96, 0.25);
}

.val-banner-icon {
  font-size: 32px;
  line-height: 1;
  flex-shrink: 0;
}

.val-banner-text { flex: 1; }

.val-banner-title {
  font-size: 16px;
  color: var(--bright);
  font-weight: 600;
  margin-bottom: 3px;
}

.val-banner-sub {
  font-size: 12px;
  color: var(--soft);
}

/* ─── Semáforo ─── */
.val-semaforo {
  border-radius: var(--r2);
  padding: 18px 22px;
  margin-bottom: 6px;
  border: 1px solid;
}

.val-semaforo-ok {
  background: rgba(97, 196, 89, 0.06);
  border-color: rgba(97, 196, 89, 0.25);
}

.val-semaforo-info {
  background: rgba(255, 213, 0, 0.06);
  border-color: rgba(255, 213, 0, 0.25);
}

.val-semaforo-warning {
  background: rgba(232, 131, 49, 0.08);
  border-color: rgba(232, 131, 49, 0.35);
}

.val-semaforo-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}

.val-semaforo-icon {
  font-size: 28px;
  line-height: 1;
}

.val-semaforo-ok .val-semaforo-icon { color: var(--jade); }
.val-semaforo-info .val-semaforo-icon { color: var(--gold); }
.val-semaforo-warning .val-semaforo-icon { color: #F5C0A0; }

.val-semaforo-titulo {
  font-size: 16px;
  color: var(--bright);
  font-weight: 700;
  margin-bottom: 2px;
}

.val-semaforo-sub {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.5px;
}

.val-semaforo-grupo {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 8px;
}

.val-semaforo-item {
  font-size: 12px;
  padding: 5px 0;
  display: flex;
  align-items: center;
  gap: 6px;
}

.val-semaforo-item.ok { color: var(--jade); }
.val-semaforo-item.warn { color: #F5C0A0; }

/* ─── Body: grid 2 cols en desktop ─── */
.val-detail-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-bottom: 24px;
}

@media (min-width: 900px) {
  .val-detail-body {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
  .val-section.full-width,
  .val-semaforo.full-width {
    grid-column: 1 / -1;
  }
}

.val-section {
  background: var(--steel);
  border: 1px solid var(--wire);
  border-radius: var(--r2);
  padding: 18px;
}

.val-section-label {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 12px;
}

/* ─── Info del equipo ─── */
.val-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--wire);
}

.val-info-label {
  font-size: 9px;
  color: var(--muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 4px;
}

.val-info-value {
  font-size: 12px;
  color: var(--soft);
  font-weight: 500;
}

/* ─── Stats grid ─── */
.val-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}

.val-stat {
  padding: 16px 12px;
  background: rgba(255,255,255,0.03);
  border-radius: 10px;
  text-align: center;
}

.val-stat-label {
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 6px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-weight: 600;
}

.val-stat-value {
  font-size: 22px;
  color: var(--bright);
  font-weight: 700;
  font-family: 'Barlow Condensed', monospace;
  letter-spacing: 1px;
  line-height: 1;
}

.val-stat-sub {
  font-size: 10px;
  color: var(--muted);
  margin-top: 6px;
}

.val-stat-sub.ok { color: var(--jade); }
.val-stat-sub.warn { color: #F5C0A0; }

/* ─── Fallas ─── */
.val-falla-row {
  padding: 12px 0;
  border-bottom: 1px solid var(--wire);
}

.val-falla-row:last-child { border-bottom: none; padding-bottom: 0; }
.val-falla-row:first-child { padding-top: 0; }

.val-falla-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}

.val-falla-folio {
  font-size: 13px;
  color: var(--bright);
  font-weight: 600;
}

.val-falla-tiempo {
  font-size: 11px;
  color: var(--jade);
  font-family: 'Courier New', monospace;
}

.val-falla-desc {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.4;
  margin-bottom: 4px;
}

.val-falla-meta {
  font-size: 11px;
  color: var(--muted);
}

.val-falla-estado {
  color: var(--muted);
}

.val-falla-estado.ok {
  color: var(--jade);
  font-weight: 600;
}

/* ─── Notas ─── */
.val-notas-tecnico {
  padding: 14px;
  background: rgba(255, 213, 0, 0.04);
  border-left: 3px solid var(--gold);
  border-radius: 8px;
  font-size: 13px;
  color: var(--soft);
  line-height: 1.6;
  white-space: pre-wrap;
  word-wrap: break-word;
}

.val-notas-tecnico.notas-cortas {
  font-size: 13px;
  padding: 12px;
}

.val-notas-meta {
  font-size: 10px;
  color: var(--muted);
  margin-top: 6px;
  text-align: right;
  font-style: italic;
}

/* ─── Pausas ─── */
.val-pausa-row {
  padding: 10px 12px;
  background: rgba(232, 131, 49, 0.05);
  border-left: 2px solid #E88331;
  border-radius: 6px;
  margin-bottom: 6px;
  font-size: 12px;
}

.val-pausa-row:last-child { margin-bottom: 0; }

.val-pausa-row strong { color: #F5C0A0; }

.val-pausa-meta {
  font-size: 10px;
  color: var(--muted);
  margin-top: 4px;
}

/* ─── Acciones del jefe — al final del contenido, NO sticky ─── */
.val-actions {
  display: flex;
  gap: 10px;
  padding: 20px 0 40px 0;
  justify-content: flex-end;
  flex-wrap: wrap;
  border-top: 1px solid var(--wire);
  margin-top: 24px;
}

@media (max-width: 768px) {
  .val-actions {
    justify-content: stretch;
  }
  .val-action-btn {
    flex: 1;
    min-width: 0 !important;
  }
}

.val-action-btn {
  padding: 14px 24px;
  border-radius: 10px;
  border: none;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.15s;
  min-width: 180px;
}

.val-action-btn:hover {
  transform: translateY(-1px);
}

.val-btn-reject {
  background: rgba(233, 69, 96, 0.1);
  border: 1px solid var(--crimson);
  color: var(--crimson);
}

.val-btn-reject:hover { background: rgba(233, 69, 96, 0.2); }

.val-btn-observe {
  background: rgba(255, 213, 0, 0.1);
  border: 1px solid var(--gold);
  color: var(--gold);
}

.val-btn-observe:hover { background: rgba(255, 213, 0, 0.2); }

.val-btn-approve {
  background: var(--jade);
  color: #173404;
}

.val-btn-approve:hover { background: #7dd570; }

/* ─── Historial de pausas con scroll/collapse ─── */
.val-pausas-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 4px 0 12px 0;
  user-select: none;
}

.val-pausas-toggle {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--soft);
  font-size: 11px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
}

.val-pausas-toggle:hover {
  border-color: var(--gold);
  color: var(--gold);
}

.val-pausas-toggle-icon {
  font-size: 10px;
}

.val-pausas-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 320px;
  overflow-y: auto;
  padding-right: 6px;
  scroll-behavior: smooth;
}

/* Scrollbar personalizado desktop */
.val-pausas-list::-webkit-scrollbar {
  width: 6px;
}

.val-pausas-list::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.03);
  border-radius: 3px;
}

.val-pausas-list::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 3px;
}

.val-pausas-list::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}

/* Collapsed state: mobile colapsa full, desktop mantiene scroll limitado */
.val-pausas-list.collapsed {
  max-height: 0;
  overflow: hidden;
  padding-right: 0;
}

/* Mobile: por default colapsado cuando hay muchas */
@media (max-width: 768px) {
  .val-pausas-list {
    max-height: none; /* en mobile, si lo abres, se ve todo */
  }
}

/* ═══════════════════════════════════════════════════════
   HISTÓRICO TÉCNICO (Pantalla 4)
═══════════════════════════════════════════════════════ */

.tec-hist-filtros {
  display: flex;
  overflow-x: auto;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--wire);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.tec-hist-filtros::-webkit-scrollbar {
  display: none;
}

.tec-hist-filtro-btn {
  flex-shrink: 0;
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--wire);
  border-radius: 20px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
}

.tec-hist-filtro-btn:active {
  transform: scale(0.97);
}

.tec-hist-filtro-btn.active {
  background: rgba(255, 213, 0, 0.12);
  border-color: var(--gold);
  color: var(--gold);
}

.tec-hist-filtro-count {
  font-size: 10px;
  padding: 1px 7px;
  background: rgba(255,255,255,0.08);
  border-radius: 8px;
  font-weight: 700;
}

.tec-hist-filtro-btn.active .tec-hist-filtro-count {
  background: rgba(255, 213, 0, 0.2);
  color: var(--gold);
}

.tec-hist-lista {
  padding: 14px 16px;
  padding-bottom: 80px;
}

.tec-hist-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--wire);
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: background 0.15s;
}

.tec-hist-card:active {
  background: rgba(255,255,255,0.05);
}

.tec-hist-card.estado-completado {
  border-left: 3px solid var(--jade);
}

.tec-hist-card.estado-por_validar {
  border-left: 3px solid var(--gold);
}

.tec-hist-card.estado-rechazada {
  border-left: 3px solid #E88331;
  background: rgba(232, 131, 49, 0.04);
}

/* ═══════════════════════════════════════════════════════
   OPERADOR HUB
═══════════════════════════════════════════════════════ */
.op-hub-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.op-hub-eyebrow{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:2px;color:var(--gold);text-transform:uppercase}
.op-hub-title-main{font-size:20px;font-weight:700;color:var(--white)}
.op-hub-grid{display:grid;gap:10px;grid-template-columns:1fr}
.op-hub-card{position:relative;overflow:hidden;background:
linear-gradient(180deg,rgba(21,34,54,.98),rgba(13,24,40,.98));
border:1px solid rgba(120,147,177,.18);border-radius:var(--r2);padding:12px;
box-shadow:inset 0 1px 0 rgba(255,255,255,.03),0 10px 24px rgba(0,0,0,.18)}
.op-hub-card::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,rgba(255,213,0,.95),rgba(255,213,0,.08))}
.op-hub-card::after{content:"";position:absolute;top:10px;right:-28px;width:88px;height:18px;transform:rotate(35deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);pointer-events:none}
.op-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.op-hub-title{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;letter-spacing:.5px;color:var(--bright);margin-bottom:8px;text-transform:uppercase}
.op-hub-subtitle{font-size:11px;color:var(--muted);margin-bottom:6px}
.op-hub-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}
.op-hub-kpi-label{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.op-hub-kpi-num{font-size:21px;font-weight:700;color:var(--gold)}
.op-hub-line{font-size:12px;color:var(--soft);margin-bottom:6px}
.op-hub-chip-row{display:flex;flex-wrap:wrap;gap:6px}
.op-hub-chip{background:linear-gradient(180deg,rgba(255,213,0,.12),rgba(255,213,0,.05));border:1px solid rgba(255,213,0,.24);border-radius:999px;padding:4px 9px;font-size:11px;color:var(--gold);box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.op-hub-empty{font-size:12px;color:var(--muted);font-style:italic}
.op-hub-actions{display:flex;flex-wrap:wrap;gap:8px}
.op-hub-actions .btn{flex:1;min-width:130px;min-height:42px;font-family:'Barlow Condensed',sans-serif;font-size:15px;letter-spacing:.5px;text-transform:uppercase}
.op-profile-head{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:start;margin-bottom:8px}
.op-profile-head--hero{margin-top:12px}
.op-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:7px}
.op-avatar{width:88px;height:88px;border-radius:999px;object-fit:cover;border:2px solid rgba(255,213,0,.48);background:rgba(255,255,255,.04);box-shadow:0 0 0 4px rgba(255,213,0,.06),0 14px 24px rgba(0,0,0,.22)}
.op-avatar-empty{display:flex;align-items:center;justify-content:center;font-size:30px;color:var(--muted)}
.op-avatar-btn{font-size:11px;padding:6px 8px}
.op-avatar-edit{position:absolute;top:-4px;right:-2px;z-index:2;width:32px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#1b2740,#101827);border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 24px rgba(0,0,0,.24);color:#f4f7fb;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.op-avatar-edit:hover{transform:translateY(-1px);border-color:rgba(255,213,0,.38);box-shadow:0 14px 28px rgba(0,0,0,.28)}
.op-avatar-edit svg{width:14px;height:14px;fill:currentColor}
.op-avatar-edit input{display:none}
.op-profile-progress-head{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--soft)}
.op-profile-progress-bar{height:10px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;margin-top:6px}
.op-profile-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#ffe88a)}
.op-profile-checks{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.op-profile-check{font-size:12px;padding:6px 8px;border-radius:8px;border:1px solid var(--wire);color:var(--muted)}
.op-profile-check.ok{color:var(--jade);border-color:rgba(79,212,154,.35);background:rgba(79,212,154,.07)}
.op-profile-check.pending{color:var(--muted)}
.op-doc-card{margin-top:10px}
.op-doc-form{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:8px}
.op-doc-drop{margin-top:6px}
.op-doc-preview{margin-top:8px}
.op-doc-preview img{width:100%;max-height:210px;object-fit:cover;border-radius:10px;border:1px solid var(--wire)}
.op-doc-pdf-preview{border:1px dashed rgba(255,213,0,.3);border-radius:10px;padding:14px;color:var(--gold);font-size:13px}
.op-doc-progress-wrap{display:flex;align-items:center;gap:8px;margin-top:8px}
.op-doc-progress-bar{height:8px;flex:1;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.op-doc-progress-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),#ffe88a);transition:width .18s ease}
.op-doc-progress-label{font-size:11px;color:var(--muted);min-width:34px;text-align:right}
.op-doc-error{min-height:16px;color:var(--crimson);font-size:12px;margin-top:6px}
.op-doc-list{display:grid;gap:7px;margin-top:10px}
.op-doc-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px;border:1px solid var(--wire);border-radius:9px;background:rgba(255,255,255,.02)}
.op-doc-item.missing{border-style:dashed;background:rgba(255,255,255,.01)}
.op-doc-main{min-width:0}
.op-doc-title{font-size:12px;font-weight:700;color:var(--bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.op-doc-meta{font-size:11px;color:var(--muted)}
.op-doc-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.op-doc-badge{padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.2px}
.op-doc-badge.ok{background:rgba(79,212,154,.12);color:var(--jade);border:1px solid rgba(79,212,154,.35)}
.op-doc-badge.warn{background:rgba(255,213,0,.11);color:var(--gold);border:1px solid rgba(255,213,0,.35)}
.op-doc-badge.late{background:rgba(192,48,64,.12);color:var(--crimson);border:1px solid rgba(192,48,64,.35)}
.op-home-hero{background:radial-gradient(circle at top right, rgba(255,213,0,.13), transparent 36%),linear-gradient(160deg, rgba(6,17,30,.95), rgba(18,32,52,.96));border-color:rgba(255,213,0,.18)}
.op-home-header{background:
radial-gradient(circle at top right, rgba(255,213,0,.16), transparent 28%),
linear-gradient(135deg,rgba(20,31,48,.98),rgba(9,17,29,.99))}
.op-home-header::before{height:3px;background:linear-gradient(90deg,#ffd500,rgba(255,213,0,.18))}
.op-home-header::after{content:"";position:absolute;left:14px;right:14px;bottom:10px;height:6px;border-radius:999px;background:repeating-linear-gradient(135deg,rgba(255,213,0,.22) 0 10px,transparent 10px 20px);opacity:.45}
.op-home-header-main{display:grid;gap:12px}
.op-home-header--pro{padding:18px}
.op-home-header--pro .op-home-header-main{gap:16px}
.op-home-identity-top{display:grid;grid-template-columns:110px 1fr;gap:16px;align-items:center}
.op-identity-badge{position:relative;width:96px;height:96px}
.op-identity-badge::after{content:"";position:absolute;inset:-8px;border-radius:999px;border:1px solid rgba(255,213,0,.12);pointer-events:none}
.op-identity-dot{position:absolute;right:4px;bottom:6px;width:14px;height:14px;border-radius:999px;background:#2adf9b;border:2px solid #101722;box-shadow:0 0 0 3px rgba(42,223,155,.14)}
.op-avatar--xl{width:96px;height:96px;font-size:36px;font-weight:800}
.op-home-profile{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:center}
.op-home-identity{min-width:0}
.op-home-greet{font-size:14px;color:var(--soft)}
.op-home-name{font-family:'Barlow Condensed',sans-serif;font-size:48px;line-height:.88;font-weight:800;letter-spacing:.6px;color:var(--white);text-transform:uppercase;max-width:440px}
.op-home-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}
.op-rank-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:rgba(255,213,0,.12);border:1px solid rgba(255,213,0,.32);font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--gold)}
.op-active-line{display:inline-flex;align-items:center;gap:6px;color:#46e2b0;font-weight:700;font-size:14px}
.op-active-line::before{content:"";width:8px;height:8px;border-radius:999px;background:#46e2b0;box-shadow:0 0 12px rgba(70,226,176,.3)}
.op-home-unit{margin-top:12px;font-size:13px;color:var(--muted)}
.op-home-hero-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.op-home-hero-copy{font-size:13px;color:var(--soft);margin-top:6px;max-width:520px;line-height:1.45}
.op-home-aspire{margin-top:6px;font-family:'Barlow Condensed',sans-serif;font-size:15px;letter-spacing:.4px;color:#ffe37a;text-transform:uppercase}
.op-home-status-wrap{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}
.op-status-pill{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid var(--wire);background:rgba(255,255,255,.03);white-space:nowrap}
.op-status-pill.ok{color:var(--jade);border-color:rgba(79,212,154,.35)}
.op-status-pill.warn{color:var(--gold);border-color:rgba(255,213,0,.35)}
.op-status-pill.alert{color:var(--ember);border-color:rgba(255,149,0,.35)}
.op-hero-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%}
.op-hero-meta-card{padding:10px;border-radius:12px;border:1px solid var(--wire);background:rgba(255,255,255,.025)}
.op-hero-meta-value{font-size:14px;color:var(--bright);font-weight:700;line-height:1.35;margin-top:4px}
.op-hero-mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.op-hero-mini-card{position:relative;padding:16px 14px 12px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(8,12,18,.92),rgba(10,14,22,.98))}
.op-hero-mini-card{box-shadow:0 10px 20px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.03)}
.op-hero-mini-card.tone-gold{border-color:rgba(255,213,0,.24)}
.op-hero-mini-card.tone-ember{border-color:rgba(255,120,40,.22)}
.op-hero-mini-card.tone-jade{border-color:rgba(79,212,154,.22)}
.op-mini-overline{font-size:11px;letter-spacing:1.6px;color:var(--muted);text-transform:uppercase}
.op-hero-mini-value{font-family:'Barlow Condensed',sans-serif;font-size:34px;line-height:.95;font-weight:800;color:var(--white);margin-top:10px}
.op-hero-mini-sub{font-size:12px;color:var(--soft);margin-top:8px}
.op-hub-actions--hero{margin-top:8px}
.op-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:10px}
.op-summary-grid--compact{margin-top:2px}
.op-summary-card{position:relative;overflow:hidden;padding:12px;border-radius:14px;border:1px solid var(--wire);background:
linear-gradient(180deg,rgba(19,33,53,.98),rgba(11,20,35,.98))}
.op-summary-card::before{content:"";position:absolute;left:12px;top:0;width:44px;height:3px;border-radius:0 0 4px 4px;background:rgba(255,213,0,.9)}
.op-summary-card::after{content:"";position:absolute;inset:auto 10px 10px auto;width:42px;height:42px;border:1px solid rgba(255,255,255,.04);border-radius:10px;opacity:.5}
.op-summary-card.tone-gold{border-color:rgba(255,213,0,.25)}
.op-summary-card.tone-crimson{border-color:rgba(192,48,64,.28)}
.op-summary-card.tone-jade{border-color:rgba(79,212,154,.28)}
.op-summary-card.tone-ice{border-color:rgba(72,176,232,.28)}
.op-summary-value{font-size:24px;font-weight:800;color:var(--bright);margin:6px 0 4px}
.op-summary-sub{font-size:12px;color:var(--muted);line-height:1.4}
.op-home-two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.op-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
.op-mini-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:700;color:#1b1400;border:1px solid rgba(255,213,0,.45);background:linear-gradient(180deg,#ffe37a,#ffcf00);box-shadow:inset 0 1px 0 rgba(255,255,255,.45)}
.op-inline-progress{display:flex;align-items:center;gap:10px;margin-top:8px}
.op-inline-progress-bar{height:8px;flex:1;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.op-inline-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#ffe88a)}
.op-inline-progress-text{font-size:12px;color:var(--bright);font-weight:700;white-space:nowrap}
.op-inline-note{margin-top:10px;font-size:12px;color:var(--soft);line-height:1.45}
.op-course-list{display:grid;gap:9px}
.op-course-row{padding:10px;border-radius:10px;border:1px solid rgba(120,147,177,.16);background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01))}
.op-course-row.is-muted{opacity:.72}
.op-course-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.op-course-title{font-size:12px;font-weight:700;color:var(--bright)}
.op-course-hours{font-size:11px;color:var(--gold);font-weight:700;white-space:nowrap}
.op-course-bar{height:8px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,.2)}
.op-course-bar span{display:block;height:100%;background:linear-gradient(90deg,#ffd500,#ffea8d 60%,#fff1ba)}
.op-course-foot{font-size:11px;color:var(--muted);margin-top:5px}
.op-spotlight-card{padding:11px;border-radius:12px;border:1px solid rgba(255,149,0,.2);background:linear-gradient(180deg,rgba(255,149,0,.08),rgba(255,149,0,.03))}
.op-spotlight-title{font-size:14px;color:var(--bright);font-weight:700}
.op-spotlight-sub{font-size:12px;color:var(--soft);line-height:1.45;margin-top:5px}
.op-preview-card{opacity:.96;border-style:dashed}
.op-preview-card .op-inline-note{position:relative;padding-left:14px}
.op-preview-card .op-inline-note::before{content:"";position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:999px;background:var(--gold);box-shadow:0 0 10px rgba(255,213,0,.25)}
.op-preview-tag{display:inline-flex;align-items:center;justify-content:center;padding:4px 9px;border-radius:999px;font-size:10px;font-weight:700;color:var(--gold);border:1px solid rgba(255,213,0,.24);background:rgba(255,213,0,.07)}
.op-showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.op-showcase-grid--top{margin-top:12px}
.op-install-card{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:12px;border-color:rgba(255,213,0,.28);background:linear-gradient(135deg,rgba(255,213,0,.12),rgba(16,21,30,.98) 42%)}
.op-install-copy{min-width:0}
.op-install-card .op-hub-title{margin-bottom:4px}
.op-install-actions{display:flex;gap:8px;flex-shrink:0}
.op-tier-card{margin-top:12px;padding:16px;border-color:rgba(255,213,0,.34);background:radial-gradient(circle at top right, rgba(255,213,0,.12), transparent 38%),linear-gradient(180deg,rgba(33,26,2,.94),rgba(10,11,14,.98))}
.op-tier-head{display:grid;grid-template-columns:88px 1fr auto;gap:14px;align-items:center}
.op-tier-mark{display:flex;flex-direction:column;align-items:center;justify-content:center;width:72px;height:72px;border-radius:16px;background:linear-gradient(180deg,#ffd500,#e8bb00);color:#1a1400;font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;line-height:.9}
.op-tier-mark span{font-size:42px}
.op-tier-copy .op-hub-title{margin-bottom:4px}
.op-tier-name{font-family:'Barlow Condensed',sans-serif;font-size:40px;line-height:.9;font-weight:800;color:var(--white);text-transform:uppercase}
.op-tier-progress-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:14px;font-size:13px;color:var(--soft)}
.op-tier-progress-head strong{color:var(--gold)}
.op-tier-progress{margin-top:8px;height:10px;border-radius:999px;background:rgba(255,213,0,.1);overflow:hidden}
.op-tier-progress span{display:block;height:100%;background:linear-gradient(90deg,#ffd500,#ffea8d)}
.op-tier-req-title{margin-top:14px;font-family:'Barlow Condensed',sans-serif;font-size:16px;letter-spacing:2px;color:#b8a87a;text-transform:uppercase}
.op-tier-req-list{display:grid;gap:8px;margin-top:10px}
.op-tier-req{display:grid;grid-template-columns:24px 1fr auto;gap:8px;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.op-tier-req:last-child{border-bottom:0}
.op-tier-req-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:rgba(255,255,255,.06);font-weight:800}
.op-tier-req.ok .op-tier-req-icon{background:rgba(79,212,154,.14);color:var(--jade)}
.op-tier-req.pending .op-tier-req-icon{background:rgba(255,255,255,.06);color:var(--muted)}
.op-tier-req-label{font-size:14px;color:var(--bright)}
.op-tier-req-meta{font-size:13px;font-weight:700}
.op-tier-req.ok .op-tier-req-meta{color:var(--jade)}
.op-tier-req.pending .op-tier-req-meta{color:var(--gold)}
.op-performance-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.op-performance-card{padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(9,12,18,.92),rgba(9,12,18,.98))}
.op-performance-card.tone-jade{border-color:rgba(79,212,154,.24)}
.op-performance-card.tone-amber{border-color:rgba(255,185,0,.24)}
.op-performance-card.tone-blue{border-color:rgba(74,150,255,.26)}
.op-performance-card.tone-rose{border-color:rgba(246,116,141,.2)}
.op-performance-value{font-family:'Barlow Condensed',sans-serif;font-size:46px;line-height:.9;font-weight:800;color:#fff}
.op-performance-label{margin-top:8px;font-size:14px;color:var(--soft)}
.op-performance-note{margin-top:4px;font-size:13px;color:#4fe49f}
.op-commit-list{display:grid;gap:10px}
.op-commit-card{display:grid;grid-template-columns:54px 1fr auto;gap:12px;align-items:center;padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(11,13,18,.95),rgba(12,14,20,.99))}
.op-commit-icon{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;background:rgba(255,213,0,.08);font-size:24px}
.op-commit-main{min-width:0}
.op-commit-title{font-size:15px;font-weight:700;color:#fff}
.op-commit-note{font-size:12px;color:var(--muted);margin-top:4px}
.op-commit-bar{margin-top:8px;height:5px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.op-commit-bar span{display:block;height:100%;background:linear-gradient(90deg,#ffd500,#ffea8d)}
.op-commit-card.blue .op-commit-bar span{background:linear-gradient(90deg,#5ab1ff,#7ec7ff)}
.op-commit-card.jade .op-commit-bar span{background:linear-gradient(90deg,#31d49b,#8ef0ca)}
.op-commit-badge{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,213,0,.3);font-size:12px;font-weight:700;color:var(--gold)}
.op-doc-count{font-size:13px;font-weight:700;color:#43e2ab}
.op-doc-status-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;border:1px solid rgba(255,255,255,.06);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,rgba(8,12,18,.88),rgba(8,12,18,.96))}
.op-doc-status-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:132px;padding:14px;border-right:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);text-align:center}
.op-doc-status-card:nth-child(2n){border-right:0}
.op-doc-status-card:nth-last-child(-n+2){border-bottom:0}
.op-doc-status-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:rgba(255,255,255,.05);font-size:20px;font-weight:800;color:var(--muted)}
.op-doc-status-card.ok .op-doc-status-icon{background:rgba(79,212,154,.12);color:var(--jade)}
.op-doc-status-title{margin-top:12px;font-size:14px;color:#d9e2ee}
.op-doc-status-state{margin-top:6px;font-size:14px;font-weight:700;color:var(--jade);text-transform:uppercase}
.op-doc-status-card.pending .op-doc-status-state{color:var(--gold)}
.op-course-highlight{display:flex;flex-direction:column;gap:4px;margin-top:12px;padding:14px 16px;border-radius:18px;background:linear-gradient(180deg,#ffd500,#e8ba00);color:#161000}
.op-course-highlight strong{font-family:'Barlow Condensed',sans-serif;font-size:28px;line-height:.95;text-transform:uppercase}
.op-course-highlight span{font-size:15px}
.op-home-header--pro,.op-tier-card,.op-install-card,.op-showcase-grid>.op-hub-card{box-shadow:0 18px 36px rgba(0,0,0,.16)}
.op-notif-list{display:grid;gap:7px;margin-top:4px}
.op-notif-item{border:1px solid var(--wire);border-radius:9px;padding:9px;background:rgba(255,255,255,.02)}
.op-notif-item.unread{border-color:rgba(255,213,0,.35);background:rgba(255,213,0,.05)}
.op-notif-title{font-size:12px;font-weight:700;color:var(--bright)}
.op-notif-msg{font-size:12px;color:var(--soft);margin-top:2px}
.op-notif-date{font-size:11px;color:var(--muted);margin-top:4px}
.op-hub-switch{display:inline-flex;align-items:center;gap:6px;margin-right:10px;font-size:12px;color:var(--soft)}
.op-hub-notif{padding:8px;border-radius:8px;border:1px solid var(--wire);font-size:12px;color:var(--soft);margin-bottom:6px;display:flex;justify-content:space-between;gap:8px}
.op-hub-notif.unread{border-color:rgba(255,213,0,.35);background:rgba(255,213,0,.06)}
.op-hub-notif span{font-size:11px;color:var(--muted)}
.op-hub-filters{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:10px}
.op-hub-history-item{padding:9px;border-radius:8px;border:1px solid var(--wire);background:rgba(255,255,255,.02);margin-bottom:6px}

@media (min-width:768px){
  .op-hub-grid{grid-template-columns:1fr 1fr}
  .op-doc-form{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1024px){
  .op-hub-grid{grid-template-columns:repeat(3,1fr)}
  .op-doc-form{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:320px){
  .op-hub-card{padding:10px}
  .op-doc-actions{flex-direction:column;align-items:flex-end}
  .op-profile-checks{grid-template-columns:1fr}
}
@media (max-width:767px){
  .page{padding:12px 12px 22px}
  .topbar{padding-left:12px;padding-right:12px}
  .page-label{font-size:12px;letter-spacing:2px}
  .page-title{font-size:16px}
  .tb-btn{width:36px;height:36px}
  .op-hub-card{padding:13px 12px;border-radius:18px}
  .op-home-hero-main,.op-card-head,.op-inline-progress{flex-direction:column;align-items:flex-start}
  .op-home-status-wrap{justify-content:flex-start}
  .op-summary-grid,.op-home-two-col,.op-hero-meta,.op-preview-grid,.op-home-profile,.op-showcase-grid,.op-home-identity-top{grid-template-columns:1fr}
  .op-hub-kpi-row{grid-template-columns:1fr 1fr 1fr}
  .op-hub-title-main{font-size:18px}
  .op-profile-head{grid-template-columns:1fr;justify-items:center}
  .op-profile-progress{width:100%}
  .op-tier-head{grid-template-columns:1fr}
  .op-home-header--pro{padding:14px 14px 12px;border-radius:22px}
  .op-identity-badge{width:78px;height:78px}
  .op-avatar--xl{width:78px;height:78px;font-size:28px}
  .op-avatar-edit{width:28px;height:28px;top:-2px;right:-2px}
  .op-avatar-edit svg{width:12px;height:12px}
  .op-home-greet{font-size:13px;color:#d6dee7}
  .op-home-name{font-size:30px;max-width:none;letter-spacing:.3px}
  .op-rank-badge{font-size:15px;padding:5px 10px}
  .op-active-line{font-size:13px}
  .op-home-unit{margin-top:8px;font-size:12px}
  .op-home-aspire{font-size:12px;letter-spacing:.7px;color:#ffe58b}
  .op-hero-mini-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:9px;
    padding-top:2px;
    margin-top:2px;
  }
  .op-hero-mini-card{
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    padding:12px 12px 11px;
    border-radius:16px;
    min-height:92px;
    background:linear-gradient(180deg,rgba(9,13,19,.98),rgba(13,18,28,.98));
  }
  .op-hero-mini-card:first-child{
    grid-column:1 / -1;
    min-height:88px;
    padding:12px 13px 10px;
  }
  .op-hero-mini-card:first-child .op-hero-mini-value{
    font-size:22px;
    line-height:.95;
    margin-top:8px;
  }
  .op-hero-mini-card:not(:first-child) .op-hero-mini-value{
    font-size:28px;
    line-height:.95;
    margin-top:8px;
  }
  .op-hero-mini-sub{font-size:11px;margin-top:4px;line-height:1.25}
  .op-tier-card{padding:15px 13px;border-radius:20px}
  .op-tier-mark{width:64px;height:64px;border-radius:14px;font-size:16px}
  .op-tier-mark span{font-size:34px}
  .op-tier-name{font-size:30px;letter-spacing:.3px}
  .op-tier-progress-head{font-size:12px;align-items:flex-start;flex-direction:column}
  .op-tier-req{
    grid-template-columns:22px 1fr;
    gap:8px;
    padding:10px 0;
  }
  .op-tier-req-meta{grid-column:2;font-size:12px}
  .op-showcase-grid{gap:10px;margin-top:10px}
  .op-showcase-grid--top{margin-top:10px}
  .op-card-head{gap:6px;margin-bottom:10px}
  .op-card-head .op-hub-title{margin-bottom:2px}
  .op-card-head .op-hub-subtitle{font-size:11px;color:#8ea0b3}
  .op-performance-grid{gap:9px;grid-template-columns:repeat(2,minmax(0,1fr))}
  .op-performance-card{
    padding:13px 12px;
    border-radius:16px;
    min-height:138px;
    background:linear-gradient(180deg,rgba(9,12,18,.98),rgba(12,16,24,.98));
  }
  .op-performance-value{font-size:38px}
  .op-performance-label{font-size:13px;line-height:1.25}
  .op-performance-note{font-size:12px;line-height:1.3}
  .op-commit-card{grid-template-columns:44px 1fr}
  .op-commit-card{padding:11px 10px;border-radius:16px}
  .op-commit-icon{width:40px;height:40px;border-radius:12px;font-size:21px}
  .op-commit-title{font-size:14px}
  .op-commit-note{font-size:11px}
  .op-doc-status-grid{border-radius:16px}
  .op-doc-status-card{min-height:108px;padding:12px}
  .op-doc-status-title,.op-doc-status-state{font-size:12px}
  .op-doc-status-icon{width:38px;height:38px;font-size:18px}
  .op-course-row{padding:10px 9px;border-radius:14px}
  .op-course-head{align-items:flex-start;flex-direction:column;gap:4px}
  .op-course-hours{font-size:12px}
  .op-course-highlight{
    padding:14px 14px 13px;
    border-radius:18px;
    box-shadow:0 12px 22px rgba(255,213,0,.14);
  }
  .op-course-highlight strong{font-size:22px}
  .op-course-highlight span{font-size:13px}
  .op-install-card{padding:14px 13px;border-radius:18px}
  .op-block-actions{background:linear-gradient(180deg,rgba(17,25,39,.98),rgba(10,16,25,.98))}
  .op-block-fallas{background:linear-gradient(180deg,rgba(20,23,30,.98),rgba(12,16,23,.98))}
  .op-hub-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .op-hub-actions .btn{
    min-height:46px;
    font-size:14px;
    border-radius:14px;
    justify-content:center;
    box-shadow:0 10px 18px rgba(0,0,0,.14);
  }
  .op-hub-actions .btn:nth-child(-n+2){grid-column:1 / -1}
  .op-spotlight-card{padding:13px 12px;border-radius:16px}
  .op-preview-tag,.op-doc-count{font-size:11px}
  .op-block-tier .op-preview-tag,
  .op-block-performance .op-preview-tag,
  .op-block-commitments .op-preview-tag,
  .op-block-courses .op-preview-tag{opacity:.78}
  .op-block-actions .op-card-head .op-hub-subtitle,
  .op-block-fallas .op-card-head .op-hub-subtitle,
  .op-block-docs .op-card-head .op-hub-subtitle{display:none}
  .op-block-tier .op-hub-subtitle{line-height:1.35}
  .op-block-docs .op-card-head,
  .op-block-courses .op-card-head,
  .op-block-performance .op-card-head,
  .op-block-commitments .op-card-head{margin-bottom:12px}
  .op-commit-badge{justify-self:start}
  .op-install-card,.op-install-actions{flex-direction:column;align-items:flex-start}
  .op-install-actions{width:100%}
  .op-install-actions .btn{width:100%}
}

.tec-hist-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 6px;
}

.tec-hist-folio {
  font-size: 14px;
  color: var(--bright);
  font-weight: 600;
}

.tec-hist-badge {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 10px;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}

.tec-hist-badge.completado {
  background: rgba(97, 196, 89, 0.15);
  color: var(--jade);
}

.tec-hist-badge.por_validar {
  background: rgba(255, 213, 0, 0.15);
  color: var(--gold);
}

.tec-hist-badge.rechazada {
  background: rgba(232, 131, 49, 0.15);
  color: #F5C0A0;
}

.tec-hist-card-titulo {
  font-size: 12px;
  color: var(--soft);
  margin-bottom: 8px;
  line-height: 1.4;
}

.tec-hist-card-meta {
  display: flex;
  gap: 12px;
  font-size: 10px;
  color: var(--muted);
  flex-wrap: wrap;
}

.tec-hist-card-meta span {
  display: flex;
  align-items: center;
  gap: 3px;
}

.tec-hist-card-footer {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--wire);
  font-size: 11px;
  color: var(--muted);
}

.tec-hist-rechazo-motivo {
  margin-top: 8px;
  padding: 8px 10px;
  background: rgba(232, 131, 49, 0.08);
  border-left: 2px solid #E88331;
  border-radius: 6px;
  font-size: 11px;
  color: #F5C0A0;
  font-style: italic;
  line-height: 1.4;
}

.tec-hist-vacio {
  text-align: center;
  padding: 60px 20px;
  color: var(--muted);
  font-size: 13px;
}

.tec-hist-vacio-icon {
  font-size: 40px;
  margin-bottom: 12px;
  opacity: 0.4;
}

.tec-hist-cargar-mas {
  text-align: center;
  padding: 20px;
}

.tec-hist-cargar-btn {
  padding: 10px 20px;
  background: transparent;
  border: 1px solid var(--wire);
  border-radius: 20px;
  color: var(--soft);
  font-size: 12px;
  cursor: pointer;
}

.tec-exec-ia-disclaimer {
  font-size: 10px;
  color: var(--muted);
  font-style: italic;
  letter-spacing: 0.3px;
  display: inline-block;
  margin-top: 2px;
}

/* Mejoras visuales para el análisis IA completo */

.tec-exec-ia-empty {
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
  padding: 6px 0;
}

.tec-exec-ia-field.resumen {
  background: rgba(120, 99, 218, 0.08);
  border-radius: 6px;
  padding: 10px 12px;
  border-left: 2px solid #8E7DE8;
}

.tec-exec-ia-field.piezas {
  background: rgba(255, 213, 0, 0.04);
  border-radius: 6px;
  padding: 10px 12px;
  border-left: 2px solid var(--gold);
}

.tec-exec-ia-field.pruebas {
  background: rgba(97, 196, 89, 0.06);
  border-radius: 6px;
  padding: 10px 12px;
  border-left: 2px solid var(--jade);
}

.tec-exec-ia-field.piezas .tec-exec-ia-label {
  color: var(--gold);
}

.tec-exec-ia-field.pruebas .tec-exec-ia-label {
  color: var(--jade);
}

.tec-exec-ia-list {
  margin: 4px 0 0 0;
  padding-left: 18px;
  list-style: none;
}

.tec-exec-ia-list li {
  position: relative;
  margin-bottom: 4px;
  padding-left: 4px;
  font-size: 12px;
  color: var(--soft);
  line-height: 1.45;
}

.tec-exec-ia-list li::before {
  content: "•";
  position: absolute;
  left: -12px;
  color: var(--muted);
  font-weight: bold;
}

.tec-exec-ia-field.pruebas .tec-exec-ia-list li::before {
  content: "✓";
  color: var(--jade);
}

.tec-exec-ia-field.warning .tec-exec-ia-list li::before {
  content: "⚠";
  color: #E88331;
}

.tec-exec-ia-ol {
  margin: 6px 0 0 22px;
  padding: 0;
  list-style-type: decimal;
  color: var(--muted);
}

.tec-exec-ia-ol li {
  margin-bottom: 6px;
  padding-left: 4px;
  font-size: 12px;
  color: var(--soft);
  line-height: 1.5;
}

.tec-exec-ia-ol li::marker {
  color: var(--gold);
  font-weight: 700;
}

.tec-exec-ia-footer {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--wire);
  font-size: 11px;
  color: var(--muted);
  text-align: center;
}

.tec-exec-ia-footer strong {
  color: var(--bright);
}

/* ═══════════════════════════════════════════════════════
   MODALES CUSTOM DEL TÉCNICO
═══════════════════════════════════════════════════════ */

.tec-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 20px;
  padding-top: 40px;
  padding-bottom: 40px;
  overflow-y: auto;
  animation: tec-modal-fadein 0.15s ease-out;
}

@keyframes tec-modal-fadein {
  from { opacity: 0; }
  to { opacity: 1; }
}

.tec-modal {
  background: #111826;
  border: 1px solid #263042;
  border-radius: 14px;
  padding: 24px 20px;
  max-width: 380px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  animation: tec-modal-slideup 0.2s ease-out;
  -webkit-overflow-scrolling: touch;
}

.tec-modal::-webkit-scrollbar {
  width: 4px;
}

.tec-modal::-webkit-scrollbar-thumb {
  background: #263042;
  border-radius: 2px;
}

/* Ajuste específico para modal de pausa (contenido largo en móvil) */
.tec-modal.tec-modal-pausa {
  max-height: calc(100dvh - 24px);
  display: flex;
  flex-direction: column;
  padding: 16px 14px;
}

.tec-modal-pausa-body {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 2px;
}

.tec-modal-actions.tec-modal-actions-sticky {
  position: sticky;
  bottom: 0;
  padding-top: 10px;
  border-top: 1px solid var(--wire);
  background: #111826;
  margin-top: 10px !important;
}

@keyframes tec-modal-slideup {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.tec-modal-icon {
  font-size: 36px;
  text-align: center;
  margin-bottom: 10px;
}

.tec-modal-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--bright);
  text-align: center;
  margin-bottom: 6px;
}

.tec-modal-subtitle {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
  margin-bottom: 18px;
  line-height: 1.5;
}

.tec-modal-box {
  background: rgba(255, 213, 0, 0.06);
  border-left: 3px solid var(--gold);
  border-radius: 6px;
  padding: 12px 14px;
  margin-bottom: 16px;
  font-size: 12px;
  color: var(--soft);
  line-height: 1.5;
}

.tec-modal-box.success {
  background: rgba(97, 196, 89, 0.06);
  border-left-color: var(--jade);
}

.tec-modal-box.warning {
  background: rgba(232, 131, 49, 0.06);
  border-left-color: #E88331;
}

.tec-modal-tiempo {
  font-size: 24px;
  font-weight: 600;
  color: var(--bright);
  font-family: 'Courier New', monospace;
  letter-spacing: 2px;
  text-align: center;
  margin: 8px 0;
}

.tec-modal-actions {
  display: flex;
  gap: 10px;
}

.tec-modal-btn {
  flex: 1;
  padding: 14px;
  border-radius: 10px;
  border: none;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.tec-modal-btn.cancel {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--soft);
}

.tec-modal-btn.cancel:active {
  background: rgba(255,255,255,0.04);
}

.tec-modal-btn.primary {
  background: var(--gold);
  color: #111;
}

.tec-modal-btn.success {
  background: var(--jade);
  color: #173404;
}

.tec-modal-btn.warning {
  background: #E88331;
  color: #3D1F08;
}

.tec-modal-btn.danger {
  background: var(--crimson);
  color: #fff;
}

@media (max-width: 520px) {
  .tec-modal-overlay {
    padding: 10px;
    padding-top: max(12px, env(safe-area-inset-top));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }
  .tec-modal {
    max-height: calc(100dvh - 20px);
  }
  .tec-pausa-motivos {
    grid-template-columns: 1fr;
    gap: 6px;
  }
}

/* Estados de pausada en cards de fallas */
.tec-exec-falla-card.pausada {
  background: rgba(232, 131, 49, 0.06);
  border: 1px solid rgba(232, 131, 49, 0.25);
  border-left: 3px solid #E88331;
}

.tec-exec-falla-card.pausada .tec-exec-falla-meta {
  color: #F5C0A0;
}

/* Botón reanudar */
.tec-exec-falla-btn.reanudar {
  background: #E88331;
  color: #3D1F08;
}

/* ═══════════════════════════════════════════════════════
   PANTALLA 3 — Cierre de OT
═══════════════════════════════════════════════════════ */

.tec-cierre-banner {
  padding: 20px 16px;
  text-align: center;
  background: rgba(97, 196, 89, 0.08);
  border-bottom: 1px solid rgba(97, 196, 89, 0.2);
}

.tec-cierre-banner-icon {
  font-size: 42px;
  color: var(--jade);
  margin-bottom: 4px;
  line-height: 1;
}

.tec-cierre-banner-title {
  font-size: 17px;
  color: var(--bright);
  font-weight: 600;
  margin-bottom: 4px;
}

.tec-cierre-banner-sub {
  font-size: 12px;
  color: var(--soft);
}

.tec-cierre-section {
  padding: 16px;
  border-bottom: 1px solid var(--wire);
}

.tec-cierre-label {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 10px;
}

.tec-cierre-required {
  color: var(--crimson);
  margin-left: 3px;
}

.tec-cierre-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.tec-cierre-stat {
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border-radius: 10px;
}

.tec-cierre-stat-label {
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 4px;
  letter-spacing: 0.5px;
}

.tec-cierre-stat-value {
  font-size: 20px;
  color: var(--bright);
  font-weight: 600;
  font-family: 'Courier New', monospace;
  line-height: 1.1;
}

.tec-cierre-stat-value.tec-cierre-stat-green {
  color: var(--jade);
  font-family: var(--font-sans, inherit);
}

.tec-cierre-stat-sub {
  font-size: 10px;
  color: var(--gold);
  margin-top: 4px;
}

.tec-cierre-stat-sub.over {
  color: #F5C0A0;
}

.tec-cierre-stat-sub.under {
  color: var(--jade);
}

.tec-cierre-fallas-label {
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 6px;
  letter-spacing: 0.5px;
}

.tec-cierre-falla-item {
  padding: 10px 12px;
  background: rgba(97, 196, 89, 0.06);
  border-left: 3px solid var(--jade);
  border-radius: 6px;
  margin-bottom: 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.tec-cierre-falla-info {
  flex: 1;
  min-width: 0;
}

.tec-cierre-falla-titulo {
  font-size: 12px;
  color: var(--bright);
  font-weight: 500;
  line-height: 1.3;
}

.tec-cierre-falla-meta {
  font-size: 10px;
  color: var(--jade);
  margin-top: 3px;
}

.tec-cierre-falla-check {
  color: var(--jade);
  font-size: 14px;
  flex-shrink: 0;
}

.tec-cierre-textarea {
  width: 100%;
  min-height: 100px;
  padding: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--wire);
  border-radius: 10px;
  color: var(--bright);
  /* 16px evita auto-zoom en iOS al enfocar campos */
  font-size: 16px;
  font-family: var(--font-sans, inherit);
  line-height: 1.5;
  resize: none;
  box-sizing: border-box;
}

.tec-cierre-textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: rgba(255,255,255,0.06);
}

.tec-cierre-hint {
  font-size: 10px;
  color: var(--muted);
  margin-top: 6px;
  font-style: italic;
}

.tec-cierre-hint.ok {
  color: var(--jade);
  font-style: normal;
}

.tec-cierre-hint.warn {
  color: #F5C0A0;
  font-style: normal;
}

.tec-cierre-estado-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.tec-cierre-estado-btn {
  padding: 14px 10px;
  background: transparent;
  border: 1px solid var(--wire);
  border-radius: 12px;
  color: var(--soft);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  transition: all 0.15s;
}

.tec-cierre-estado-btn:active {
  transform: scale(0.98);
}

.tec-cierre-estado-btn.selected {
  background: rgba(97, 196, 89, 0.12);
  border-color: var(--jade);
  color: var(--jade);
}

.tec-cierre-estado-btn.selected[data-estado="seguimiento"] {
  background: rgba(232, 131, 49, 0.12);
  border-color: #E88331;
  color: #F5C0A0;
}

.tec-cierre-estado-icon {
  font-size: 20px;
  line-height: 1;
}

.tec-cierre-estado-txt {
  font-weight: 600;
  font-size: 13px;
}

.tec-cierre-estado-sub {
  font-size: 10px;
  color: var(--muted);
}

.tec-cierre-estado-btn.selected .tec-cierre-estado-sub {
  color: inherit;
  opacity: 0.8;
}

.tec-cierre-firma {
  padding: 14px 16px;
  background: rgba(255,255,255,0.02);
  border-bottom: 1px solid var(--wire);
}

.tec-cierre-firma-row {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
}

.tec-cierre-firma-row input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: var(--jade);
  flex-shrink: 0;
  cursor: pointer;
}

.tec-cierre-firma-text {
  flex: 1;
}

.tec-cierre-firma-confirm {
  font-size: 12px;
  color: var(--bright);
  line-height: 1.4;
}

.tec-cierre-firma-meta {
  font-size: 10px;
  color: var(--muted);
  margin-top: 4px;
}

.tec-cierre-enviar {
  padding: 16px;
  background: rgba(97, 196, 89, 0.05);
  border-top: 1px solid rgba(97, 196, 89, 0.15);
}

.tec-cierre-enviar-btn {
  width: 100%;
  padding: 15px;
  background: var(--jade);
  border: none;
  border-radius: 12px;
  color: #173404;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.tec-cierre-enviar-btn:disabled {
  background: rgba(97, 196, 89, 0.2);
  color: rgba(97, 196, 89, 0.5);
  cursor: not-allowed;
}

.tec-cierre-enviar-btn:not(:disabled):active {
  transform: scale(0.99);
}

.tec-cierre-enviar-hint {
  font-size: 10px;
  color: var(--muted);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}

.tec-cierre-enviar-hint.ok {
  color: var(--jade);
  font-style: normal;
}

/* ═══════════════════════════════════════════════════════
   MODAL DE PAUSA CON MOTIVO
═══════════════════════════════════════════════════════ */

.tec-pausa-motivos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px;
}

.tec-pausa-motivo-btn {
  padding: 12px 8px;
  background: transparent;
  border: 1px solid var(--wire);
  border-radius: 10px;
  color: var(--soft);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  text-align: center;
  line-height: 1.3;
  transition: all 0.15s;
}

.tec-pausa-motivo-btn:active {
  transform: scale(0.97);
}

.tec-pausa-motivo-btn.selected {
  background: rgba(232, 131, 49, 0.15);
  border-color: #E88331;
  color: #F5C0A0;
}

.tec-pausa-motivo-icon {
  display: block;
  font-size: 20px;
  margin-bottom: 4px;
  line-height: 1;
}

.tec-pausa-detalle {
  width: 100%;
  min-height: 60px;
  padding: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--wire);
  border-radius: 8px;
  color: var(--bright);
  font-size: 12px;
  font-family: inherit;
  line-height: 1.4;
  resize: vertical;
  box-sizing: border-box;
  margin-top: 8px;
}

.tec-pausa-detalle:focus {
  outline: none;
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════════
   HISTORIAL DE PAUSAS (visible en Pantalla 2 y detalle OT)
═══════════════════════════════════════════════════════ */

.tec-pausas-section {
  padding: 16px;
  border-bottom: 1px solid var(--wire);
}

.tec-pausas-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  cursor: pointer;
}

.tec-pausas-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
}

.tec-pausas-count {
  font-size: 10px;
  color: #F5C0A0;
  background: rgba(232, 131, 49, 0.12);
  padding: 3px 8px;
  border-radius: 8px;
  font-weight: 600;
}

.tec-pausa-item {
  padding: 10px 12px;
  background: rgba(232, 131, 49, 0.04);
  border-left: 3px solid #E88331;
  border-radius: 6px;
  margin-bottom: 6px;
}

.tec-pausa-item.abierta {
  background: rgba(232, 131, 49, 0.08);
  animation: tec-pausa-pulse 2s ease-in-out infinite;
}

@keyframes tec-pausa-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.75; }
}

.tec-pausa-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.tec-pausa-info {
  flex: 1;
  min-width: 0;
}

.tec-pausa-motivo {
  font-size: 12px;
  color: var(--bright);
  font-weight: 600;
  margin-bottom: 3px;
}

.tec-pausa-meta {
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 3px;
}

.tec-pausa-detalle-txt {
  font-size: 11px;
  color: var(--soft);
  font-style: italic;
  margin-top: 4px;
  padding-left: 8px;
  border-left: 2px solid var(--wire);
}

.tec-pausa-duracion {
  font-size: 11px;
  color: #F5C0A0;
  font-weight: 600;
  font-family: 'Courier New', monospace;
  flex-shrink: 0;
  text-align: right;
}

.tec-pausa-duracion.abierta {
  color: #E88331;
}

/* ═══════════════════════════════════════════════════════
   EXPANSIÓN DE CARD DE FALLA (tec)
═══════════════════════════════════════════════════════ */

.tec-exec-falla-card {
  cursor: pointer;
}

.tec-exec-falla-top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.tec-exec-falla-body {
  flex: 1;
  min-width: 0;
}

.tec-exec-falla-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

.tec-exec-falla-chevron {
  color: var(--muted);
  font-size: 11px;
  flex-shrink: 0;
  transition: transform 0.2s;
  padding: 2px 4px;
}

.tec-exec-falla-expanded {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--wire);
  cursor: default;
  animation: tec-exp-fadein 0.2s ease-out;
}

@keyframes tec-exp-fadein {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.tec-exec-falla-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}

.tec-exec-badge {
  font-size: 9px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--wire);
  border-radius: 8px;
  color: var(--soft);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  font-weight: 600;
}

.tec-exec-badge.severidad-critica {
  background: rgba(233, 69, 96, 0.12);
  border-color: rgba(233, 69, 96, 0.3);
  color: #FFB3C1;
}

.tec-exec-badge.severidad-alta {
  background: rgba(232, 131, 49, 0.12);
  border-color: rgba(232, 131, 49, 0.3);
  color: #F5C0A0;
}

.tec-exec-badge.severidad-media {
  background: rgba(255, 213, 0, 0.08);
  border-color: rgba(255, 213, 0, 0.2);
  color: var(--gold);
}

.tec-exec-badge.severidad-baja {
  background: rgba(97, 196, 89, 0.08);
  border-color: rgba(97, 196, 89, 0.25);
  color: var(--jade);
}

.tec-exec-falla-block {
  background: rgba(255,255,255,0.02);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 8px;
}

.tec-exec-falla-block.ia {
  background: rgba(120, 99, 218, 0.06);
  border-left: 3px solid #8E7DE8;
}

.tec-exec-falla-block.accion {
  background: rgba(97, 196, 89, 0.06);
  border-left: 3px solid var(--jade);
}

.tec-exec-falla-block-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 6px;
}

.tec-exec-falla-block.ia .tec-exec-falla-block-label {
  color: #A99BE8;
}

.tec-exec-falla-block.accion .tec-exec-falla-block-label {
  color: var(--jade);
}

.tec-exec-falla-block-content {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.5;
}

.tec-exec-ia-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tec-exec-ia-field {
  padding-left: 0;
}

.tec-exec-ia-field.warning {
  background: rgba(232, 131, 49, 0.06);
  border-radius: 6px;
  padding: 8px 10px;
  border-left: 2px solid #E88331;
}

.tec-exec-ia-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--bright);
  margin-bottom: 4px;
  letter-spacing: 0.3px;
}

.tec-exec-ia-field.warning .tec-exec-ia-label {
  color: #F5C0A0;
}

.tec-exec-ia-value {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.5;
}

.tec-exec-ia-value strong {
  color: var(--bright);
  font-weight: 600;
}

.tec-exec-falla-actions {
  margin-top: 10px;
}

/* Evitar que el click en el contenido expandido cierre la card */
.tec-exec-falla-expanded * {
  cursor: default;
}

/* Header con logo de marca para Pantalla 1 técnico */
.tec-header-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--wire);
  background: linear-gradient(to bottom, rgba(255,213,0,.03), transparent);
}

.tec-header-logo {
  height: 38px;
  width: auto;
  border-radius: 4px;
  flex-shrink: 0;
}

.tec-header-brand-text {
  flex: 1;
  min-width: 0;
}

.tec-header-brand-name {
  font-size: 14px;
  color: var(--bright);
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tec-header-brand-sub {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-top: 3px;
  font-weight: 500;
}

/* Ajustar el header del saludo para que fluya con el de marca */
.tec-header-brand + .tec-header {
  padding-top: 14px;
  border-top: none;
}

/* Logo chico en header de Pantalla 2 */
.tec-exec-title {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
}

.tec-exec-header-logo {
  height: 24px;
  width: auto;
  border-radius: 3px;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════
   PANTALLA 2 — Ejecución de OT (Técnico)
═══════════════════════════════════════════════════════ */

/* Header */
.tec-exec-header {
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--wire);
  background: var(--pit);
  position: relative;
  z-index: 2;
}

.tec-exec-back {
  background: transparent;
  border: none;
  color: var(--ice);
  font-size: 14px;
  padding: 10px 12px;
  min-height: 40px;
  min-width: 96px;
  border-radius: 10px;
  cursor: pointer;
  white-space: nowrap;
  position: relative;
  z-index: 3;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.tec-exec-back:active {
  color: #B5D4F4;
  background: rgba(72, 176, 232, 0.1);
}

.tec-exec-title {
  flex: 1;
  text-align: center;
  pointer-events: none;
}

.tec-exec-eyebrow {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.tec-exec-folio {
  font-size: 14px;
  color: var(--bright);
  font-weight: 600;
}

/* Contexto equipo */
.tec-exec-contexto {
  padding: 14px 16px;
  border-bottom: 1px solid var(--wire);
}

.tec-exec-contexto.critica {
  background: rgba(192, 48, 64, 0.08);
}

.tec-exec-contexto.alta {
  background: rgba(232, 131, 49, 0.08);
}

.tec-exec-contexto-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

.tec-exec-contexto-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.tec-exec-equipo {
  font-size: 15px;
  color: var(--bright);
  font-weight: 600;
}

.tec-exec-prio-pill {
  padding: 4px 10px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.4px;
  white-space: nowrap;
  flex-shrink: 0;
  text-transform: capitalize;
}

.tec-exec-prio-pill.critica {
  background: rgba(192, 48, 64, 0.2);
  color: #F7C1C1;
}

.tec-exec-prio-pill.alta {
  background: rgba(232, 131, 49, 0.22);
  color: #F5C0A0;
}

.tec-exec-prio-pill.media {
  background: rgba(255, 213, 0, 0.15);
  color: #FAC775;
}

.tec-exec-prio-pill.baja {
  background: rgba(97, 196, 89, 0.15);
  color: #C0DD97;
}

.tec-exec-desc {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.45;
}

/* Cronómetro */
.tec-exec-crono-box {
  padding: 20px 16px;
  text-align: center;
  border-bottom: 1px solid var(--wire);
  background: var(--pit);
}

.tec-exec-crono-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.tec-exec-crono {
  font-size: 38px;
  color: var(--bright);
  font-weight: 600;
  font-family: 'Courier New', monospace;
  letter-spacing: 2px;
  margin-bottom: 8px;
  line-height: 1;
}

.tec-exec-crono-activa {
  font-size: 11px;
  color: var(--gold);
  margin-bottom: 14px;
  font-weight: 500;
}

.tec-exec-crono-btn {
  width: 100%;
  max-width: 360px;
  padding: 16px;
  background: var(--crimson);
  border: none;
  border-radius: 12px;
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 8px;
}

.tec-exec-crono-btn:active {
  transform: scale(0.98);
}

.tec-exec-crono-btn.pausado {
  background: var(--jade);
  color: #173404;
}

/* Secciones */
.tec-exec-section {
  padding: 16px;
  border-bottom: 1px solid var(--wire);
}

.tec-exec-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.tec-exec-section-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
}

.tec-exec-section-badge {
  font-size: 10px;
  color: var(--gold);
  background: rgba(255, 213, 0, 0.15);
  padding: 3px 10px;
  border-radius: 8px;
  font-weight: 600;
}

/* Fallas cards */
.tec-exec-falla-card {
  padding: 12px 14px;
  border-radius: 10px;
  margin-bottom: 8px;
  border: 1px solid var(--wire);
  background: rgba(255, 255, 255, 0.02);
}

.tec-exec-falla-card.en-curso {
  background: rgba(255, 213, 0, 0.07);
  border: 1px solid rgba(255, 213, 0, 0.3);
  border-left: 3px solid var(--gold);
}

.tec-exec-falla-card.completada {
  background: rgba(97, 196, 89, 0.08);
  border: 1px solid rgba(97, 196, 89, 0.25);
}

.tec-exec-falla-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.tec-exec-falla-dot {
  font-size: 14px;
  flex-shrink: 0;
}

.tec-exec-falla-info {
  flex: 1;
  min-width: 0;
}

.tec-exec-falla-titulo {
  font-size: 13px;
  color: var(--bright);
  font-weight: 500;
  line-height: 1.3;
}

.tec-exec-falla-card.completada .tec-exec-falla-titulo {
  text-decoration: line-through;
  color: var(--muted);
}

.tec-exec-falla-meta {
  font-size: 10px;
  color: var(--muted);
  margin-top: 3px;
}

.tec-exec-falla-card.completada .tec-exec-falla-meta {
  color: var(--jade);
}

.tec-exec-falla-btn {
  padding: 8px 14px;
  border: none;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

.tec-exec-falla-btn.iniciar {
  background: var(--ice);
  color: #042C53;
}

.tec-exec-falla-btn.terminar {
  background: var(--jade);
  color: #173404;
}

.tec-exec-ver-ia-btn {
  width: 100%;
  margin-top: 8px;
  padding: 8px;
  background: rgba(72, 176, 232, 0.1);
  border: 1px solid rgba(72, 176, 232, 0.25);
  border-radius: 8px;
  color: var(--ice);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
}

/* Checklist */
.tec-exec-progreso-bar {
  height: 3px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 2px;
  margin-bottom: 12px;
  overflow: hidden;
}

.tec-exec-progreso-fill {
  height: 100%;
  background: var(--jade);
  border-radius: 2px;
  width: 0%;
  transition: width 0.25s ease;
}

.tec-exec-tarea {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 8px;
  margin-bottom: 6px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 0.15s;
}

.tec-exec-tarea:active {
  transform: scale(0.99);
}

.tec-exec-tarea.completada {
  background: rgba(97, 196, 89, 0.05);
}

.tec-exec-tarea.activa {
  background: rgba(72, 176, 232, 0.06);
  border: 1px solid rgba(72, 176, 232, 0.2);
}

.tec-exec-check {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  border: 2px solid var(--wire);
  background: transparent;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  color: transparent;
}

.tec-exec-tarea.completada .tec-exec-check {
  background: var(--jade);
  border-color: var(--jade);
  color: #173404;
}

.tec-exec-tarea-texto {
  flex: 1;
  min-width: 0;
}

.tec-exec-tarea-titulo {
  font-size: 13px;
  color: var(--bright);
  line-height: 1.35;
}

.tec-exec-tarea.completada .tec-exec-tarea-titulo {
  text-decoration: line-through;
  color: var(--muted);
}

.tec-exec-tarea-falla-badge {
  font-size: 9px;
  color: var(--gold);
  margin-top: 3px;
}

/* Acciones rápidas */
.tec-exec-acciones {
  padding: 12px 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  border-bottom: 1px solid var(--wire);
}

.tec-exec-accion-btn {
  padding: 14px 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--wire);
  border-radius: 10px;
  color: var(--soft);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
}

.tec-exec-accion-btn:active {
  background: rgba(255, 255, 255, 0.08);
}

.tec-exec-accion-btn.tec-exec-accion-alerta {
  background: rgba(192, 48, 64, 0.08);
  border-color: rgba(192, 48, 64, 0.3);
  color: #F09595;
}

/* Terminar OT */
.tec-exec-terminar {
  padding: 16px;
  background: rgba(97, 196, 89, 0.04);
  border-top: 1px solid rgba(97, 196, 89, 0.15);
}

.tec-exec-terminar-btn {
  width: 100%;
  padding: 14px;
  background: var(--jade);
  border: none;
  border-radius: 12px;
  color: #173404;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.tec-exec-terminar-btn:disabled {
  background: rgba(97, 196, 89, 0.15);
  color: rgba(97, 196, 89, 0.5);
  cursor: not-allowed;
}

.tec-exec-terminar-btn:not(:disabled):active {
  transform: scale(0.99);
}

.tec-exec-terminar-hint {
  font-size: 10px;
  color: var(--muted);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}

/* Responsive */
@media (max-width: 380px) {
  .tec-exec-crono { font-size: 32px; }
  .tec-exec-contexto,
  .tec-exec-section { padding: 14px; }
}

/* ═══════════════════════════════════════════════════════
   VISTA TÉCNICO (SPA)
═══════════════════════════════════════════════════════ */

.tecnico-app {
  position: fixed;
  inset: 0;
  background: var(--pit);
  z-index: 90;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  font-family: var(--font-sans);
}

.tec-pantalla {
  max-width: 480px;
  margin: 0 auto;
  padding-bottom: 24px;
  min-height: 100vh;
}

/* ─── Header personal ─── */
.tec-header {
  padding: 20px 18px 14px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  border-bottom: 1px solid var(--wire);
}

.tec-greet {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 2px;
}

.tec-name {
  font-size: 22px;
  color: var(--bright);
  font-weight: 600;
  letter-spacing: -0.3px;
}

.tec-role {
  font-size: 11px;
  color: var(--gold);
  margin-top: 3px;
  font-weight: 500;
  letter-spacing: 0.3px;
}

.tec-menu-btn {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--soft);
  font-size: 15px;
  cursor: pointer;
  transition: background 0.15s;
}

.tec-menu-btn:active {
  background: var(--plate);
}

/* ─── Stats ─── */
.tec-stats {
  padding: 14px 18px;
  background: rgba(97, 196, 89, 0.04);
  border-bottom: 1px solid rgba(97, 196, 89, 0.15);
}

.tec-stats-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.tec-stats-title {
  font-size: 10px;
  color: var(--jade);
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.tec-stats-period {
  font-size: 11px;
  color: var(--muted);
}

.tec-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}

.tec-stat {
  text-align: left;
}

.tec-stat-value {
  font-size: 23px;
  color: var(--bright);
  font-weight: 600;
  line-height: 1;
}

.tec-stat-value.tec-stat-green { color: var(--jade); }
.tec-stat-value.tec-stat-gold { color: var(--gold); }

.tec-stat-sub {
  font-size: 11px;
  color: var(--muted);
  font-weight: 400;
  margin-left: 2px;
}

.tec-stat-label {
  font-size: 10px;
  color: var(--muted);
  margin-top: 4px;
  letter-spacing: 0.3px;
}

/* ─── Banner notificación ─── */
.tec-notif-banner {
  margin: 12px 18px;
  padding: 12px 14px;
  background: rgba(255, 213, 0, 0.06);
  border: 1px solid rgba(255, 213, 0, 0.2);
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.tec-notif-icon { font-size: 20px; }

.tec-notif-content { flex: 1; }

.tec-notif-title {
  font-size: 13px;
  color: var(--bright);
  font-weight: 500;
}

.tec-notif-time {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}

/* ─── Secciones ─── */
.tec-section {
  padding: 18px 18px 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.tec-section:first-of-type {
  border-top: none;
}

.tec-section-label {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 700;
}

.tec-section-label-gold {
  color: var(--gold);
}

.tec-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.tec-section-count {
  font-size: 11px;
  color: var(--muted);
}

/* ─── Cards de OT ─── */
.tec-ot-card {
  padding: 14px;
  border-radius: 12px;
  border: 1px solid var(--wire);
  background: transparent;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all 0.15s;
}

.tec-ot-card:active {
  transform: scale(0.99);
}

.tec-ot-card.tec-ot-encurso {
  background: rgba(255, 213, 0, 0.07);
  border: 1px solid rgba(255, 213, 0, 0.3);
  border-left: 3px solid var(--gold);
  margin-bottom: 8px;
}

.tec-ot-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
  gap: 8px;
}

.tec-ot-folio {
  font-size: 15px;
  color: var(--bright);
  font-weight: 600;
}

.tec-ot-equipo {
  font-size: 11px;
  color: var(--soft);
  margin-top: 2px;
}

.tec-ot-prio-pill {
  padding: 4px 9px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.tec-ot-prio-critica {
  background: rgba(192, 48, 64, 0.25);
  color: #F7C1C1;
}
.tec-ot-prio-alta {
  background: rgba(232, 131, 49, 0.22);
  color: #F5C0A0;
}
.tec-ot-prio-media {
  background: rgba(255, 213, 0, 0.15);
  color: #FAC775;
}
.tec-ot-prio-baja {
  background: rgba(97, 196, 89, 0.15);
  color: #C0DD97;
}

.tec-ot-desc {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.4;
  margin: 8px 0 10px;
}

.tec-ot-venc {
  font-size: 10px;
  color: var(--crimson);
  background: rgba(192, 48, 64, 0.15);
  padding: 3px 7px;
  border-radius: 7px;
  font-weight: 600;
  letter-spacing: 0.4px;
}

.tec-ot-venc-normal {
  color: var(--muted);
  background: transparent;
  padding: 0;
  font-weight: 400;
  font-style: italic;
}

.tec-ot-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.tec-ot-encurso-info {
  display: flex;
  align-items: center;
  gap: 10px;
}

.tec-ot-cronometro {
  font-size: 14px;
  color: var(--gold);
  font-weight: 600;
  font-family: 'Courier New', monospace;
}

.tec-ot-progreso-fallas {
  font-size: 10px;
  color: var(--muted);
}

.tec-ot-btn {
  padding: 9px 14px;
  border: none;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}

.tec-ot-btn-continuar {
  background: var(--gold);
  color: #412402;
}

.tec-ot-btn-iniciar {
  background: var(--ice);
  color: #042C53;
  width: 100%;
  padding: 11px;
  margin-top: 8px;
}

.tec-ot-tiempo-est {
  font-size: 10px;
  color: var(--muted);
}

/* ─── Footer ─── */
.tec-footer-stats {
  padding: 20px 18px;
  text-align: center;
  font-size: 11px;
  color: var(--muted);
}

.tec-footer-dot {
  margin: 0 6px;
  color: var(--wire);
}

.tec-footer-link {
  color: var(--ice);
  cursor: pointer;
  font-weight: 500;
}

.tec-footer-link:active {
  color: #B5D4F4;
}

/* ─── Estado vacío ─── */
.tec-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--muted);
  font-size: 13px;
  font-style: italic;
}

/* ─── Mobile ─── */
@media (max-width: 380px) {
  .tec-header { padding: 16px 14px 12px; }
  .tec-section { padding: 16px 14px 8px; }
  .tec-stats { padding: 12px 14px; }
  .tec-stat-value { font-size: 20px; }
}

/* Badge de estado ejecucion en detalle OT */
.ot-falla-estado-badge {
  font-size: 9px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 8px;
  border: 1px solid;
  background: rgba(255, 255, 255, 0.03);
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Badge NUEVA (falla descubierta durante ejecucion) */
.ot-falla-badge-descubierta {
  font-size: 9px;
  font-weight: 700;
  color: var(--ice);
  background: rgba(72, 176, 232, 0.15);
  padding: 3px 7px;
  border-radius: 8px;
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex-shrink: 0;
  animation: pulseBadge 2s ease-in-out infinite;
}

@keyframes pulseBadge {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

/* En detalle, la card debe tener ancho completo */
#otd-fallas-list .ot-falla-card {
  margin-bottom: 8px;
}

#otd-fallas-list .ot-falla-card-row {
  grid-template-columns: 22px 1fr auto auto auto !important;
}

@media (max-width: 520px) {
  #otd-fallas-list .ot-falla-card-row {
    grid-template-columns: 22px 1fr auto !important;
  }
}

/* Botón "Hacer principal" ⭐ */
.ot-falla-star {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--gold);
  cursor: pointer;
  font-size: 12px;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
}

.ot-falla-star:hover {
  background: rgba(255, 213, 0, 0.15);
  border-color: var(--gold);
  transform: scale(1.1);
}

/* Aumentar columnas para acomodar botón ⭐ */
.ot-falla-card-row {
  grid-template-columns: 22px 1fr auto auto auto !important;
}

/* Principal solo tiene badge + ✕ (no ⭐) */
.ot-falla-card.ot-falla-principal .ot-falla-card-row {
  grid-template-columns: 22px 1fr auto auto !important;
}

.ot-tarea-num {
  width: 20px;
  height: 20px;
  border-radius: 4px;
  background: rgba(255, 213, 0, 0.12);
  color: var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}

.ot-tarea-num.ot-tarea-num-custom {
  background: rgba(72, 176, 232, 0.12);
  color: var(--ice);
}

.ot-tarea-texto {
  flex: 1;
  font-size: 13px;
  color: var(--bright);
  line-height: 1.4;
}

.ot-tarea-del {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 4px;
  transition: all 0.15s;
  flex-shrink: 0;
}

.ot-tarea-del:hover {
  background: rgba(192, 48, 64, 0.1);
  color: var(--crimson);
}

.ot-tarea-add {
  display: flex;
  gap: 8px;
}

.ot-tarea-add input {
  flex: 1;
}

.ot-tareas-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 6px;
  font-style: italic;
}

/* FOOTER STICKY */
.ot-footer-sticky {
  position: sticky;
  bottom: 0;
  background: var(--steel);
  border-top: 1px solid var(--wire);
  padding: 14px 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  z-index: 10;
}

.ot-footer-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

/* Mobile footer */
@media (max-width: 640px) {
  .ot-footer-sticky {
    flex-direction: column;
    gap: 8px;
  }

  .ot-footer-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .ot-footer-sticky .btn-ghost {
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════
   SELECTOR MÚLTIPLE DE FALLAS EN OT
═══════════════════════════════════════════════════════ */

/* Badge contador */
.ot-fallas-badge {
  font-size: 11.5px;
  color: var(--muted);
  background: transparent;
  padding: 0;
  border-radius: 0;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
}

/* Contenedor de fallas seleccionadas */
.ot-fallas-box {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  margin-bottom: 10px;
  min-height: 0;
}

.ot-fallas-vacio {
  padding: 14px;
  font-size: 12px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
}

/* Card individual de falla */
.ot-falla-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  transition: background 0.15s;
}

.ot-falla-card:last-child {
  border-bottom: none;
}

.ot-falla-card.ot-falla-principal {
  background: rgba(192, 48, 64, 0.06);
  border: 1px solid rgba(192, 48, 64, 0.2);
  border-left: 3px solid var(--crimson);
  border-radius: var(--r);
  margin-bottom: 4px;
}

.ot-falla-card-icon {
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
}

.ot-falla-card-info {
  flex: 1;
  min-width: 0;
}

.ot-falla-card-folio {
  font-size: 13px;
  font-weight: 600;
  color: var(--bright);
  line-height: 1.3;
}

.ot-falla-card-meta {
  font-size: 11px;
  color: var(--soft);
  margin-top: 2px;
}

.ot-falla-principal .ot-falla-card-folio {
  color: #FFB4B4;
}

.ot-falla-principal .ot-falla-card-meta {
  color: #F09595;
}

/* Badge "PRINCIPAL" */
.ot-falla-badge-principal {
  font-size: 9px;
  color: var(--gold);
  background: rgba(255, 213, 0, 0.18);
  padding: 2px 6px;
  border-radius: 8px;
  font-weight: 700;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

/* Botón quitar */
.ot-falla-del {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 14px;
  padding: 4px 8px;
  border-radius: 4px;
  transition: all 0.15s;
  flex-shrink: 0;
}

.ot-falla-del:hover {
  background: rgba(192, 48, 64, 0.1);
  color: var(--crimson);
}

/* Texto de ayuda */
.ot-fallas-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 6px;
  font-style: italic;
  line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════
   CARDS EXPANDIBLES DE FALLAS EN OT
═══════════════════════════════════════════════════════ */

.ot-falla-card {
  display: block !important;
  padding: 0 !important;
  overflow: hidden;
}

.ot-falla-card-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 10px;
}

.ot-falla-card.ot-falla-expandida {
  background: rgba(255, 213, 0, 0.03);
}

.ot-falla-card.ot-falla-principal.ot-falla-expandida {
  background: rgba(192, 48, 64, 0.08);
}

/* Botón expandir */
.ot-falla-expand {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--gold);
  cursor: pointer;
  font-size: 11px;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  transition: all 0.15s;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}

.ot-falla-expand:hover {
  background: rgba(255, 213, 0, 0.15);
  border-color: var(--gold);
}

/* Panel expandido */
.ot-falla-ia-panel {
  padding: 0 12px 14px;
  border-top: 1px dashed rgba(255, 213, 0, 0.2);
  margin-top: 2px;
  animation: slideDownIA 0.2s ease-out;
}

@keyframes slideDownIA {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.ot-falla-ia-block {
  margin-top: 12px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--wire);
  border-radius: var(--r);
}

.ot-falla-ia-block-warn {
  background: rgba(192, 48, 64, 0.05);
  border-color: rgba(192, 48, 64, 0.2);
  border-left: 3px solid var(--crimson);
}

.ot-falla-ia-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.ot-falla-ia-block-warn .ot-falla-ia-label {
  color: var(--crimson);
}

.ot-falla-ia-text {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.55;
  white-space: pre-wrap;
}

.ot-falla-ia-list {
  margin: 0;
  padding-left: 18px;
  font-size: 12px;
  color: var(--soft);
  line-height: 1.6;
}

.ot-falla-ia-list li {
  margin-bottom: 3px;
}

.ot-falla-ia-empty {
  padding: 12px;
  text-align: center;
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
}

/* ═══════════════════════════════════════════════════════
   CARDS DE FALLAS - FIX DE LAYOUT
═══════════════════════════════════════════════════════ */

/* Card contenedora */
.ot-falla-card {
  display: block !important;
  padding: 0 !important;
  overflow: visible;
  margin-bottom: 8px;
  border: 1px solid var(--wire);
  border-radius: var(--r);
  background: rgba(255, 255, 255, 0.01);
  transition: all 0.15s;
}

.ot-falla-card:last-child {
  margin-bottom: 0;
}

.ot-falla-card:hover {
  border-color: rgba(255, 213, 0, 0.2);
}

/* Card principal destacada */
.ot-falla-card.ot-falla-principal {
  background: rgba(192, 48, 64, 0.06);
  border: 1px solid rgba(192, 48, 64, 0.25);
  border-left: 3px solid var(--crimson);
}

.ot-falla-card.ot-falla-expandida {
  background: rgba(255, 213, 0, 0.04);
  border-color: rgba(255, 213, 0, 0.3);
}

.ot-falla-card.ot-falla-principal.ot-falla-expandida {
  background: rgba(192, 48, 64, 0.09);
}

/* Fila principal: ícono + info + controles */
.ot-falla-card-row {
  display: grid;
  grid-template-columns: 22px 1fr auto auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  min-height: 52px;
}

/* Ícono de severidad */
.ot-falla-card-icon {
  font-size: 16px;
  line-height: 1;
  width: 22px;
  text-align: center;
}

/* Info: folio + meta */
.ot-falla-card-info {
  min-width: 0;
  overflow: hidden;
}

.ot-falla-card-folio {
  font-size: 13px;
  font-weight: 600;
  color: var(--bright);
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ot-falla-card-meta {
  font-size: 11px;
  color: var(--soft);
  margin-top: 3px;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ot-falla-principal .ot-falla-card-folio {
  color: #FFB4B4;
}

.ot-falla-principal .ot-falla-card-meta {
  color: #F5959A;
}

/* Botón expandir ▼ */
.ot-falla-expand {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--gold);
  cursor: pointer;
  font-size: 10px;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
}

.ot-falla-expand:hover {
  background: rgba(255, 213, 0, 0.15);
  border-color: var(--gold);
  transform: scale(1.05);
}

/* Badge PRINCIPAL */
.ot-falla-badge-principal {
  font-size: 9px;
  color: var(--gold);
  background: rgba(255, 213, 0, 0.2);
  padding: 4px 8px;
  border-radius: 8px;
  font-weight: 700;
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Botón quitar ✕ */
.ot-falla-del {
  background: transparent;
  border: 1px solid var(--wire);
  color: var(--muted);
  cursor: pointer;
  font-size: 11px;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
}

.ot-falla-del:hover {
  background: rgba(192, 48, 64, 0.15);
  border-color: var(--crimson);
  color: var(--crimson);
}

/* Panel expandido */
.ot-falla-ia-panel {
  padding: 0 14px 14px 44px;
  animation: slideDownIA 0.2s ease-out;
}

@keyframes slideDownIA {
  from { opacity: 0; max-height: 0; }
  to { opacity: 1; max-height: 1000px; }
}

.ot-falla-ia-block {
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--wire);
  border-radius: var(--r);
}

.ot-falla-ia-block-warn {
  background: rgba(192, 48, 64, 0.05);
  border-color: rgba(192, 48, 64, 0.2);
  border-left: 3px solid var(--crimson);
}

.ot-falla-ia-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.ot-falla-ia-block-warn .ot-falla-ia-label {
  color: var(--crimson);
}

.ot-falla-ia-text {
  font-size: 12px;
  color: var(--soft);
  line-height: 1.55;
  white-space: pre-wrap;
}

.ot-falla-ia-list {
  margin: 0;
  padding-left: 18px;
  font-size: 12px;
  color: var(--soft);
  line-height: 1.6;
}

.ot-falla-ia-list li {
  margin-bottom: 4px;
}

.ot-falla-ia-empty {
  padding: 14px;
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  font-style: italic;
}

/* Contenedor de cards */
.ot-fallas-box {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  margin-bottom: 10px;
  min-height: 0;
}

.ot-fallas-vacio {
  padding: 14px;
  font-size: 12px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
}

/* Responsive para móvil */
@media (max-width: 520px) {
  .ot-falla-card-row {
    grid-template-columns: 22px 1fr auto;
    gap: 8px;
    padding: 10px;
  }

  /* En móvil, el ícono de expandir pasa debajo */
  .ot-falla-card-row .ot-falla-expand {
    grid-column: 1 / -1;
    width: 100%;
    height: 24px;
    margin-top: 4px;
  }

  .ot-falla-card-folio {
    white-space: normal;
    line-height: 1.4;
  }

  .ot-falla-card-meta {
    white-space: normal;
    line-height: 1.4;
  }

  .ot-falla-ia-panel {
    padding: 0 10px 12px 10px;
  }
}

/* Badge del folio de falla origen en cada tarea */
.ot-tarea-origen {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--gold);
  background: rgba(255, 213, 0, 0.12);
  padding: 3px 7px;
  border-radius: 8px;
  white-space: nowrap;
  flex-shrink: 0;
}

.ot-tarea-ia {
  background: rgba(255, 213, 0, 0.02);
}

.ot-tarea-custom {
  background: rgba(72, 176, 232, 0.02);
}

.ot-tarea-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.ot-tarea-item:last-child {
  border-bottom: none;
}
