﻿/* public/css/welcome_v2.css - FinanzApp Welcome (v5) 
   - Mantiene el diseño actual y lo propaga a los partials: nav, stepper, quiz, results, sales, footer.
*/

/* Fuente */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800;900&display=swap');

:root{
  --primary:#6366f1;
  --primary-dark:#4338ca;
  --accent:#ec4899;
  --accent-yellow:#f59e0b;

  --bg-body:#f8fafc;
  --bg-surface:#ffffff;
  --bg-surface-2:#f1f5f9;

  --text-main:#1e293b;
  --text-muted:#64748b;

  --border:rgba(15,23,42,.10);
  --border-strong:rgba(15,23,42,.16);

  --radius-xl:32px;
  --radius-lg:20px;
  --radius-md:14px;
  --radius-sm:12px;

  --shadow-float:0 20px 40px -10px rgba(99,102,241,.15);
  --shadow-card:0 10px 30px -5px rgba(0,0,0,.06);
  --shadow-soft:0 8px 20px rgba(15,23,42,.08);

  --ring:0 0 0 4px rgba(99,102,241,.25);
  --ring-accent:0 0 0 4px rgba(236,72,153,.20);

  /* Compatibilidad con inline vars en partials */
  --p-primary:var(--primary);
}

/* ========= RESET / BASE ========= */
*,
*::before,
*::after{ box-sizing:border-box; }

html{ -webkit-text-size-adjust:100%; }

body.welcome-body{
  background:var(--bg-body);
  background-image:
    radial-gradient(at 0% 0%, rgba(99,102,241,.08) 0px, transparent 55%),
    radial-gradient(at 100% 0%, rgba(236,72,153,.08) 0px, transparent 55%),
    radial-gradient(at 60% 120%, rgba(245,158,11,.06) 0px, transparent 55%);
  color:var(--text-main);
  font-family:'Outfit',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  margin:0;
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
}

img, video{ max-width:100%; height:auto; display:block; }

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:none; }

button{
  font:inherit;
  color:inherit;
  border:none;
  background:transparent;
  padding:0;
  cursor:pointer;
}

button:disabled{ cursor:not-allowed; opacity:.65; }

:focus{ outline:none; }
:focus-visible{ box-shadow:var(--ring); border-radius:12px; }

[hidden]{ display:none !important; }

/* ========= LAYOUT ========= */
.welcome-container{
  width:100%;
  max-width:1100px;
  margin:0 auto;
  padding:20px;
  display:flex;
  flex-direction:column;
  align-items:center;
}

.welcome-section{
  width:100%;
  max-width:1100px;
  margin:28px auto;
  padding:0 20px;
}

@media (max-width:768px){
  .welcome-container{ padding:15px; }
  .welcome-section{ padding:0 15px; margin:22px auto; }
}

/* ========= TOPBAR / NAV ========= */
.welcome-topbar{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 0 28px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.brand-mark{
  width:44px;
  height:44px;
  border-radius:14px;
  background:#fff;
  box-shadow:0 12px 24px rgba(99,102,241,.25);
  position:relative;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.brand-mark::after{
  display:none;
}

.brand-logo{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:6px;
}

.brand-text{ min-width:0; }
.brand-title{
  font-size:24px;
  font-weight:900;
  letter-spacing:-1px;
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.brand-subtitle{
  color:var(--text-muted);
  font-size:.95rem;
  margin-top:-2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.top-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.top-link{
  color:var(--text-muted);
  font-weight:700;
  font-size:.98rem;
  padding:10px 12px;
  border-radius:12px;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
.top-link:hover{
  color:var(--text-main);
  background:rgba(99,102,241,.08);
  transform:translateY(-1px);
}

.top-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 14px;
  border-radius:14px;
  font-weight:800;
  font-size:.98rem;
  color:#fff;
  background:var(--text-main);
  box-shadow:0 14px 28px rgba(30,41,59,.18);
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.top-cta:hover{
  background:var(--primary);
  box-shadow:0 18px 38px rgba(99,102,241,.35);
  transform:translateY(-2px);
}

@media (max-width:768px){
  .welcome-topbar{ padding:14px 0 18px; }
  .brand-mark{ width:40px; height:40px; border-radius:13px; }
  .brand-title{ font-size:22px; }
  .brand-subtitle, .top-link{ display:none; }
  .top-actions{ gap:8px; }
  .top-link--mobile{ display:inline-flex; }
}

/* ========= HERO ========= */
.hero-wrapper{
  text-align:center;
  max-width:820px;
  margin:0 auto 38px;
  animation:fadeInScale .8s ease-out;
}

.pain-alert{
  background:#fff1f2;
  border:2px solid #fecdd3;
  color:#be123c;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 22px;
  border-radius:50px;
  font-weight:800;
  font-size:1.05rem;
  margin:0 auto 22px;
  box-shadow:0 4px 15px rgba(190,18,60,.10);
  transform:rotate(-.7deg);
}

.hero-title{
  font-size:clamp(2.2rem, 3.2vw + 1.2rem, 3.6rem);
  line-height:1.08;
  font-weight:900;
  margin:0 0 16px;
  color:var(--text-main);
  letter-spacing:-.02em;
}

.hero-title span.highlight{
  color:var(--primary);
  position:relative;
  white-space:nowrap;
}

.hero-title span.highlight::after{
  content:'';
  position:absolute;
  bottom:6px;
  left:0;
  width:100%;
  height:12px;
  background:rgba(99,102,241,.18);
  z-index:-1;
  border-radius:8px;
}

.hero-subtitle{
  font-size:clamp(1.05rem, .55vw + 1rem, 1.45rem);
  color:var(--text-muted);
  margin:0 auto 30px;
  max-width:640px;
}

.cta-big{
  background:var(--text-main);
  color:#fff;
  font-size:1.18rem;
  font-weight:900;
  padding:18px 34px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:12px;
  transition:transform .25s cubic-bezier(.34, 1.56, .64, 1),
             background .2s ease,
             box-shadow .2s ease;
  box-shadow:0 20px 40px -10px rgba(30,41,59,.45);
}
.cta-big:hover{
  transform:translateY(-4px) scale(1.03);
  background:var(--primary);
  box-shadow:0 25px 50px -12px rgba(99,102,241,.55);
}

@media (max-width:768px){
  .pain-alert{ font-size:.95rem; padding:10px 14px; width:100%; justify-content:center; }
}

/* ========= BUTTONS (reutilizables) ========= */
.btn-primary,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:16px;
  padding:14px 16px;
  font-weight:900;
  letter-spacing:-.01em;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
  text-decoration:none;
  width:auto;
}

.btn-primary{
  background:linear-gradient(135deg, var(--text-main) 0%, #0f172a 100%);
  color:#fff;
  box-shadow:0 18px 36px rgba(15,23,42,.22);
}
.btn-primary:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  box-shadow:0 18px 36px rgba(99,102,241,.30);
}
.btn-primary:focus-visible{ box-shadow:var(--ring-accent); }

.btn-ghost{
  background:rgba(255,255,255,.65);
  border:1px solid var(--border);
  color:var(--text-main);
  box-shadow:0 10px 25px rgba(15,23,42,.06);
  backdrop-filter: blur(10px);
}
.btn-ghost:hover{
  transform:translateY(-2px);
  border-color:rgba(99,102,241,.28);
  box-shadow:0 14px 30px rgba(99,102,241,.12);
}

.btn-small{
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
  font-size:.95rem;
}

.btn-hero{
  border-radius:999px;
  padding:16px 18px;
}

/* ========= STEPPER ========= */
.welcome-stepper{
  width:100%;
  max-width:1100px;
  margin:8px auto 6px;
  padding:0 20px;
}
.stepper{
  width:100%;
  display:flex;
  gap:10px;
  padding:10px;
  border-radius:22px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:var(--shadow-card);
  backdrop-filter: blur(12px);
}

.stepper-item{
  flex:1 1 0;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:18px;
  background:transparent;
  text-align:left;
  min-width:0;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.stepper-item:hover{
  background:rgba(99,102,241,.08);
  transform:translateY(-1px);
}

.stepper-num{
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  font-weight:900;
  color:var(--primary);
  background:rgba(99,102,241,.10);
  border:1px solid rgba(99,102,241,.18);
  flex:0 0 auto;
}

.stepper-text{ min-width:0; }
.stepper-title{
  display:block;
  font-weight:900;
  letter-spacing:-.01em;
  font-size:1.02rem;
  color:var(--text-main);
  line-height:1.15;
}
.stepper-sub{
  display:block;
  font-size:.92rem;
  color:var(--text-muted);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.stepper-item.is-active{
  background:linear-gradient(135deg, rgba(99,102,241,.16) 0%, rgba(236,72,153,.12) 100%);
  box-shadow:0 18px 36px rgba(99,102,241,.12);
}
.stepper-item.is-active .stepper-num{
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  border-color:transparent;
  color:#fff;
}
.stepper-item.is-active .stepper-sub{ color:rgba(30,41,59,.80); }

@media (max-width:768px){
  .welcome-stepper{ padding:0 15px; }
  .stepper{ flex-direction:column; }
  .stepper-item{ padding:12px 12px; }
  .stepper-sub{ white-space:normal; }
}

/* ========= QUIZ ========= */
.quiz-shell{
  background:var(--bg-surface);
  width:100%;
  max-width:680px;
  padding:40px;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-float);
  border:1px solid rgba(255,255,255,.80);
  position:relative;
  margin:14px auto 0;
}

.quiz-progress{
  height:12px;
  background:#e2e8f0;
  border-radius:10px;
  overflow:hidden;
}
.quiz-progress-bar{
  height:100%;
  width:0%;
  background:linear-gradient(90deg, #ec4899, #8b5cf6);
  border-radius:10px;
  transition:width .4s ease;
}

.quiz-question-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin:10px 0 18px;
  padding:10px 12px;
  border-radius:16px;
  background:rgba(99,102,241,.06);
  border:1px solid rgba(99,102,241,.12);
}
.qqh-left{ display:flex; align-items:center; gap:10px; min-width:0; }
.qqh-title{
  font-weight:900;
  letter-spacing:-.01em;
  color:var(--text-main);
  font-size:.98rem;
}
.quiz-q-title{
  font-size:1.7rem;
  font-weight:900;
  text-align:center;
  margin:18px 0 22px;
  color:var(--text-main);
  letter-spacing:-.02em;
}
.quiz-options{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.quiz-opt{
  display:flex;
  align-items:center;
  gap:15px;
  width:100%;
  background:#fff;
  border:2px solid #f1f5f9;
  padding:18px 22px;
  border-radius:var(--radius-lg);
  font-size:1.12rem;
  font-weight:800;
  color:var(--text-main);
  text-align:left;
  transition:transform .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
  box-shadow:0 4px 10px rgba(0,0,0,.03);
}
.quiz-opt:hover{
  border-color:rgba(99,102,241,.55);
  background:#eff6ff;
  transform:translateY(-1px);
}
.quiz-opt.selected{
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  color:#fff;
  border-color:transparent;
  box-shadow:0 14px 28px rgba(99,102,241,.26);
}

.quiz-intro-card{
  background:linear-gradient(180deg, rgba(99,102,241,.06) 0%, rgba(236,72,153,.05) 100%);
  border:1px solid rgba(99,102,241,.12);
  border-radius:var(--radius-xl);
}
.quiz-intro-title{
  font-weight:900;
  letter-spacing:-.02em;
}
.quiz-intro-text{ color:var(--text-muted); }

.quiz-stage{ width:100%; }
.quiz-questions{ margin-top:10px; }

@media (max-width:768px){
  .quiz-shell{ padding:24px 20px; border-radius:26px; }
  .quiz-q-title{ font-size:1.35rem; margin:14px 0 18px; }
  .quiz-opt{ padding:14px 15px; font-size:1rem; border-radius:18px; }
}

/* ========= SECTION HEAD (reutilizable) ========= */
.section-head{
  width:100%;
  max-width:900px;
  margin:0 auto 18px;
}
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(236,72,153,.09);
  border:1px solid rgba(236,72,153,.14);
  color:#9f1239;
  font-weight:900;
  letter-spacing:-.01em;
  margin-bottom:10px;
}
.section-title{
  font-size:clamp(1.7rem, 1.3vw + 1.4rem, 2.3rem);
  margin:0 0 10px;
  line-height:1.15;
  letter-spacing:-.02em;
  font-weight:900;
}
.section-lead{
  margin:0;
  color:var(--text-muted);
  font-size:1.06rem;
}

/* ========= RESULTADOS ========= */
.result-shell{
  width:100%;
  max-width:900px;
  margin:0 auto;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(255,255,255,.62);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-float);
  overflow:hidden;
  backdrop-filter: blur(12px);
}

.result-banner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:26px 26px 22px;
  background:
    radial-gradient(at 0% 0%, rgba(99,102,241,.18) 0, transparent 60%),
    radial-gradient(at 100% 0%, rgba(236,72,153,.14) 0, transparent 60%),
    linear-gradient(135deg, rgba(15,23,42,.92) 0%, rgba(30,41,59,.92) 100%);
  color:#fff;
}

.rb-k{
  opacity:.92;
  font-weight:800;
  letter-spacing:-.01em;
  margin-bottom:6px;
}
.rb-title{
  font-weight:900;
  font-size:clamp(1.9rem, 1.6vw + 1.5rem, 2.6rem);
  line-height:1.05;
  margin:0;
  background:linear-gradient(90deg, #a5b4fc, #fbcfe8);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.archetype-grid{
  padding:22px;
}

.archetype-card{
  background:#fff;
  border-radius:var(--radius-xl);
  padding:32px;
  box-shadow:var(--shadow-card);
  text-align:left;
  border:2px solid #f1f5f9;
}

.ac-cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  margin-top:18px;
}
.ac-col{
  border-radius:18px;
  padding:18px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
}
.ac-block-title{
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 10px;
  font-size:1.15rem;
}
.ac-text{
  margin:0;
  color:var(--text-main);
}

@media (max-width:900px){
  .result-banner{ padding:22px 18px; }
  .archetype-grid{ padding:18px; }
  .archetype-card{ padding:22px; }
}
@media (max-width:768px){
  .ac-cols{ grid-template-columns:1fr; }
}

/* ========= LISTAS CON CHECK ========= */
.ul-check{
  list-style:none;
  padding:0;
  margin:12px 0 0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.li-check{
  position:relative;
  padding-left:28px;
  color:var(--text-main);
  font-weight:700;
}
.li-check::before{
  content:'✓';
  position:absolute;
  left:0;
  top:0;
  width:20px;
  height:20px;
  border-radius:8px;
  display:grid;
  place-items:center;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.22);
  color:#166534;
  font-weight:900;
  transform:translateY(1px);
}

/* ========= SALES (Carta + Oferta) ========= */
.sales-layout{
  display:grid;
  grid-template-columns: 1fr 380px;
  gap:22px;
  align-items:start;
}

.sales-letter{
  background:rgba(255,255,255,.70);
  border:1px solid rgba(255,255,255,.60);
  border-radius:var(--radius-xl);
  padding:26px;
  box-shadow:var(--shadow-card);
  backdrop-filter: blur(12px);
}

.sl-block + .sl-block{ margin-top:22px; }

.sl-title{
  margin:0 0 10px;
  font-size:1.35rem;
  font-weight:900;
  letter-spacing:-.02em;
}
.sl-text{
  margin:0;
  color:var(--text-main);
}

.sl-points{
  margin-top:16px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.sl-point{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  padding:14px 14px;
  box-shadow:0 6px 16px rgba(15,23,42,.06);
}
.sl-point-title{
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 6px;
}
.sl-point-text{
  color:var(--text-muted);
  margin:0;
  font-weight:600;
}

.trust-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.trust-item{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(99,102,241,.08);
  border:1px solid rgba(99,102,241,.12);
  font-weight:800;
  color:var(--text-main);
}
.trust-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  box-shadow:0 8px 16px rgba(99,102,241,.18);
}

.offer-panel{ position:relative; }
.offer-card{
  position:sticky;
  top:16px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.62);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-float);
  overflow:hidden;
  backdrop-filter: blur(12px);
}

.offer-ribbon{
  background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  color:#fff;
  padding:10px 16px;
  font-weight:900;
  letter-spacing:-.01em;
  text-align:center;
}

.offer-top{ padding:18px 18px 12px; }
.offer-kicker{
  font-weight:900;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.78rem;
}
.offer-sub{
  margin-top:6px;
  font-weight:900;
  font-size:1.25rem;
  letter-spacing:-.02em;
}
.offer-price{
  margin-top:12px;
  display:flex;
  align-items:baseline;
  gap:8px;
}
.offer-currency{
  font-weight:900;
  color:var(--text-muted);
}
.offer-amount{
  font-size:2.3rem;
  font-weight:900;
  letter-spacing:-.03em;
  line-height:1;
  background:linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.offer-mini{
  margin-top:10px;
  color:var(--text-muted);
  font-weight:700;
  font-size:.98rem;
}

.offer-list{
  padding:0 18px 16px;
}

.what-you-get{
  margin-top:14px;
  background:rgba(99,102,241,.06);
  border:1px solid rgba(99,102,241,.12);
  border-radius:18px;
  padding:14px;
}

.roadmap{
  margin-top:14px;
  padding:14px 18px 18px;
  border-top:1px dashed rgba(15,23,42,.14);
  background:rgba(15,23,42,.02);
}
.roadmap-title{
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 10px;
  color:var(--text-main);
}

.offer-cta{
  padding:0 18px 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.offer-btn{
  width:100%;
  border-radius:18px;
  padding:14px 16px;
}
.offer-btn--checkout{
  background:linear-gradient(135deg, #22c55e 0%, #16a34a 55%, #15803d 100%);
  box-shadow:0 18px 36px rgba(34, 197, 94, .35);
}
.offer-btn--checkout:hover{
  background:linear-gradient(135deg, #34d399 0%, #22c55e 55%, #16a34a 100%);
  box-shadow:0 20px 40px rgba(34, 197, 94, .45);
}
.offer-trust{
  padding:14px 18px 18px;
  border-top:1px solid rgba(15,23,42,.08);
  color:var(--text-muted);
  font-weight:700;
  font-size:.95rem;
}

/* Demo */
.demo-wrap{
  margin-top:18px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  padding:14px;
  box-shadow:0 8px 20px rgba(15,23,42,.07);
}
.demo-video{
  width:100%;
  aspect-ratio:16 / 9;
  border-radius:16px;
  overflow:hidden;
  background:#0b1220;
}
.demo-video iframe,
.demo-video video{
  width:100%;
  height:100%;
  border:0;
}
.demo-mini{
  margin-top:12px;
  color:var(--text-muted);
  font-weight:700;
  font-size:.98rem;
}

/* FAQ (details/summary) */
.faq{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.faq-item{
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 8px 20px rgba(15,23,42,.05);
}
.faq-q{
  list-style:none;
  padding:14px 14px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  cursor:pointer;
}
.faq-q::-webkit-details-marker{ display:none; }
.faq-q::after{
  content:'+';
  font-size:1.2rem;
  font-weight:900;
  color:var(--primary);
  line-height:1;
}
.faq-item[open] .faq-q::after{ content:'–'; color:var(--accent); }
.faq-a{
  padding:0 14px 14px;
  color:var(--text-muted);
  font-weight:650;
}

/* Side cards (si se usan) */
.offer-side,
.side-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  padding:14px;
  box-shadow:0 8px 20px rgba(15,23,42,.05);
}
.side-title{
  margin:0 0 8px;
  font-weight:900;
  letter-spacing:-.01em;
}
.side-text{
  margin:0;
  color:var(--text-muted);
  font-weight:650;
}
.side-actions{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.mp-status{
  margin-top:10px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(245,158,11,.10);
  border:1px solid rgba(245,158,11,.20);
  color:#92400e;
  font-weight:800;
}

/* Breakpoints Sales */
@media (max-width:980px){
  .sales-layout{ grid-template-columns:1fr; }
  .offer-card{ position:relative; top:auto; }
  .sl-points{ grid-template-columns:1fr; }
}

/* ========= FOOTER ========= */
.footer-mini{
  width:100%;
  max-width:1100px;
  margin:26px auto 34px;
  padding:0 20px;
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:center;
  color:var(--text-muted);
  font-weight:700;
  font-size:.95rem;
}
.footer-line{ opacity:.95; }

/* ========= ANIMACIONES ========= */
@keyframes fadeInScale{
  from{ opacity:0; transform:scale(.96); }
  to{ opacity:1; transform:scale(1); }
}
@keyframes float{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-15px); }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* === NUEVO: MODALES DE CONTENIDO (Sales Mobile Optimization) === */

/* El disparador (la "tarjeta resumen" visible) */
.concept-trigger {
    background: var(--bg-surface);
    border: 2px solid var(--bg-surface-alt);
    padding: 25px;
    border-radius: var(--radius-lg);
    text-align: center;
    cursor: pointer;
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
    margin-bottom: 30px;
    position: relative;
    overflow: hidden;
}

/* Pequeño acento de color en el top */
.concept-trigger::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(90deg, var(--primary-light), var(--accent-yellow));
    opacity: 0.7;
}

.concept-trigger:hover, .concept-trigger:active {
    border-color: var(--primary);
    transform: translateY(-3px);
    box-shadow: var(--shadow-card);
}

.concept-trigger-icon {
    font-size: 2.5rem; margin-bottom: 15px; display: block;
    filter: grayscale(100%); opacity: 0.5; transition: var(--transition);
}
.concept-trigger:hover .concept-trigger-icon { filter: grayscale(0%); opacity: 1; transform: scale(1.1); }

.concept-trigger-title {
    font-weight: 800; font-size: 1.3rem; margin-bottom: 15px;
    color: var(--text-main); line-height: 1.2;
}

.btn-concept {
    background: var(--primary-light);
    color: var(--primary-dark);
    font-weight: 700; padding: 10px 24px; border-radius: 50px;
    display: inline-flex; align-items: center; gap: 8px; font-size: 0.9rem;
    transition: var(--transition);
}
.btn-concept::after { content: '→'; transition: transform 0.3s ease; }
.concept-trigger:hover .btn-concept { background: var(--primary); color: white; }
.concept-trigger:hover .btn-concept::after { transform: translateX(4px); }


/* El Modal Overlay */
.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(15, 23, 42, 0.85); /* Fondo oscuro con blur */
    backdrop-filter: blur(8px);
    z-index: 9999;
    display: none; /* Oculto por defecto */
    justify-content: center; align-items: center; /* Centrado total */
    padding: 20px;
    opacity: 0; transition: opacity 0.3s ease;
}

.modal-overlay.is-active { display: flex; opacity: 1; }

/* El Contenido del Modal */
.modal-content {
    background: var(--bg-surface);
    padding: 35px 30px;
    border-radius: var(--radius-xl);
    max-width: 500px; width: 100%;
    max-height: 85vh; overflow-y: auto; /* Scroll interno si es muy largo */
    box-shadow: var(--shadow-float);
    position: relative;
    transform: translateY(20px); transition: transform 0.3s ease;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.modal-overlay.is-active .modal-content { transform: translateY(0); }

.modal-close {
    position: absolute; top: 15px; right: 20px;
    font-size: 2rem; line-height: 1; cursor: pointer;
    color: var(--text-muted); transition: var(--transition);
    background: var(--bg-surface-alt); width: 40px; height: 40px;
    border-radius: 50%; display: flex; justify-content: center; align-items: center;
}
.modal-close:hover { background: var(--accent); color: white; transform: rotate(90deg); }

.modal-body-title { font-size: 1.6rem; font-weight: 800; margin-bottom: 20px; color: var(--primary); }
.modal-body-text p { margin-bottom: 15px; font-size: 1.1rem; line-height: 1.7; color: var(--text-main); }

/* Ajuste para el body cuando el modal está abierto */
body.modal-open { overflow: hidden; }

/* Modificación para los puntos de solución en móvil */
@media (max-width: 768px) {
    .sl-points.mobile-hidden { display: none; } /* Ocultamos la lista original en móvil */
    .points-triggers-mobile { display: flex; flex-direction: column; gap: 15px; } /* Mostramos los triggers */
}
@media (min-width: 769px) {
    .points-triggers-mobile { display: none; } /* Ocultamos triggers en escritorio */
}
