
:root{
  --bg:#0b0f16; --bg2:#0f1520; --card:rgba(255,255,255,.03);
  --line:rgba(255,255,255,.10); --dash:rgba(255,255,255,.22);
  --txt:rgba(255,255,255,.90); --mut:rgba(255,255,255,.72); --mut2:rgba(255,255,255,.55);
  --accent:#00abf3; --cero:#FF7A00; --plus:#6AD2FF;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg2) 100%);
  color:var(--txt);
}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:18px}
.wf{
  border:1px solid var(--line);
  border-radius:18px;
  background:radial-gradient(900px 280px at 20% 0%, rgba(0,171,243,.14) 0%, rgba(0,171,243,0) 60%),
             rgba(255,255,255,.02);
  overflow:hidden;
}
.topbar{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:14px 16px; border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:1000;letter-spacing:.06em;font-size:12px}
.mark{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(0,171,243,.12)}
.nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nav a{
  text-decoration:none; font-weight:900; font-size:12px;
  border:1px solid var(--line); border-radius:999px; padding:8px 10px;
  background:rgba(255,255,255,.03);
}
.page-title{padding:18px 16px 10px}
h1{margin:0 0 8px;font-size:26px;line-height:1.15}
p{margin:0;color:var(--mut);line-height:1.5}
.section{padding:14px 16px}
.label{
  display:inline-block; font-size:12px; font-weight:1000; letter-spacing:.12em;
  border:1px solid var(--line); border-radius:999px; padding:8px 10px;
  background:rgba(255,255,255,.03); color:rgba(255,255,255,.82);
  margin:0 0 10px;
}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.box{
  border:1px solid var(--line); background:var(--card); border-radius:16px; padding:14px;
}
.box h3{margin:0 0 8px;font-size:15px}
.muted{color:var(--mut)}
.hr{height:1px;background:var(--line);margin:12px 0}
.kpi{display:flex;gap:8px;flex-wrap:wrap}
.pill{border:1px dashed var(--dash);background:rgba(255,255,255,.03);padding:7px 10px;border-radius:999px;font-weight:900;font-size:12px}
.cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:12px;text-decoration:none;font-weight:1000;font-size:13px;
  border:1px solid rgba(0,171,243,.32);
  background:rgba(0,171,243,.14);
}
.btn.ghost{border-color:var(--line);background:rgba(255,255,255,.03)}
.btn.small{padding:8px 10px;font-size:12px;border-radius:10px}
.imgph{
  height:160px;border:2px dashed var(--dash);border-radius:16px;background:rgba(255,255,255,.02);
}
.form{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field{border:2px dashed var(--dash);border-radius:12px;padding:10px;color:rgba(255,255,255,.70);background:rgba(255,255,255,.02)}
.field.full{grid-column:1/-1}
.footer{
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
  padding:14px 16px;border-top:1px solid var(--line);color:var(--mut2);font-size:12px
}
.approval{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.02);
  padding:12px 12px
}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);border-radius:999px;padding:8px 10px;font-weight:1000;font-size:12px;background:rgba(255,255,255,.03)
}
.dot{width:10px;height:10px;border-radius:50%;background:#9ca3af}
.dot.ok{background:#22c55e}
.dot.no{background:#ef4444}
.note{color:var(--mut);font-size:12px}
.checklist{
  margin-top:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.02);
  padding:12px
}
.checklist h3{margin:0 0 10px;font-size:14px}
.chk{display:flex;align-items:flex-start;gap:10px;margin:8px 0;color:var(--mut)}
.chk input{margin-top:3px}
@media (max-width:980px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .topbar{flex-direction:column;align-items:flex-start}
  .nav{justify-content:flex-start}
}

/* Branding: logo support */
.brandlogo{display:flex;align-items:center;gap:10px}
.brandlogo img{height:40px;width:auto;display:block}
@media (max-width:980px){ .brandlogo img{height:32px} }

/* Ensure readability in form controls */
input, textarea, select{ color: rgba(255,255,255,.92); }
input::placeholder, textarea::placeholder{ color: rgba(255,255,255,.45); }


/* FIX: Ensure approval buttons are readable */
.btn, .btn.small, button.btn, [data-approve].btn, [data-pending].btn{
  color: rgba(255,255,255,.95) !important;
}
.btn.ghost, .btn.small.ghost{
  color: rgba(255,255,255,.95) !important;
}


/* === Quote panel (USD + EUR) === */
.quote-wrap{display:grid;gap:12px}
.quote-card{border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);border-radius:16px;padding:14px}
.quote-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.quote-title h3{margin:0;font-size:15px}
.quote-sub{margin:4px 0 0;color:rgba(255,255,255,.68);font-size:13px;line-height:1.35}
.quote-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
@media(min-width:900px){.quote-grid{grid-template-columns:1.2fr .8fr}}
.quote-kpis{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.quote-kpi{border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:6px 10px;font-size:12px;background:rgba(0,0,0,.18);color:rgba(255,255,255,.88)}
.quote-kpi b{font-weight:800}
.quote-nums{display:grid;gap:8px}
.quote-nums .row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.quote-nums .row .lbl{color:rgba(255,255,255,.65);font-size:12px}
.quote-nums .row .val{font-size:14px;font-weight:800}
.quote-badge{display:inline-flex;align-items:center;gap:8px}
.quote-badge .dot{width:8px;height:8px;border-radius:50%;background:rgba(0,216,160,.95);box-shadow:0 0 0 4px rgba(0,216,160,.12)}
.quote-extras{display:grid;gap:10px}
.quote-extras .extra{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px;background:rgba(255,255,255,.03)}
.quote-extras label{display:flex;gap:10px;cursor:pointer}
.quote-extras input{margin-top:3px}
.quote-extras .meta{color:rgba(255,255,255,.70);font-size:12px;line-height:1.35}
.quote-extras .price{white-space:nowrap;color:rgba(255,255,255,.80);font-size:12px}
.quote-foot{margin-top:10px;color:rgba(255,255,255,.60);font-size:12px;line-height:1.35}


/* === Export estructura (diagrama + HTML) === */
.struct-card{border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);border-radius:16px;padding:14px}
.struct-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:10px}
.btn-export{appearance:none;border:1px solid rgba(255,255,255,.16);background:rgba(0,171,243,.18);color:rgba(255,255,255,.92);padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:800}
.btn-export:hover{background:rgba(0,171,243,.26)}
.btn-export.secondary{background:rgba(255,255,255,.06)}
.btn-export.secondary:hover{background:rgba(255,255,255,.10)}
.struct-preview{margin-top:12px;display:grid;gap:12px}
.struct-cols{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:900px){.struct-cols{grid-template-columns:1fr 1fr}}
.struct-box{border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:12px;background:rgba(255,255,255,.03)}
.struct-box h4{margin:0 0 8px;font-size:13px;color:rgba(255,255,255,.85)}
.struct-list{margin:0;padding-left:18px;color:rgba(255,255,255,.82);line-height:1.45}
.flow{display:flex;flex-direction:column;gap:10px}
.flow-node{border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px 12px;background:rgba(0,0,0,.18);display:flex;justify-content:space-between;gap:10px;align-items:center}
.flow-node .name{font-weight:800}
.flow-node .tag{font-size:12px;color:rgba(255,255,255,.65)}
.flow-arrow{height:16px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35)}
.flow-arrow:before{content:"↓";font-size:16px}
.struct-hint{color:rgba(255,255,255,.65);font-size:12px;line-height:1.35;margin-top:8px}
