@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@600;700&family=Inter:wght@400;500;600&display=swap');
/* ENERCON · Tema "Grafito y verde" — grafito oscuro sobrio, acento verde apagado (no neón).
   (estilo cobre anterior respaldado en assets/styles.OLD-pre-A3.css) */
:root{
  --bg:#0E1110; --side:#111413; --panel:#161A18; --panel2:#1B201D; --line:#272D29;
  --txt:#E7EAE8; --muted:#9AA39E;
  --accent:#4FA383; --accent2:#5FB492; --cu2:#3C7E66;
  --eco:#4FA383; --dem:#D97777; --equ:#8A948E; --warn:#D6A94E;
  --radius:11px; --shadow:0 6px 24px rgba(0,0,0,.45);
  --font-num:'Rajdhani','Segoe UI',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Inter','Segoe UI',system-ui,Roboto,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px}
a{color:var(--accent2);text-decoration:none}
button{font-family:inherit}
h1,h2,h3{margin:0 0 .4em}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.spacer{flex:1}
.hidden{display:none!important}
/* Números grandes y títulos en Rajdhani (tema grafito+verde) */
h1{font-family:var(--font-num);font-weight:700;letter-spacing:.01em}
.stat .v,.traz-head,.kpi-n{font-family:var(--font-num);font-weight:700}
/* Dashboard de obras */
.ob-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.ob-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s,transform .15s}
.ob-card:hover{border-color:var(--accent);transform:translateY(-2px)}
/* Secciones de obra desplegables (accordion de cards) */
.sec{margin-bottom:11px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--side)}
.sec-h{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none;background:var(--panel)}
.sec-h:hover{background:var(--panel2)}
.sec-ic{font-size:17px}
.sec-t{font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:12.5px;color:var(--txt)}
.sec .chev{margin-left:auto;color:var(--muted);transition:transform .15s;font-size:13px}
.sec.col .chev{transform:rotate(-90deg)}
.sec.col .sec-b{display:none}
.sec-b{padding:14px 16px}
/* 3D sutil (CSS puro, GPU — sin librerías) */
.ob-card{box-shadow:0 2px 10px rgba(0,0,0,.30);transform-style:preserve-3d}
.card,.sec{box-shadow:0 2px 12px rgba(0,0,0,.28)}
@media (hover:hover) and (prefers-reduced-motion:no-preference){
  .ob-card{will-change:transform;transition:transform .12s ease,box-shadow .2s,border-color .15s}
  .ob-card:hover{box-shadow:0 18px 40px rgba(0,0,0,.55),0 0 0 1px rgba(79,163,131,.25)}
  .stat{transition:transform .16s ease,box-shadow .2s}
  .stat:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,.45)}
}

/* ---------- Login (split, grafito + cobre) ---------- */
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:20px;margin-bottom:4px}
.brand .bolt{color:var(--accent)}
.auth{display:grid;grid-template-columns:1.1fr .9fr;min-height:100vh}
.auth-brand{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:56px 60px;color:#efeae2;
  background:radial-gradient(1200px 500px at 20% -10%,rgba(79,163,131,.20),transparent 60%),linear-gradient(135deg,#16201C 0%,#121613 55%,#0c0f0d 100%)}
.auth-brand::before{content:"";position:absolute;inset:0;opacity:.13;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cg fill='none' stroke='%234FA383' stroke-width='1.2'%3E%3Cpath d='M10 30h30v-20M40 30l15 15h25M80 45v25h25M10 70h25l15 15v25M70 95h40M95 10v25'/%3E%3Ccircle cx='40' cy='30' r='3'/%3E%3Ccircle cx='80' cy='45' r='3'/%3E%3Ccircle cx='105' cy='70' r='3'/%3E%3Ccircle cx='50' cy='85' r='3'/%3E%3Ccircle cx='95' cy='10' r='3'/%3E%3C/g%3E%3C/svg%3E")}
.auth-brand > *{position:relative;z-index:1}
.auth-brand .logo-img{height:54px;margin-bottom:4px;background:#fff;padding:9px 14px;border-radius:12px;align-self:flex-start;box-shadow:0 6px 18px rgba(0,0,0,.3)}
.auth-brand .brand-tag{color:#9FC9B5;font-style:italic;font-size:14px;margin-top:14px;max-width:440px}
.auth-brand h2{font-size:30px;line-height:1.22;margin:22px 0 8px;max-width:460px;font-weight:800}
.auth-brand p.lead{color:#c9c0b1;max-width:440px;font-size:15px;line-height:1.5}
.auth-feats{margin-top:34px;display:flex;flex-direction:column;gap:16px;max-width:460px}
.auth-feat{display:flex;gap:13px;align-items:flex-start}
.auth-feat .ic{flex:none;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(79,163,131,.13);border:1px solid rgba(79,163,131,.32);font-size:18px}
.auth-feat .tx b{display:block;font-size:14px}
.auth-feat .tx span{color:#b3a890;font-size:13px}
.auth-brand .foot{position:absolute;bottom:24px;left:60px;color:#8f867a;font-size:12px;z-index:1}

.auth-form{display:flex;align-items:center;justify-content:center;background:#f4f2ee;padding:30px}
.auth-card{width:380px;max-width:100%}
.auth-card .auth-logo{display:block;height:50px;margin:0 0 22px}
.auth-card h1{color:#1c1a17;font-size:25px;margin:0 0 4px}
.auth-card .sub{color:#7a7263;margin-bottom:20px;font-size:14px}
.auth-card label{color:#7a7263;font-weight:600}
.auth-card input{background:#fff;border:1px solid #ddd6c8;color:#1c1a17;padding:11px}
.auth-card input::placeholder{color:#b3aa99}
.auth-card input:focus{border-color:var(--cu2);box-shadow:0 0 0 3px rgba(79,163,131,.18)}
.auth-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.checkbox{display:flex;align-items:center;gap:8px;color:#7a7263;font-size:13px;cursor:pointer;user-select:none}
.checkbox input{width:16px;height:16px;accent-color:var(--cu2)}
.auth-card .btn.primary{width:100%;margin-top:18px;padding:12px;font-size:15px;background:linear-gradient(180deg,var(--accent),var(--cu2));color:#06231A;box-shadow:0 8px 20px rgba(60,126,102,.32)}
.auth-card .foot{margin-top:22px;text-align:center;color:#a39a89;font-size:12px}
.auth-card .link{color:var(--cu2);font-size:13px;font-weight:600}
@media(max-width:860px){.auth{grid-template-columns:1fr}.auth-brand{display:none}}

/* ---------- Login v2 (split marca + 3D, variante C) ---------- */
.login{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% center,rgba(79,163,131,.13) 0%,#0E1110 70%);padding:28px}
.lfx{position:absolute;inset:0;z-index:0;pointer-events:none}
.lfx svg{width:100%;height:100%;display:block}
.lfx .tr{fill:none;stroke:#4FA383;stroke-width:1.4;opacity:.20;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 4px rgba(79,163,131,.45));stroke-dasharray:14 240;animation:lflow linear infinite}
.lfx .tr:nth-child(1){animation-duration:5s}.lfx .tr:nth-child(2){animation-duration:6.5s}.lfx .tr:nth-child(3){animation-duration:5.8s}.lfx .tr:nth-child(4){animation-duration:7.2s}.lfx .tr:nth-child(5){animation-duration:4.6s}.lfx .tr:nth-child(6){animation-duration:6.1s}.lfx .tr:nth-child(7){animation-duration:5.3s}.lfx .tr:nth-child(8){animation-duration:6.8s}
.lfx .nd{fill:#4FA383;filter:drop-shadow(0 0 6px rgba(79,163,131,.7));animation:lpulse 3.2s ease-in-out infinite}
@keyframes lflow{to{stroke-dashoffset:-254}}
@keyframes lpulse{0%,100%{opacity:.25}50%{opacity:.85}}
.lfloat{position:relative;z-index:1;perspective:1400px}
.lcard{display:flex;width:920px;max-width:100%;min-height:600px;position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);transform-style:preserve-3d;transform:rotateY(-5deg);transition:transform .45s cubic-bezier(.25,.46,.45,.94);box-shadow:0 8px 22px rgba(0,0,0,.55),0 28px 64px rgba(0,0,0,.6),0 0 52px rgba(79,163,131,.10);animation:lcardIn .7s cubic-bezier(.25,.46,.45,.94) both}
.lcard:hover{transform:rotateY(0)}
@keyframes lcardIn{from{opacity:0;transform:rotateY(-9deg) translateY(28px)}to{opacity:1;transform:rotateY(-5deg) translateY(0)}}
.lbrand{width:360px;flex:none;padding:50px 38px;color:var(--txt);background:linear-gradient(150deg,#1a241f,#121613 60%,#0d100e);position:relative;overflow:hidden}
.lbrand::before{content:"";position:absolute;inset:0;opacity:.10;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90' viewBox='0 0 90 90'%3E%3Cg fill='none' stroke='%234FA383' stroke-width='1.1'%3E%3Cpath d='M8 24h22v-16M30 24l12 12h20M62 36v20h20M8 56h18l12 12'/%3E%3Ccircle cx='30' cy='24' r='2.4'/%3E%3Ccircle cx='62' cy='36' r='2.4'/%3E%3Ccircle cx='82' cy='56' r='2.4'/%3E%3C/g%3E%3C/svg%3E")}
.lbrand>*{position:relative}
.lblogo{height:48px;background:#fff;padding:8px 13px;border-radius:12px;display:inline-block;box-shadow:0 6px 16px rgba(0,0,0,.35)}
.lbrand h2{font-family:var(--font-num);font-weight:700;font-size:28px;margin:22px 0 8px;letter-spacing:.04em}
.lbrand p{color:var(--muted);font-size:13.5px;line-height:1.55;margin:0}
.lfeat{margin-top:28px;display:flex;flex-direction:column;gap:15px}
.lfeat div{display:flex;align-items:center;gap:10px;font-size:13px;color:#b9c2bc}
.lfeat i{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:none;box-shadow:0 0 8px rgba(79,163,131,.6)}
.lfooting{position:absolute;bottom:26px;left:36px;right:36px;color:#5E6661;font-size:11.5px;line-height:1.7}
.lform{flex:1;background:var(--panel);display:flex;align-items:center;justify-content:center}
.lform-in{width:100%;padding:48px 48px}
.lform h1{color:var(--txt);font-size:27px;font-weight:700;margin:0 0 6px;letter-spacing:.01em}
.lsub{color:var(--muted);font-size:14px;margin-bottom:30px;line-height:1.5}
.lform label{display:block;color:var(--txt);font-weight:600;font-size:13.5px;margin:0 0 7px}
.lfg{margin-bottom:24px}
.lform input[name]{width:100%;border:none;border-bottom:1px solid #3a423d;background:transparent;padding:12px 4px;color:#cfd6d1;font-size:15px;outline:none;border-radius:0;transition:border-color .2s}
.lform input::placeholder{color:#5E6661}
.lform input[name]:focus{border-bottom-color:var(--accent);box-shadow:none}
.lrow{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px}
.lchk{display:flex!important;align-items:center;gap:8px;color:var(--muted);font-size:13px;cursor:pointer;font-weight:400!important;margin:0;width:auto}
.lform input[type=checkbox]{width:18px!important;height:18px;flex:none;accent-color:var(--accent);margin:0}
.llink{color:var(--muted);font-size:12.5px;cursor:pointer;transition:color .15s}
.llink:hover{color:var(--accent)}
.lbtn{width:100%;height:50px;border:none;border-radius:9px;background:linear-gradient(135deg,#3C7E66,#4FA383);color:#06231A;font-weight:700;font-size:16px;cursor:pointer;margin-top:26px;box-shadow:0 4px 20px rgba(60,126,102,.35);transition:all .2s}
.lbtn:hover{background:linear-gradient(135deg,#46916f,#5FB492);box-shadow:0 6px 28px rgba(79,163,131,.5);transform:translateY(-1px)}
.lbtn:disabled{opacity:.6;cursor:not-allowed}
.lhelp{text-align:center;color:#5E6661;font-size:12px;margin-top:20px}
@media(max-width:720px){.lbrand{display:none}.lcard{width:420px;min-height:0;transform:none;animation-name:none}.lfloat{animation:none;perspective:none}.lform-in{padding:40px 32px}}
@media(prefers-reduced-motion:reduce){.lfx .tr,.lfx .nd,.lfloat,.lcard{animation:none!important}}

/* ---------- Inputs ---------- */
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
input,select,textarea{width:100%;padding:9px 11px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;color:var(--txt);font-size:14px;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
.btn{display:inline-flex;align-items:center;gap:7px;justify-content:center;padding:9px 15px;border:1px solid var(--line);background:var(--panel2);color:var(--txt);border-radius:8px;cursor:pointer;font-size:14px;transition:.15s}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:linear-gradient(180deg,var(--accent),var(--cu2));border:none;color:#06231A;font-weight:800}
.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent}
.btn.danger{border-color:#5d2c22;color:#f0a294}
.btn.danger:hover{background:#3a201a}
.btn.sm{padding:5px 9px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Layout: rail lateral de iconos (A3) ---------- */
.layout{display:grid;grid-template-columns:76px 1fr;min-height:100vh}
.side{background:var(--side);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 9px;position:sticky;top:0;height:100vh;z-index:10}
.side-logo{display:block;background:#fff;border-radius:11px;padding:6px;margin-bottom:18px;box-shadow:0 4px 12px rgba(0,0,0,.35)}
.side-logo img{display:block;width:44px;height:auto}
.snav{display:flex;flex-direction:column;gap:6px;align-items:center;width:100%}
.snav a{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;color:var(--muted);font-size:10px;font-weight:600;text-align:center;width:58px;border-radius:11px;line-height:1.1}
.snav a .ic{font-size:19px}
.side .ic{display:flex;align-items:center;justify-content:center}
.side .ic svg{display:block;width:22px;height:22px}
.snav a.on{background:var(--panel2);color:var(--accent);box-shadow:inset 0 0 0 1px rgba(79,163,131,.35)}
.snav a:hover{color:var(--txt)}
.side .sep{flex:1}
.side-user{display:flex;flex-direction:column;align-items:center;gap:4px;padding:9px 4px;width:58px;border-radius:11px;color:var(--muted);font-size:10px;font-weight:600;border-top:1px solid var(--line);padding-top:12px;border-radius:0;width:100%;text-align:center}
.side-user .av{width:32px;height:32px;border-radius:50%;background:var(--panel2);color:var(--accent);display:grid;place-items:center;font-weight:800;font-size:14px}
.side-user.on .av{box-shadow:inset 0 0 0 1px rgba(79,163,131,.5)}
.side-user:hover{color:var(--txt)}
.side-out{display:flex;flex-direction:column;align-items:center;gap:3px;background:transparent;border:none;color:var(--muted);font-size:10px;font-weight:600;cursor:pointer;padding:7px 4px;width:100%;border-radius:9px}
.side-out .ic{font-size:16px}
.side-out:hover{color:var(--dem)}
.content{min-width:0}
.container{max-width:1200px;margin:0 auto;padding:24px 24px 60px}
@media(max-width:780px){
  .layout{grid-template-columns:1fr}
  .side{position:sticky;top:0;height:auto;flex-direction:row;align-items:center;padding:8px 12px;border-right:none;border-bottom:1px solid var(--line)}
  .side-logo{margin:0 8px 0 0;padding:4px}.side-logo img{width:34px}
  .snav{flex-direction:row;width:auto}
  .snav a{flex-direction:row;width:auto;padding:7px 10px;font-size:12px}
  .snav a .ic{font-size:15px}
  .side-user{flex-direction:row;width:auto;border-top:none;padding:4px 8px}
  .side-user .lb,.side-out .lb{display:none}
  .side-out{flex-direction:row;width:auto}
}
.page-head{display:flex;align-items:center;gap:12px;margin:0 0 18px;min-height:42px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:22px;line-height:1.2}
.page-head .spacer{flex:1}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.card h2{font-size:16px}
.card-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;min-height:34px}
.card-head h2{margin:0;font-size:16px}
.card-head .spacer{flex:1}
.card-head .btn{flex:none}
.grid{display:grid;gap:14px}
.grid.cols2{grid-template-columns:1fr 1fr}
.grid.cols3{grid-template-columns:repeat(3,1fr)}
.grid.cols4{grid-template-columns:repeat(4,1fr)}
@media(max-width:780px){.grid.cols2,.grid.cols3,.grid.cols4{grid-template-columns:1fr}}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;position:sticky;top:0;background:var(--panel)}
tbody tr:hover{background:var(--panel2)}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.table-wrap{overflow:auto;max-height:62vh;border:1px solid var(--line);border-radius:var(--radius)}
.table-wrap table th{top:0}

/* ---------- Chips / badges ---------- */
.tag{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700}
.tag.eco{background:rgba(127,176,105,.14);color:var(--eco)}
.tag.dem{background:rgba(226,101,78,.14);color:var(--dem)}
.tag.equ{background:var(--panel2);color:var(--equ)}
.tag.rubro{background:var(--panel2);color:var(--muted);border:1px solid var(--line);font-weight:600}
.tag.warn{background:rgba(229,194,90,.14);color:var(--warn);border:1px solid rgba(229,194,90,.3)}
.report-warn{background:rgba(229,194,90,.10);border:1px solid rgba(229,194,90,.38);color:#e9cd80;border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px;line-height:1.5}
.report-info{background:rgba(79,163,131,.08);border:1px solid rgba(79,163,131,.3);color:#A9CDBC;border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px}
.pill{padding:6px 12px;border-radius:8px;border:1px solid var(--line);background:transparent;cursor:pointer;font-weight:600;color:var(--muted)}
.pill.active{background:var(--accent);color:#06231A;border-color:transparent;font-weight:800}

/* ---------- Stats ---------- */
.stat{background:var(--panel2);border:1px solid var(--line);border-top:3px solid var(--line);border-radius:var(--radius);padding:14px}
.stat .k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}
.stat .v{font-size:22px;font-weight:800;margin-top:4px;font-variant-numeric:tabular-nums}
.v.eco{color:var(--eco)} .v.dem{color:var(--dem)}

/* ---------- Tablero visual (dashboard) ---------- */
.dash-grid{display:grid;grid-template-columns:1fr 290px;gap:22px}
@media(max-width:820px){.dash-grid{grid-template-columns:1fr}}
.chart-legend{display:flex;gap:16px;font-size:12px;color:var(--muted)}
.dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
.chart-row{display:grid;grid-template-columns:160px 1fr 74px;gap:12px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.chart-row:last-child{border-bottom:none}
.chart-label{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bars{display:flex;flex-direction:column;gap:4px}
.bar2{height:11px;border-radius:4px;background:var(--panel2)}
.bar2 > i{display:block;height:100%;border-radius:4px;min-width:3px;transition:width .45s ease}
.bar2 .lic{background:#8d8a82}
.bar2 .proy{background:linear-gradient(90deg,var(--accent),var(--cu2))}
.chart-val{text-align:right}
.dash-side{border-left:1px solid var(--line);padding-left:20px}
@media(max-width:820px){.dash-side{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:14px}}
.dash-tally{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center}
.tl{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:11px 6px}
.tv{font-size:23px;font-weight:800;font-variant-numeric:tabular-nums}
.tv.eco{color:var(--eco)} .tv.dem{color:var(--dem)}
.tk{font-size:11px;color:var(--muted);margin-top:2px}
.dash-mov-h{margin:16px 0 7px;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.mov-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 0;border-bottom:1px dashed var(--line)}
.mov-row:last-child{border-bottom:none}
.mov-name{font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}

/* ---------- Misc ---------- */
.tabs{display:flex;gap:6px;margin-bottom:14px}
.dropzone{border:2px dashed var(--line);border-radius:var(--radius);padding:26px;text-align:center;color:var(--muted);cursor:pointer;transition:.15s}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);color:var(--txt);background:var(--panel2)}
.report-box{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:12px;margin-top:12px;font-size:13px}
.report-box .line{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px dashed var(--line)}
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);width:560px;max-width:100%;padding:22px;max-height:88vh;overflow:auto}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--panel2);border:1px solid var(--line);padding:11px 18px;border-radius:10px;box-shadow:var(--shadow);transition:.25s;opacity:0;z-index:100}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.err{border-color:#5d2c22;color:#f0a294}
.toast.ok{border-color:#42542f;color:#b9d6a4}
.err-text{color:#f0a294;font-size:13px;min-height:18px;margin-top:8px}
.inline-edit{background:transparent;border:1px solid transparent;padding:4px 6px}
.inline-edit:hover{border-color:var(--line)}
.empty{text-align:center;color:var(--muted);padding:30px}
.crumb{color:var(--muted);font-size:13px;margin-bottom:6px}
.crumb a{color:var(--muted)}
.loading{padding:40px;text-align:center;color:var(--muted)}
.bar{height:8px;border-radius:6px;background:var(--panel2);overflow:hidden}
.bar > i{display:block;height:100%}

/* ---- Triage de omitidos ---- */
.triage-list{max-height:280px;overflow:auto;border:1px solid var(--line);border-radius:8px}
.triage-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px dashed var(--line)}
.triage-row:last-child{border-bottom:none}
.triage-row.done{opacity:.6}
.triage-row .t-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.triage-row .t-qty{width:64px;text-align:right;font-size:12px}
.triage-row .t-actions{display:flex;gap:4px}
.triage-row .t-status{min-width:96px;text-align:right;font-size:12px}

/* ---- Curva de trazabilidad (valor ganado) ---- */
.traz-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
@media(max-width:820px){.traz-grid{grid-template-columns:1fr}}
.traz-kpi{display:flex;flex-direction:column;gap:8px}
.traz-head{font-size:34px;font-weight:700;line-height:1}
.traz-head.dem{color:var(--dem)}.traz-head.eco{color:var(--eco)}.traz-head.equ{color:#cfc9bd}
.traz-chart{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:8px}
.traz-pts{max-height:150px;overflow:auto;margin-top:8px;font-size:13px}
.traz-pts .line{padding:4px 0;border-bottom:1px dashed var(--line)}
