/* ============================================================
   Solarfam · Hub de Ofertas — prototipo (MARCA REAL solarfam.com)
   Azul #608ccf · navy #012a66 · acento naranja/rojo del isotipo
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --brand-navy:#012a66;
  --brand-blue:#608ccf;
  --brand-orange:#F2741A;
  --brand-red:#E5322B;

  --color-primary:#012a66;
  --color-primary-d:#001b45;
  --color-primary-soft:#E6ECF6;
  --color-secondary:#F2741A;
  --color-secondary-soft:#FCEADD;
  --color-bg:#F2F4F7;
  --color-surface:#FFFFFF;
  --color-text:#1A1A1A;
  --color-text-muted:#5B6B7B;
  --color-border:#E4E8EE;
  --color-border-strong:#CBD3DE;
  --color-success:#1FA971;
  --color-success-soft:#E2F4EC;
  --color-warning:#E07B12;
  --color-warning-soft:#FCEEDC;
  --color-danger:#E5322B;
  --color-danger-soft:#FBE5E3;

  --state-0:#5B6B7B; --state-0-soft:#EDF0F3;
  --state-1:#3F72BE; --state-1-soft:#E8EFF8;
  --state-2:#1FA971; --state-2-soft:#E2F4EC;
  --state-3:#012a66; --state-3-soft:#E2E8F2;

  --radius:10px; --radius-sm:7px; --radius-lg:14px;
  --shadow:0 1px 3px rgba(15,36,56,.08),0 1px 2px rgba(15,36,56,.04);
  --shadow-md:0 6px 20px rgba(15,36,56,.10);
  --sidebar-w:262px;
  --mono:ui-monospace,"SF Mono",Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--color-bg);
  color:var(--color-text);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.ic{width:18px;height:18px;flex:0 0 auto}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  background:var(--color-surface);border-right:1px solid var(--color-border);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.brand{padding:20px 20px 14px;border-bottom:1px solid var(--color-border)}
.lockup{display:flex;align-items:center;gap:10px}
.logo{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;overflow:hidden}
.logo img{width:100%;height:100%;object-fit:contain}
.logo svg{width:24px;height:24px}
.brand .wordmark{height:25px;width:auto;display:block}
.brand .name{font-weight:800;font-size:16px;letter-spacing:-.02em}
.brand .tag{display:block;font-size:11px;color:var(--color-text-muted);font-weight:700;letter-spacing:.02em;margin-top:7px}

.nav{padding:12px 12px 0;overflow-y:auto;flex:1}
.navlbl{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--color-text-muted);padding:14px 10px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--color-text);font-weight:600;font-size:14px;margin-bottom:2px;cursor:pointer;
  transition:background .12s,color .12s}
.nav a .ic{color:var(--color-text-muted)}
.nav a:hover{background:var(--color-bg)}
.nav a.active{background:var(--color-primary-soft);color:var(--color-primary-d)}
.nav a.active .ic{color:var(--color-primary)}
.nav a.soon{opacity:.55;cursor:default}
.nav a.soon:hover{background:transparent}
.soonbadge{margin-left:auto;font-size:9.5px;font-weight:700;background:var(--color-bg);
  color:var(--color-text-muted);padding:2px 6px;border-radius:20px;border:1px solid var(--color-border)}
.sidefoot{padding:14px 18px;border-top:1px solid var(--color-border);font-size:12px;color:var(--color-text-muted)}
.sidefoot .row{display:flex;align-items:center;gap:7px;font-weight:600}
.dot{width:7px;height:7px;border-radius:50%;background:var(--color-secondary);box-shadow:0 0 0 3px var(--color-secondary-soft)}
.sidefoot .scale{margin-top:5px;line-height:1.4}

/* ---------- Main / topbar ---------- */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;padding:16px 28px;background:var(--color-surface);
  border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:20}
.topbar h1{font-size:18px;font-weight:800;letter-spacing:-.02em;margin:0}
.topbar .sub{font-size:12.5px;color:var(--color-text-muted);font-weight:600;margin-top:1px}
.topspacer{flex:1}
.search{display:flex;align-items:center;gap:8px;background:var(--color-bg);border:1px solid var(--color-border);
  padding:8px 12px;border-radius:var(--radius);color:var(--color-text-muted);font-size:13px;min-width:230px}
.search input{border:0;background:transparent;outline:0;font:inherit;color:var(--color-text);width:100%}

.rolepick{display:flex;align-items:center;gap:8px}
.rolepick select{font:inherit;font-weight:700;font-size:13px;color:var(--color-text);
  border:1px solid var(--color-border-strong);background:var(--color-surface);
  padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer}
.user{display:flex;align-items:center;gap:9px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--color-primary-soft);color:var(--color-primary-d);
  display:grid;place-items:center;font-weight:800;font-size:13px}
.user .meta{font-size:12.5px;line-height:1.25}
.user .meta b{font-size:13px}
.user .meta span{color:var(--color-text-muted);font-weight:600}

.content{padding:24px 28px 48px;max-width:1180px}

/* ---------- Generic bits ---------- */
.pagehead{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.pagehead .grow{flex:1}
.pagehead h2{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 3px}
.pagehead p{margin:0;color:var(--color-text-muted);font-size:14px}

.btn{display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:700;font-size:14px;
  padding:10px 16px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:.12s}
.btn .ic{width:17px;height:17px}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-primary:hover{background:var(--color-primary-d)}
.btn-ghost{background:var(--color-surface);border-color:var(--color-border-strong);color:var(--color-text)}
.btn-ghost:hover{background:var(--color-bg)}
.btn-warn{background:var(--color-secondary);color:#3a2a06}
.btn-warn:hover{filter:brightness(.96)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-block{width:100%;justify-content:center}

.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);
  box-shadow:var(--shadow)}
.card-pad{padding:20px}
.card h3{margin:0 0 2px;font-size:15.5px;font-weight:800;letter-spacing:-.01em}
.card .hint{color:var(--color-text-muted);font-size:13px;margin:0 0 14px}
.cardhead{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--color-border)}
.cardhead h3{margin:0}
.cardhead .ic{color:var(--color-primary)}
.cardhead .grow{flex:1}

.grid{display:grid;gap:18px}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1080px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:1fr}.g-2{grid-template-columns:1fr}}

/* KPI */
.kpi{padding:18px 20px}
.kpi .lbl{font-size:12.5px;color:var(--color-text-muted);font-weight:700;display:flex;align-items:center;gap:7px}
.kpi .lbl .ic{width:15px;height:15px}
.kpi .val{font-size:30px;font-weight:800;letter-spacing:-.03em;margin-top:6px}
.kpi .delta{font-size:12.5px;font-weight:700;margin-top:3px}
.up{color:var(--color-success)} .down{color:var(--color-danger)} .flat{color:var(--color-text-muted)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
  padding:3px 9px;border-radius:20px;white-space:nowrap}
.badge .bdot{width:7px;height:7px;border-radius:50%}
.st-0{background:var(--state-0-soft);color:var(--state-0)} .st-0 .bdot{background:var(--state-0)}
.st-1{background:var(--state-1-soft);color:var(--state-1)} .st-1 .bdot{background:var(--state-1)}
.st-2{background:var(--state-2-soft);color:var(--state-2)} .st-2 .bdot{background:var(--state-2)}
.st-3{background:var(--state-3-soft);color:var(--state-3)} .st-3 .bdot{background:var(--state-3)}
.role-badge{font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;
  background:var(--color-primary-soft);color:var(--color-primary-d);letter-spacing:.02em}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;
  background:var(--color-bg);border:1px solid var(--color-border);padding:5px 10px;border-radius:20px}

/* Tables */
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--color-text-muted);padding:11px 16px;border-bottom:1px solid var(--color-border)}
.tbl td{padding:13px 16px;border-bottom:1px solid var(--color-border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tbody tr{cursor:pointer;transition:background .1s}
.tbl tbody tr:hover{background:var(--color-bg)}
.tbl .num{font-family:var(--mono);text-align:right;font-weight:600}
.tbl .ref{font-family:var(--mono);font-weight:700;color:var(--color-primary-d)}
.muted{color:var(--color-text-muted)}
.right{text-align:right}.center{text-align:center}
.strong{font-weight:800}

/* Forms */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}
.field .req{color:var(--color-danger)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:14px;
  padding:10px 12px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);
  background:var(--color-surface);color:var(--color-text);outline:0;transition:.12s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-primary);
  box-shadow:0 0 0 3px var(--color-primary-soft)}
.field .help{font-size:12px;color:var(--color-text-muted);margin-top:5px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:720px){.frow{grid-template-columns:1fr}}
.dropzone{border:1.5px dashed var(--color-border-strong);border-radius:var(--radius);
  padding:22px;text-align:center;color:var(--color-text-muted);background:var(--color-bg);font-size:13.5px}
.dropzone .ic{width:26px;height:26px;color:var(--color-primary);margin:0 auto 6px}

/* Stepper */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:22px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:var(--color-text-muted)}
.step .num{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:12.5px;
  background:var(--color-surface);border:1.5px solid var(--color-border-strong);color:var(--color-text-muted)}
.step.done .num{background:var(--color-success);border-color:var(--color-success);color:#fff}
.step.active{color:var(--color-primary-d)}
.step.active .num{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.step-line{flex:1;height:2px;background:var(--color-border);margin:0 12px;min-width:24px}
.step-line.done{background:var(--color-success)}

/* Product type selector */
.ptypes{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:720px){.ptypes{grid-template-columns:1fr}}
.ptype{border:1.5px solid var(--color-border);border-radius:var(--radius);padding:16px;cursor:pointer;
  background:var(--color-surface);transition:.12s}
.ptype:hover{border-color:var(--color-primary)}
.ptype.sel{border-color:var(--color-primary);background:var(--color-primary-soft)}
.ptype .ic{width:24px;height:24px;color:var(--color-primary)}
.ptype b{display:block;margin:8px 0 2px;font-size:15px}
.ptype span{font-size:12.5px;color:var(--color-text-muted)}

/* Trace links — the differentiator */
.trace{position:relative;font-weight:700;color:var(--color-text);cursor:pointer;
  border-bottom:2px dotted var(--color-secondary);padding-bottom:1px}
.trace:hover{color:var(--color-primary-d)}
.trace::after{content:"";display:inline-block;width:6px;height:6px;margin-left:3px;border-radius:50%;
  background:var(--color-secondary);vertical-align:middle}

/* Trace panel */
.tracepanel{position:fixed;top:0;right:0;width:380px;max-width:92vw;height:100vh;background:var(--color-surface);
  border-left:1px solid var(--color-border);box-shadow:var(--shadow-md);z-index:60;
  transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column}
.tracepanel.open{transform:translateX(0)}
.tp-head{padding:18px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:10px}
.tp-head .ic{color:var(--color-secondary)}
.tp-head h4{margin:0;font-size:15px;font-weight:800}
.tp-head .close{margin-left:auto;cursor:pointer;color:var(--color-text-muted);background:var(--color-bg);
  border:1px solid var(--color-border);border-radius:7px;width:30px;height:30px;display:grid;place-items:center}
.tp-body{padding:20px;overflow-y:auto}
.tp-val{font-size:26px;font-weight:800;letter-spacing:-.02em;font-family:var(--mono)}
.tp-field{font-size:13px;color:var(--color-text-muted);font-weight:700;margin-bottom:14px}
.tp-trail{list-style:none;margin:0;padding:0;position:relative}
.tp-trail li{position:relative;padding:0 0 18px 26px}
.tp-trail li::before{content:"";position:absolute;left:7px;top:4px;width:11px;height:11px;border-radius:50%;
  background:var(--color-surface);border:2.5px solid var(--color-primary)}
.tp-trail li::after{content:"";position:absolute;left:12px;top:15px;bottom:-2px;width:2px;background:var(--color-border)}
.tp-trail li:last-child::after{display:none}
.tp-trail .t-src{font-weight:800;font-size:13.5px}
.tp-trail .t-meta{font-size:12.5px;color:var(--color-text-muted);margin-top:2px}
.scrim{position:fixed;inset:0;background:rgba(15,36,56,.28);z-index:55;opacity:0;pointer-events:none;transition:.2s}
.scrim.open{opacity:1;pointer-events:auto}

/* Doc preview (oferta) */
.doc{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:40px 46px;max-width:760px}
.doc .dochead{display:flex;align-items:flex-start;gap:16px;border-bottom:2px solid var(--color-primary);padding-bottom:18px;margin-bottom:22px}
.doc .dochead .grow{flex:1}
.doc h2.dt{font-size:24px;font-weight:800;margin:0 0 2px;letter-spacing:-.02em}
.doc .dmeta{font-size:13px;color:var(--color-text-muted);font-weight:600}
.doc h3.sec{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary-d);
  margin:26px 0 12px;display:flex;align-items:center;gap:8px}
.doc p{font-size:14px;line-height:1.65;margin:0 0 12px}
.specs{width:100%;border-collapse:collapse;font-size:13.5px}
.specs td{padding:10px 0;border-bottom:1px solid var(--color-border)}
.specs td:last-child{text-align:right;font-family:var(--mono);font-weight:700}
.totalbar{display:flex;justify-content:space-between;align-items:center;margin-top:16px;
  background:var(--color-primary-soft);border-radius:var(--radius);padding:16px 20px}
.totalbar .lbl{font-weight:800;font-size:15px}
.totalbar .amt{font-family:var(--mono);font-weight:800;font-size:24px;color:var(--color-primary-d)}

/* Alert / note */
.note{display:flex;gap:11px;padding:13px 16px;border-radius:var(--radius);font-size:13.5px;align-items:flex-start}
.note .ic{flex:0 0 auto;margin-top:1px}
.note-info{background:var(--color-primary-soft);color:var(--color-primary-d)}
.note-warn{background:var(--color-warning-soft);color:#8a5a06}
.note-ok{background:var(--color-success-soft);color:#0d6b46}
.note b{font-weight:800}

/* Admin template editor */
.editor{display:grid;grid-template-columns:230px 1fr;gap:0;border:1px solid var(--color-border);
  border-radius:var(--radius);overflow:hidden;background:var(--color-surface)}
@media(max-width:820px){.editor{grid-template-columns:1fr}}
.editor .blocks{border-right:1px solid var(--color-border);padding:12px;background:var(--color-bg)}
.blk{display:flex;align-items:center;gap:9px;padding:10px 11px;border-radius:var(--radius-sm);font-size:13.5px;
  font-weight:600;cursor:grab;background:var(--color-surface);border:1px solid var(--color-border);margin-bottom:8px}
.blk .ic{color:var(--color-text-muted);width:15px}
.blk .h{margin-left:auto;color:var(--color-border-strong)}
.canvas{padding:20px;min-height:320px}
.cblock{border:1.5px dashed var(--color-border-strong);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:12px;position:relative}
.cblock.sel{border-style:solid;border-color:var(--color-primary);background:var(--color-primary-soft)}
.cblock .tag{position:absolute;top:-9px;left:12px;background:var(--color-surface);font-size:10.5px;font-weight:700;
  color:var(--color-text-muted);padding:0 6px;text-transform:uppercase;letter-spacing:.04em}

/* Tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:20px}
.tab{padding:10px 14px;font-weight:700;font-size:13.5px;color:var(--color-text-muted);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.active{color:var(--color-primary-d);border-bottom-color:var(--color-primary)}

/* Login */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}
@media(max-width:880px){.login-wrap{grid-template-columns:1fr}.login-art{display:none}}
.login-art{background:linear-gradient(155deg,#012a66,#063a82 52%,#608ccf);color:#fff;
  padding:54px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-art::before{content:"";position:absolute;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(242,116,26,.42),rgba(229,50,43,.18) 45%,transparent 72%);top:-100px;right:-80px}
.login-art .brandlogo{height:34px;width:auto}
.login-art .biglogo{display:flex;align-items:center;gap:12px;position:relative}
.login-art .biglogo .logo{width:44px;height:44px}
.login-art .biglogo .name{font-size:22px;font-weight:800}
.login-art h2{font-size:32px;font-weight:800;letter-spacing:-.03em;line-height:1.18;margin:0 0 14px;position:relative}
.login-art p{font-size:15px;opacity:.92;line-height:1.6;max-width:420px;position:relative}
.login-art .feats{position:relative;display:flex;flex-direction:column;gap:13px;margin-top:6px}
.login-art .feat{display:flex;align-items:center;gap:11px;font-size:14.5px;font-weight:600}
.login-art .feat .ic{color:var(--color-secondary)}
.login-art .foot{font-size:12.5px;opacity:.75;position:relative}
.login-form{display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:380px}
.login-card h1{font-size:24px;font-weight:800;margin:0 0 4px;letter-spacing:-.02em}
.login-card .sub{color:var(--color-text-muted);margin:0 0 26px;font-size:14px}
.demo-note{margin-top:18px;font-size:12.5px;color:var(--color-text-muted);background:var(--color-bg);
  border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:11px 13px}

/* Proto ribbon */
.ribbon{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:80;
  background:var(--color-text);color:#fff;font-size:12px;font-weight:600;padding:7px 15px;border-radius:30px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:8px;opacity:.92}
.ribbon .bdot{width:7px;height:7px;border-radius:50%;background:var(--color-secondary)}
