/* SOLLERTIA Portal Cliente v2.0 - estilos frontend
   Paleta: navy #0B2545, blue #2563EB, gold #F2C200, neutral #f4f7f8.
   Pensado para coexistir con el theme Porto sin pelearse con sus reglas. */

.sol-portal{
  --sol-navy:#0B2545;
  --sol-navy-2:#13335f;
  --sol-blue:#2563EB;
  --sol-gold:#F2C200;
  --sol-bg:#f4f7f8;
  --sol-line:#d9e2e7;
  --sol-ink:#13232b;
  --sol-muted:#5b6478;
  --sol-bad:#b42318;
  --sol-ok:#047857;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  color:var(--sol-ink);
  max-width:1100px;
  margin:0 auto;
  padding:24px 16px 64px;
  box-sizing:border-box;
}
.sol-portal *,
.sol-portal *::before,
.sol-portal *::after{box-sizing:border-box}

.sol-header{text-align:center;margin-bottom:28px}
.sol-logo{width:96px;height:auto;display:block;margin:0 auto 12px;border-radius:14px;background:#000;padding:6px}
.sol-title{font-size:26px;font-weight:800;color:var(--sol-navy);margin:0 0 6px;letter-spacing:-.01em}
.sol-subtitle{font-size:14px;color:var(--sol-muted);max-width:680px;margin:0 auto;line-height:1.5}

.sol-step-title{font-size:14px;font-weight:700;color:var(--sol-navy);text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px;text-align:center}

/* Grid de tarjetas de nicho (6 cards en 3x2) */
.sol-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:16px}
@media (max-width: 900px){.sol-grid{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media (max-width: 560px){.sol-grid{grid-template-columns:1fr}}

.sol-card{
  background:#fff;border:1px solid var(--sol-line);border-radius:14px;
  padding:20px;text-align:left;cursor:pointer;display:flex;flex-direction:column;
  gap:8px;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  font:inherit;color:inherit;width:100%;
}
.sol-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(11,37,69,.10);border-color:var(--sol-blue)}
.sol-card:focus-visible{outline:3px solid var(--sol-gold);outline-offset:2px}

.sol-card-icon{
  width:48px;height:48px;border-radius:12px;
  margin-bottom:6px;position:relative;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:900;font-family:Arial,sans-serif;
}
/* Iconos por nicho - paleta suave para diferenciar visualmente */
.sol-icon-ins{background:#E6F1FB;color:#0C447C}
.sol-icon-ins::after{content:"\2714"}                              /* check */
.sol-icon-pru{background:#FAEEDA;color:#854F0B}
.sol-icon-pru::after{content:"\26A1"}                              /* rayo */
.sol-icon-lab{background:#E1F5EE;color:#085041}
.sol-icon-lab::after{content:"\2697";font-size:26px}               /* alambique */
.sol-icon-enr{background:#EAF3DE;color:#27500A}
.sol-icon-enr::after{content:"\2600";font-size:26px}               /* sol */
.sol-icon-con{background:#F1EFE8;color:#444441}
.sol-icon-con::after{content:"\1F3D7";font-size:24px}              /* construccion */
.sol-icon-dis{background:#EEEDFE;color:#3C3489}
.sol-icon-dis::after{content:"\270F";font-size:22px}               /* lapiz */

.sol-card-title{font-size:15px;font-weight:800;color:var(--sol-navy);line-height:1.3}
.sol-card-desc{font-size:13px;color:var(--sol-muted);line-height:1.5;flex:1}
.sol-card-prefix{font-size:11px;color:#9aa2b1;font-family:ui-monospace,Consolas,monospace;letter-spacing:.02em;margin-top:8px}

/* Paso formulario / drill-down */
.sol-step-form{background:#fff;border:1px solid var(--sol-line);border-radius:14px;padding:22px 24px}
.sol-back-btn{background:transparent;border:0;color:var(--sol-navy);font-weight:700;font-size:12px;cursor:pointer;padding:6px 0;margin-bottom:10px}
.sol-back-btn:hover{color:var(--sol-blue)}

.sol-bread{font-size:12px;color:var(--sol-muted);margin-bottom:8px}
.sol-bread-root{color:var(--sol-muted)}
.sol-bread-sep{margin:0 6px;color:var(--sol-line)}
.sol-bread strong{color:var(--sol-navy);font-weight:700}

.sol-nicho-title{font-size:22px;font-weight:800;color:var(--sol-navy);margin:0 0 6px;line-height:1.25}
.sol-nicho-desc{font-size:14px;color:var(--sol-muted);margin:0 0 18px;line-height:1.55;max-width:780px}

/* Tipo de cliente (solo LAB) */
.sol-tipo-cliente{background:#E1F5EE;border-left:4px solid #0F6E56;border-radius:0 10px 10px 0;padding:14px 16px;margin-bottom:18px}
.sol-tipo-aviso{font-size:12px;color:#04342C;line-height:1.55;margin-bottom:10px}
.sol-tipo-label{font-size:12px;font-weight:700;color:#04342C;text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:8px}
.sol-tipo-options{display:flex;gap:14px;flex-wrap:wrap}
.sol-tipo-opt{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#04342C;font-weight:500;cursor:pointer}
.sol-tipo-opt input[type="radio"]{accent-color:#0F6E56}

/* Chips de sub-servicio */
.sol-subservicios-wrap{margin-bottom:18px}
.sol-subs-label{font-size:12px;font-weight:700;color:var(--sol-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px}
.sol-chips{display:flex;flex-wrap:wrap;gap:8px}
.sol-chip{
  font-size:13px;padding:7px 14px;border-radius:18px;
  background:#fafbfd;border:1px solid var(--sol-line);
  cursor:pointer;color:var(--sol-ink);font-weight:500;
  transition:background .12s ease,border-color .12s ease,color .12s ease;
}
.sol-chip:hover{border-color:var(--sol-blue);color:var(--sol-blue)}
.sol-chip.sol-chip-sel{background:var(--sol-navy);border-color:var(--sol-navy);color:#fff}

.sol-fieldset{border:1px solid var(--sol-line);border-radius:10px;padding:14px 16px 8px;margin-bottom:14px}
.sol-fieldset legend{font-size:11px;font-weight:800;color:var(--sol-navy);text-transform:uppercase;letter-spacing:.05em;padding:0 8px;background:#fff}
.sol-fieldset-legal{background:#fafbfd}

.sol-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.sol-row > label,.sol-row > div{display:block}
.sol-row label.sol-full,.sol-row > .sol-full{grid-column:1 / -1}
.sol-row-checks{grid-template-columns:1fr;gap:6px}
@media (max-width: 640px){.sol-row{grid-template-columns:1fr}}

.sol-portal label{font-size:12px;font-weight:700;color:#33444d;display:block;margin-bottom:4px}
.sol-portal input[type="text"],
.sol-portal input[type="email"],
.sol-portal input[type="tel"],
.sol-portal input[type="number"],
.sol-portal input[type="date"],
.sol-portal select,
.sol-portal textarea{
  width:100%;border:1px solid var(--sol-line);border-radius:8px;padding:9px 10px;
  font:inherit;font-weight:400;font-size:13px;color:var(--sol-ink);background:#fff;
}
.sol-portal textarea{resize:vertical;min-height:96px}
.sol-portal input:focus,.sol-portal select:focus,.sol-portal textarea:focus{outline:2px solid var(--sol-blue);outline-offset:0;border-color:var(--sol-blue)}

.sol-check{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--sol-ink);font-weight:500;line-height:1.5;padding:6px 0;cursor:pointer}
.sol-check input[type="checkbox"]{margin-top:2px;width:16px;height:16px;flex-shrink:0;accent-color:var(--sol-blue)}
.sol-check-legal{align-items:flex-start;flex-wrap:wrap}
.sol-check-legal span{flex:1 1 auto;min-width:200px}
.sol-modal-link{font-size:12px;color:var(--sol-blue);text-decoration:underline;flex-basis:100%;margin-left:24px;cursor:pointer;background:transparent;border:0;padding:0;font:inherit}
.sol-modal-link:hover{color:var(--sol-navy)}

.sol-captcha{display:flex;justify-content:center;margin:14px 0}

.sol-actions{display:flex;justify-content:flex-end;margin-top:18px;gap:10px}
.sol-btn{border:0;border-radius:10px;padding:12px 22px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;transition:background .15s ease}
.sol-btn-primary{background:var(--sol-navy);color:#fff}
.sol-btn-primary:hover{background:var(--sol-navy-2)}
.sol-btn-primary:disabled{opacity:.6;cursor:not-allowed}

.sol-form-message{margin-top:14px;padding:0 4px;font-size:13px;min-height:22px}
.sol-form-message.error{color:var(--sol-bad);font-weight:700}
.sol-form-message.ok{color:var(--sol-ok);font-weight:700}

/* Paso de exito */
.sol-step-success{background:#fff;border:1px solid var(--sol-line);border-radius:14px;padding:36px 24px;text-align:center;margin-top:6px}
.sol-success-icon{width:72px;height:72px;border-radius:50%;background:#dcfce7;color:#15803d;font-size:34px;font-weight:900;line-height:72px;margin:0 auto 14px}
.sol-step-success h3{color:var(--sol-navy);font-size:22px;margin:0 0 8px}
.sol-codigo-box{margin:18px auto;padding:14px 24px;background:#0b2545;color:#fff;border-radius:10px;display:inline-block;font-size:22px;font-weight:800;letter-spacing:.04em;font-family:ui-monospace,Consolas,Menlo,monospace}
.sol-success-next{font-size:13px;color:var(--sol-muted);max-width:540px;margin:14px auto 0;line-height:1.5}

/* Modales legales */
.sol-modal{position:fixed;inset:0;background:rgba(11,37,69,.65);z-index:99999;display:flex;align-items:center;justify-content:center;padding:20px}
.sol-modal[hidden]{display:none}
.sol-modal-content{background:#fff;max-width:760px;width:100%;max-height:84vh;border-radius:14px;padding:24px 28px;overflow-y:auto;position:relative;box-shadow:0 24px 48px rgba(0,0,0,.30)}
.sol-modal-content h3{margin:0 0 14px;color:var(--sol-navy);font-size:20px}
.sol-modal-close{position:absolute;top:14px;right:18px;background:transparent;border:0;font-size:28px;line-height:1;color:var(--sol-muted);cursor:pointer}
.sol-modal-close:hover{color:var(--sol-navy)}
.sol-modal-body{font-size:13px;color:var(--sol-ink);line-height:1.6}
.sol-modal-body p{margin:0 0 10px}
.sol-modal-body ol{padding-left:22px;margin:0 0 12px}
.sol-modal-body li{margin-bottom:8px}
.sol-modal-body strong{color:var(--sol-navy)}
