/* ================================================================
   S&C CORREDORES DE SEGUROS — styles.css v5
   Design: Luxury Insurance · Dark Navy + Gold · High Conversion
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Serif+Display:ital@0;1&display=swap');

/* ── VARIABLES ── */
:root {
  --navy:      #0f2444;
  --navy-md:   #1a3a6b;
  --navy-lt:   #234d8f;
  --gold:      #f5c518;
  --gold-d:    #d4a800;
  --gold-lt:   #fff3b0;
  --white:     #ffffff;
  --off-white: #f8f9fc;
  --gray-100:  #f1f4f9;
  --gray-200:  #e2e8f4;
  --gray-500:  #6b7a99;
  --text:      #0f1c35;
  --text-sm:   #4a5878;
  --green:     #16a34a;
  --r: 16px;
  --r-lg: 24px;
  --shadow:    0 4px 24px rgba(15,36,68,.10);
  --shadow-lg: 0 12px 48px rgba(15,36,68,.18);
  --shadow-xl: 0 24px 80px rgba(15,36,68,.25);
  --trans: all 0.3s cubic-bezier(.4,0,.2,1);
  --trans-slow: all 0.6s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
input,textarea,select,button{font-family:inherit;}

/* ── CUSTOM SCROLLBAR ── */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--gray-100);}
::-webkit-scrollbar-thumb{background:var(--navy-md);border-radius:3px;}

/* ── UTILS ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.section-pad{padding:96px 0;}
.section-pad-sm{padding:64px 0;}
.text-center{text-align:center;}

/* ── SECTION LABELS ── */
.section-label {
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold-d);margin-bottom:14px;
}
.section-label::before{content:'';width:24px;height:2px;background:var(--gold);border-radius:2px;}

/* ── HEADINGS ── */
.h1{font-family:'DM Serif Display',serif;font-size:clamp(2.6rem,6vw,5rem);line-height:1.08;font-weight:400;letter-spacing:-.02em;}
.h2{font-family:'DM Serif Display',serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1.15;font-weight:400;letter-spacing:-.02em;color:var(--navy);}
.h3{font-size:1.15rem;font-weight:700;color:var(--navy);}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 28px;border-radius:50px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:none;transition:var(--trans);text-decoration:none;
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.12);opacity:0;transition:var(--trans);
}
.btn:hover::after{opacity:1;}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn-primary{background:var(--gold);color:var(--navy);box-shadow:0 4px 20px rgba(245,197,24,.4);}
.btn-primary:hover{background:var(--gold-d);box-shadow:0 8px 32px rgba(245,197,24,.55);}
.btn-white{background:var(--white);color:var(--navy);box-shadow:var(--shadow);}
.btn-white:hover{background:var(--off-white);box-shadow:var(--shadow-lg);}
.btn-ghost{background:rgba(255,255,255,.08);color:var(--white);border:1.5px solid rgba(255,255,255,.25);}
.btn-ghost:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.5);}
.btn-wa{background:var(--green);color:var(--white);box-shadow:0 4px 20px rgba(22,163,74,.35);}
.btn-wa:hover{background:#15803d;box-shadow:0 8px 30px rgba(22,163,74,.5);}
.btn-lg{padding:18px 36px;font-size:1.05rem;}
.btn-sm{padding:10px 20px;font-size:.85rem;}

/* ── NAVBAR ── */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:var(--trans-slow);padding:0;
}
.nav-wrap{
  background:rgba(15,36,68,.0);
  backdrop-filter:blur(0px);
  border-bottom:1px solid transparent;
  transition:var(--trans-slow);
}
#navbar.scrolled .nav-wrap{
  background:rgba(15,36,68,.97);
  backdrop-filter:blur(20px);
  border-bottom-color:rgba(245,197,24,.2);
  box-shadow:0 4px 40px rgba(0,0,0,.3);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;max-width:1200px;margin:0 auto;transition:var(--trans);
}
#navbar.scrolled .nav-inner{padding:14px 24px;}
.nav-logo{display:flex;align-items:center;flex-shrink:0;}
.nav-logo img{height:46px;filter:none;transition:var(--trans);}
#navbar.scrolled .nav-logo img{height:36px;}
.nav-menu{display:flex;align-items:center;gap:4px;}
.nav-menu a{
  color:rgba(255,255,255,.82);font-size:.88rem;font-weight:500;
  padding:8px 14px;border-radius:8px;transition:var(--trans);position:relative;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:4px;left:50%;right:50%;
  height:2px;background:var(--gold);transition:var(--trans);border-radius:2px;
}
.nav-menu a:hover,
.nav-menu a.active{color:var(--white);}
.nav-menu a:hover::after,
.nav-menu a.active::after{left:14px;right:14px;}
.nav-right{display:flex;align-items:center;gap:12px;}
.hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  padding:8px;border:none;background:none;
}
.hamburger span{
  display:block;width:22px;height:2px;background:var(--white);
  border-radius:2px;transition:var(--trans);
}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ── HERO ── */
#hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  background:linear-gradient(155deg, #050e1f 0%, var(--navy) 40%, #0d2a5a 70%, #0a1e42 100%);
  padding-top:90px;
}
.hero-canvas{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;
}
/* Animated gradient orbs */
.orb{
  position:absolute;border-radius:50%;filter:blur(80px);
  animation:orbFloat 12s ease-in-out infinite;
}
.orb-1{width:500px;height:500px;background:rgba(245,197,24,.08);top:-100px;right:-100px;animation-delay:0s;}
.orb-2{width:350px;height:350px;background:rgba(26,58,107,.6);bottom:-50px;left:-80px;animation-delay:-4s;}
.orb-3{width:250px;height:250px;background:rgba(245,197,24,.05);top:40%;right:20%;animation-delay:-8s;}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(30px,-20px) scale(1.05);}
  66%{transform:translate(-15px,25px) scale(.97);}
}
/* Grid texture */
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 100%);
}
.hero-img-wrap{
  position:absolute;right:0;top:0;bottom:0;width:50%;overflow:hidden;
}
.hero-img-wrap img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  opacity:.25;mix-blend-mode:luminosity;
}
.hero-img-gradient{
  position:absolute;inset:0;
  background:linear-gradient(90deg, var(--navy) 0%, transparent 60%, var(--navy) 100%),
    linear-gradient(0deg, var(--navy) 0%, transparent 40%);
}
.hero-content{
  position:relative;z-index:2;max-width:700px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(245,197,24,.12);border:1px solid rgba(245,197,24,.3);
  color:var(--gold);padding:7px 16px;border-radius:50px;
  font-size:.78rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  margin-bottom:28px;
  animation:fadeUp .8s .1s both;
}
.hero-badge span{
  width:6px;height:6px;border-radius:50%;background:var(--gold);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;}50%{opacity:.3;}}
.hero-title{
  color:var(--white);margin-bottom:24px;
  animation:fadeUp .8s .25s both;
}
.hero-title em{
  color:var(--gold);font-style:italic;display:block;
}
.hero-sub{
  color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1.75;
  max-width:560px;margin-bottom:40px;
  animation:fadeUp .8s .4s both;
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:14px;margin-bottom:60px;
  animation:fadeUp .8s .55s both;
}
.hero-stats{
  display:flex;gap:40px;flex-wrap:wrap;
  animation:fadeUp .8s .7s both;
  padding-top:40px;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-stat-num{
  font-size:2rem;font-weight:800;color:var(--gold);
  font-variant-numeric:tabular-nums;line-height:1;margin-bottom:4px;
}
.hero-stat-label{font-size:.78rem;color:rgba(255,255,255,.55);font-weight:500;}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px);}
  to{opacity:1;transform:translateY(0);}
}

/* ── TRUST BAR ── */
#trust-bar{
  background:var(--gold);padding:16px 0;
  overflow:hidden;position:relative;
}
.trust-scroll{
  display:flex;gap:0;animation:trustScroll 20s linear infinite;
  width:max-content;
}
.trust-item{
  display:flex;align-items:center;gap:10px;padding:0 36px;
  border-right:1px solid rgba(15,36,68,.15);
  white-space:nowrap;
  font-size:.82rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;
}
.trust-item .ti{font-size:1.1rem;}
@keyframes trustScroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ── SEGUROS TABS ── */
#seguros-tabs{background:var(--off-white);}
.tabs-header{
  display:flex;gap:6px;background:var(--white);
  border-radius:16px;padding:6px;box-shadow:var(--shadow);
  max-width:600px;margin:0 auto 48px;flex-wrap:wrap;justify-content:center;
}
.tab-btn{
  flex:1;min-width:110px;padding:12px 18px;border:none;background:transparent;
  border-radius:12px;font-family:'DM Sans',sans-serif;font-size:.84rem;font-weight:600;
  color:var(--text-sm);cursor:pointer;transition:var(--trans);
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.tab-btn.active{background:var(--navy);color:var(--white);box-shadow:var(--shadow);}
.tab-btn:hover:not(.active){background:var(--gray-100);color:var(--navy);}
.tab-panel{display:none;animation:fadeUp .4s both;}
.tab-panel.active{display:block;}

/* ── QUOTE CARD ── */
.quote-card{
  background:var(--white);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);padding:40px 48px;
  max-width:820px;margin:0 auto;
  border:1px solid var(--gray-200);
}
.progress-steps{
  display:flex;align-items:center;gap:0;margin-bottom:36px;
}
.ps-item{
  display:flex;flex-direction:column;align-items:center;flex:1;position:relative;
}
.ps-item:not(:last-child)::after{
  content:'';position:absolute;top:15px;left:50%;right:-50%;
  height:2px;background:var(--gray-200);z-index:0;
}
.ps-item.done:not(:last-child)::after,
.ps-item.active:not(:last-child)::after{background:var(--gold);}
.ps-dot{
  width:32px;height:32px;border-radius:50%;background:var(--gray-200);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;color:var(--gray-500);
  position:relative;z-index:1;transition:var(--trans);
}
.ps-item.done .ps-dot{background:var(--gold);color:var(--navy);}
.ps-item.active .ps-dot{background:var(--navy);color:var(--white);box-shadow:0 0 0 4px rgba(26,58,107,.15);}
.ps-label{font-size:.68rem;font-weight:600;color:var(--gray-500);margin-top:6px;text-align:center;}
.ps-item.active .ps-label{color:var(--navy);}
.step{display:none;}
.step.active{display:block;animation:fadeUp .35s both;}
.step-q{font-size:1.15rem;font-weight:700;color:var(--navy);margin-bottom:20px;}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px;}
.pill{
  padding:11px 20px;border-radius:50px;border:2px solid var(--gray-200);
  background:var(--white);font-size:.88rem;font-weight:600;cursor:pointer;
  transition:var(--trans);color:var(--text);display:flex;align-items:center;gap:7px;
}
.pill:hover{border-color:var(--navy-md);color:var(--navy);}
.pill.selected{border-color:var(--navy);background:var(--navy);color:var(--white);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
.form-grid.single{grid-template-columns:1fr;}
.form-group{display:flex;flex-direction:column;gap:7px;}
.form-group label{font-size:.78rem;font-weight:700;color:var(--text-sm);letter-spacing:.3px;text-transform:uppercase;}
.form-group input,
.form-group textarea,
.form-group select{
  padding:13px 16px;border:2px solid var(--gray-200);border-radius:12px;
  font-size:.92rem;transition:var(--trans);background:var(--white);
  color:var(--text);
}
.form-group input:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--navy);
  box-shadow:0 0 0 4px rgba(15,36,68,.08);
}
.step-nav{display:flex;justify-content:space-between;align-items:center;margin-top:28px;gap:12px;}
.btn-prev{
  padding:12px 22px;border:2px solid var(--gray-200);background:var(--white);
  color:var(--text-sm);border-radius:50px;font-family:'DM Sans',sans-serif;
  font-weight:600;font-size:.88rem;cursor:pointer;transition:var(--trans);
}
.btn-prev:hover{border-color:var(--navy);color:var(--navy);}
.btn-next{
  padding:13px 28px;background:var(--navy);color:var(--white);border:none;
  border-radius:50px;font-family:'DM Sans',sans-serif;font-weight:600;
  font-size:.9rem;cursor:pointer;transition:var(--trans);
}
.btn-next:hover{background:var(--navy-md);transform:translateY(-1px);}

/* ── CALCULADORA ── */
#calculadora{background:var(--navy);position:relative;overflow:hidden;}
#calculadora::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at 80% 50%, rgba(245,197,24,.06), transparent);
}
.calc-wrapper{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.calc-form-card{
  background:rgba(255,255,255,.06);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);
  padding:40px;
}
.calc-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;}
.calc-input{
  padding:13px 16px;border:1.5px solid rgba(255,255,255,.15);
  border-radius:12px;background:rgba(255,255,255,.07);color:var(--white);
  font-family:'DM Sans',sans-serif;font-size:.92rem;text-align:center;
  transition:var(--trans);
}
.calc-input:focus{outline:none;border-color:var(--gold);background:rgba(245,197,24,.08);}
.calc-input::placeholder{color:rgba(255,255,255,.3);}
.calc-input option{background:var(--navy);color:var(--white);}
.calc-result-card{
  border-radius:16px;padding:24px;margin-top:20px;
  text-align:center;display:none;animation:fadeUp .4s both;
}
.calc-result-card.vencido{background:rgba(239,68,68,.15);border:1.5px solid rgba(239,68,68,.4);}
.calc-result-card.urgente{background:rgba(249,115,22,.15);border:1.5px solid rgba(249,115,22,.4);}
.calc-result-card.pronto{background:rgba(234,179,8,.15);border:1.5px solid rgba(234,179,8,.4);}
.calc-result-card.ok{background:rgba(34,197,94,.15);border:1.5px solid rgba(34,197,94,.4);}
.calc-emoji{font-size:2.2rem;margin-bottom:8px;}
.calc-dias{font-size:1.4rem;font-weight:800;color:var(--white);line-height:1;}
.calc-msg{font-size:.82rem;color:rgba(255,255,255,.7);margin:6px 0 16px;}
.calc-info-side h3{color:var(--white);font-size:2rem;font-weight:800;margin-bottom:16px;}
.calc-benefits{display:flex;flex-direction:column;gap:14px;margin-top:28px;}
.calc-benefit{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;background:rgba(255,255,255,.05);
  border-radius:12px;border:1px solid rgba(255,255,255,.08);
}
.calc-benefit-icon{font-size:1.6rem;flex-shrink:0;}
.calc-benefit-title{font-size:.9rem;font-weight:700;color:var(--white);}
.calc-benefit-text{font-size:.78rem;color:rgba(255,255,255,.55);}

/* ── CARDS SEGUROS ── */
#cards-seguros{background:var(--white);}
.seguros-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.seguro-card{
  background:var(--white);border-radius:var(--r-lg);padding:30px 24px;
  border:1.5px solid var(--gray-200);transition:var(--trans);
  cursor:pointer;position:relative;overflow:hidden;
}
.seguro-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;transition:var(--trans);
}
.seguro-card:hover{
  border-color:var(--navy-md);
  box-shadow:var(--shadow-lg);transform:translateY(-6px);
}
.seguro-card:hover::before{transform:scaleX(1);}
.sc-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-md) 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:18px;
  box-shadow:0 4px 16px rgba(15,36,68,.25);
}
.sc-name{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:8px;}
.sc-desc{font-size:.82rem;color:var(--text-sm);line-height:1.6;flex:1;}
.sc-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8rem;font-weight:700;color:var(--gold-d);margin-top:16px;
  transition:var(--trans);
}
.sc-link:hover{gap:10px;}

/* ── ASEGURADORAS ── */
#aseguradoras{background:var(--off-white);padding:60px 0;overflow:hidden;}
.aseg-track-wrap{overflow:hidden;position:relative;margin-top:40px;}
.aseg-track-wrap::before,
.aseg-track-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;
}
.aseg-track-wrap::before{left:0;background:linear-gradient(90deg,var(--off-white),transparent);}
.aseg-track-wrap::after{right:0;background:linear-gradient(-90deg,var(--off-white),transparent);}
.aseg-track{
  display:flex;gap:24px;align-items:center;
  animation:asegScroll 26s linear infinite;width:max-content;
}
.aseg-track:hover{animation-play-state:paused;}
@keyframes asegScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.aseg-item{
  background:var(--white);border-radius:16px;padding:16px 28px;
  min-width:160px;height:76px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);border:1px solid var(--gray-200);
  transition:var(--trans);flex-shrink:0;
}
.aseg-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);}
.aseg-item img{max-height:40px;max-width:120px;object-fit:contain;width:auto;}

/* ── TESTIMONIOS ── */
#testimonios{background:var(--navy);position:relative;overflow:hidden;}
#testimonios::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 70% at 20% 50%,rgba(245,197,24,.05),transparent);
}
.testimonios-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.testi-card{
  background:rgba(255,255,255,.05);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);
  padding:32px 28px;transition:var(--trans);
}
.testi-card:hover{
  background:rgba(255,255,255,.09);border-color:rgba(245,197,24,.25);
  transform:translateY(-4px);
}
.testi-stars{color:var(--gold);font-size:1rem;letter-spacing:1px;margin-bottom:16px;}
.testi-text{
  font-size:.92rem;color:rgba(255,255,255,.8);line-height:1.75;
  font-style:italic;margin-bottom:20px;
}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--gold);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.85rem;color:var(--navy);flex-shrink:0;
}
.testi-name{font-size:.85rem;font-weight:700;color:var(--white);}
.testi-seg{font-size:.75rem;color:var(--gold);font-weight:600;}

/* ── POR QUÉ S&C ── */
#porque{background:var(--white);}
.porque-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.porque-img-side{position:relative;}
.porque-img-wrap{
  border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-xl);
  aspect-ratio:4/5;
}
.porque-img-wrap img{width:100%;height:100%;object-fit:cover;}
.porque-badge{
  position:absolute;bottom:-24px;right:-24px;
  background:var(--gold);border-radius:20px;padding:20px 24px;
  box-shadow:var(--shadow-lg);
  text-align:center;
}
.porque-badge-num{font-size:2.2rem;font-weight:800;color:var(--navy);line-height:1;}
.porque-badge-text{font-size:.72rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;}
.porque-items{display:flex;flex-direction:column;gap:20px;margin-top:36px;}
.porque-item{
  display:flex;gap:16px;padding:20px;border-radius:var(--r);
  background:var(--off-white);border:1.5px solid transparent;
  transition:var(--trans);
}
.porque-item:hover{background:var(--white);border-color:var(--gray-200);box-shadow:var(--shadow);}
.pi-icon{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--navy);display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
}
.pi-title{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:4px;}
.pi-desc{font-size:.82rem;color:var(--text-sm);line-height:1.6;}

/* ── NOSOTROS ── */
.timeline-wrap{position:relative;max-width:760px;margin:0 auto;padding:20px 0;}
.timeline-line-bg{position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--gray-200);transform:translateX(-50%);}
.timeline-line-fill{position:absolute;left:50%;top:0;width:2px;background:var(--gold);transform:translateX(-50%);height:0;transition:height .6s ease;}
.tl-row{display:flex;justify-content:flex-end;padding-right:calc(50% + 28px);margin-bottom:36px;position:relative;}
.tl-row:nth-child(even){justify-content:flex-start;padding-right:0;padding-left:calc(50% + 28px);}
.tl-dot{
  position:absolute;left:50%;top:18px;transform:translateX(-50%);
  width:40px;height:40px;border-radius:50%;background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.68rem;color:var(--navy);
  box-shadow:0 0 0 6px rgba(245,197,24,.15);z-index:1;
}
.tl-box{
  background:var(--white);border-radius:14px;padding:20px 24px;
  box-shadow:var(--shadow);max-width:250px;border:1.5px solid var(--gray-200);
  border-top:3px solid var(--gold);
}
.tl-year{font-size:.7rem;font-weight:700;color:var(--gold-d);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;}
.tl-title{font-size:.9rem;font-weight:700;color:var(--navy);}

/* ── MAPA ── */
#mapa-section{background:var(--off-white);}
.mapa-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start;}
.contact-items{display:flex;flex-direction:column;gap:16px;margin-top:28px;}
.contact-item{
  display:flex;align-items:flex-start;gap:14px;padding:18px;
  background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);
  transition:var(--trans);
}
.contact-item:hover{transform:translateX(4px);box-shadow:var(--shadow-lg);}
.ci-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px;}
.ci-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sm);margin-bottom:2px;}
.ci-val{font-size:.9rem;font-weight:600;color:var(--navy);}
.map-card{
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xl);
}
.map-card iframe{display:block;width:100%;height:380px;border:none;}
.map-footer{
  background:var(--white);padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}

/* ── RENOVACIÓN CTA ── */
#renovacion{
  background:linear-gradient(135deg,var(--navy) 0%,#0d2a5a 100%);
  position:relative;overflow:hidden;
}
#renovacion::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 100% 50%,rgba(245,197,24,.07),transparent);
}
.renov-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;}
.renov-form{
  background:rgba(255,255,255,.07);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);
  padding:36px;
}
.renov-form .form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;
}
.renov-input{
  padding:13px 16px;border:1.5px solid rgba(255,255,255,.15);
  border-radius:12px;background:rgba(255,255,255,.08);
  color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9rem;
  transition:var(--trans);
}
.renov-input::placeholder{color:rgba(255,255,255,.35);}
.renov-input:focus{outline:none;border-color:var(--gold);background:rgba(245,197,24,.08);}
.renov-input option{background:var(--navy);}

/* ── ACCORDION SEGUROS ── */
.accordion-item{
  background:var(--white);border-radius:var(--r);
  border:1.5px solid var(--gray-200);margin-bottom:12px;
  overflow:hidden;transition:var(--trans);
}
.accordion-item.open{border-color:var(--navy-md);box-shadow:var(--shadow);}
.acc-header{
  display:flex;align-items:center;gap:16px;padding:22px 24px;
  cursor:pointer;user-select:none;
}
.acc-icon-box{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--navy),var(--navy-md));
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;
}
.acc-title{flex:1;font-size:1rem;font-weight:700;color:var(--navy);}
.acc-chevron{font-size:1.1rem;color:var(--text-sm);transition:var(--trans);}
.accordion-item.open .acc-chevron{transform:rotate(180deg);color:var(--gold-d);}
.acc-body{display:none;padding:0 24px 24px;}
.acc-body.open{display:block;animation:fadeUp .25s both;}
.acc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:16px 0;}
.acc-cell{background:var(--gray-100);border-radius:10px;padding:14px;}
.acc-cell-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sm);margin-bottom:4px;}
.acc-cell-val{font-size:.85rem;color:var(--text);font-weight:500;line-height:1.5;}

/* ── CTA BAND ── */
.cta-band{
  background:var(--gold);padding:64px 0;text-align:center;
}
.cta-band h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;color:var(--navy);margin-bottom:12px;}
.cta-band p{color:rgba(15,36,68,.7);font-size:1rem;margin-bottom:28px;}

/* ── FOOTER ── */
footer{background:var(--navy);padding:64px 0 28px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.5fr 1fr;gap:48px;margin-bottom:48px;}
.footer-logo img{height:44px;margin-bottom:16px;}
.footer-desc{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.7;max-width:240px;}
.footer-col-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:16px;}
.footer-links{display:flex;flex-direction:column;gap:8px;}
.footer-links a{font-size:.85rem;color:rgba(255,255,255,.6);transition:var(--trans);}
.footer-links a:hover{color:var(--white);padding-left:4px;}
.footer-contact-list{display:flex;flex-direction:column;gap:10px;}
.fci{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.5;}
.fci span:first-child{flex-shrink:0;}
.footer-social{display:flex;flex-direction:column;gap:8px;}
.footer-social a{
  display:flex;align-items:center;gap:8px;font-size:.85rem;
  padding:10px 14px;background:rgba(255,255,255,.06);border-radius:10px;
  color:rgba(255,255,255,.7);transition:var(--trans);
}
.footer-social a:hover{background:var(--gold);color:var(--navy);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-aseg-logos{display:flex;gap:10px;flex-wrap:wrap;}
.footer-aseg-logos img{height:22px;opacity:.5;filter:brightness(0) invert(1);transition:var(--trans);}
.footer-aseg-logos img:hover{opacity:.9;}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.3);}

/* ── AGENTE IA ── */
#agente-wrap{position:fixed;bottom:24px;right:24px;z-index:900;}
#agente-btn{
  width:62px;height:62px;background:var(--navy);border:none;border-radius:50%;
  cursor:pointer;box-shadow:var(--shadow-xl);
  display:flex;align-items:center;justify-content:center;
  transition:var(--trans);position:relative;
  animation:agentBounce .6s 1.5s ease both;
}
@keyframes agentBounce{
  from{transform:scale(0);opacity:0;}
  60%{transform:scale(1.12);}
  to{transform:scale(1);opacity:1;}
}
#agente-btn:hover{transform:scale(1.08);background:var(--navy-md);}
#agente-btn svg{width:26px;height:26px;fill:var(--white);}
.agent-badge{
  position:absolute;top:-3px;right:-3px;
  width:20px;height:20px;border-radius:50%;
  background:var(--gold);display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:800;color:var(--navy);
  animation:pulse-badge 2s infinite;
}
@keyframes pulse-badge{0%,100%{box-shadow:0 0 0 0 rgba(245,197,24,.5);}50%{box-shadow:0 0 0 6px rgba(245,197,24,0);}}
#agente-chat{
  position:absolute;bottom:74px;right:0;width:348px;
  background:var(--white);border-radius:20px;
  box-shadow:0 8px 60px rgba(0,0,0,.22);
  display:none;flex-direction:column;
  max-height:530px;overflow:hidden;
  animation:chatSlideUp .3s ease;
}
#agente-chat.open{display:flex;}
@keyframes chatSlideUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.chat-header{
  background:linear-gradient(135deg,var(--navy),var(--navy-md));
  padding:16px 18px;display:flex;align-items:center;gap:10px;
  border-radius:20px 20px 0 0;
}
.chat-avatar{
  width:38px;height:38px;border-radius:50%;background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;color:var(--navy);flex-shrink:0;
}
.chat-name{color:var(--white);font-size:.88rem;font-weight:700;}
.chat-status{display:flex;align-items:center;gap:5px;font-size:.7rem;color:rgba(255,255,255,.6);}
.chat-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:pulse-dot 2s infinite;}
.chat-close{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:1.1rem;padding:4px;transition:var(--trans);}
.chat-close:hover{color:var(--white);}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:#f8fafc;}
.msg{max-width:86%;padding:10px 14px;border-radius:14px;font-size:.84rem;line-height:1.5;animation:fadeUp .25s both;}
.msg-bot{background:var(--navy);color:var(--white);border-bottom-left-radius:4px;align-self:flex-start;}
.msg-user{background:var(--gold);color:var(--navy);font-weight:600;border-bottom-right-radius:4px;align-self:flex-end;}
.typing-bubble{display:flex;gap:4px;align-items:center;padding:12px 16px;}
.typing-bubble span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.5);animation:typing-dots 1.2s infinite;}
.typing-bubble span:nth-child(2){animation-delay:.2s;}
.typing-bubble span:nth-child(3){animation-delay:.4s;}
@keyframes typing-dots{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.chat-chips{
  padding:10px 14px;display:flex;flex-wrap:wrap;gap:8px;
  border-top:1px solid var(--gray-200);background:var(--white);
  border-radius:0 0 20px 20px;
}
.chip{
  padding:7px 13px;background:var(--gray-100);border:1.5px solid var(--gray-200);
  border-radius:20px;font-size:.76rem;font-weight:700;color:var(--navy);
  cursor:pointer;transition:var(--trans);font-family:'DM Sans',sans-serif;
}
.chip:hover{background:var(--navy);color:var(--white);border-color:var(--navy);}

/* ── HERO INTERIOR (páginas internas) ── */
.page-hero{
  background:linear-gradient(155deg,#050e1f 0%,var(--navy) 50%,#0d2a5a 100%);
  padding:130px 0 70px;text-align:center;position:relative;overflow:hidden;
}
.page-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;}
.page-hero-content{position:relative;z-index:2;}
.breadcrumb{display:flex;justify-content:center;gap:8px;align-items:center;margin-bottom:14px;}
.breadcrumb a{color:rgba(255,255,255,.5);font-size:.8rem;transition:var(--trans);}
.breadcrumb a:hover{color:var(--gold);}
.breadcrumb .sep{color:rgba(255,255,255,.2);}
.breadcrumb span{color:var(--gold);font-size:.8rem;font-weight:600;}
.page-hero h1{
  font-family:'DM Serif Display',serif;
  font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400;
  color:var(--white);margin-bottom:14px;
}
.page-hero h1 span{color:var(--gold);font-style:italic;}
.page-hero p{color:rgba(255,255,255,.65);font-size:1rem;max-width:560px;margin:0 auto;}

/* ── MISIÓN VISIÓN ── */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.mv-card{
  background:var(--white);border-radius:var(--r-lg);padding:36px;
  box-shadow:var(--shadow);border-top:4px solid var(--gold);
}
.mv-card.vision{border-top-color:var(--navy);}

/* ── VALORES ── */
.valores-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.valor-card{
  background:var(--white);border-radius:var(--r-lg);padding:28px 22px;
  box-shadow:var(--shadow);text-align:center;transition:var(--trans);
  border:1.5px solid var(--gray-200);
}
.valor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--gold);}
.val-icon{font-size:2.4rem;margin-bottom:14px;}
.val-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:6px;}
.val-desc{font-size:.82rem;color:var(--text-sm);line-height:1.6;}

/* ── CONTACTO PAGE ── */
.contacto-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:start;}
.contacto-form-card{
  background:var(--white);border-radius:var(--r-lg);padding:40px;
  box-shadow:var(--shadow-lg);border:1.5px solid var(--gray-200);
}
.agendador-card{
  background:var(--white);border-radius:var(--r-lg);padding:40px;
  box-shadow:var(--shadow-lg);max-width:560px;margin:0 auto;
}
.horario-grid{display:flex;gap:12px;margin-bottom:20px;}
.horario-opt{
  flex:1;padding:16px;border:2px solid var(--gray-200);border-radius:14px;
  background:var(--white);cursor:pointer;text-align:center;
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:.88rem;
  transition:var(--trans);color:var(--text);
}
.horario-opt.selected{border-color:var(--navy);background:var(--navy);color:var(--white);}
.horario-opt:hover:not(.selected){border-color:var(--navy-md);color:var(--navy);}

/* ── AOS CUSTOM (fail-safe: visible by default) ── */
.js-anim [data-aos]{opacity:0;transition:transform .7s cubic-bezier(.4,0,.2,1),opacity .7s cubic-bezier(.4,0,.2,1);}
.js-anim [data-aos="fade-up"]{transform:translateY(30px);}
.js-anim [data-aos="fade-right"]{transform:translateX(-30px);}
.js-anim [data-aos="fade-left"]{transform:translateX(30px);}
.js-anim [data-aos="zoom-in"]{transform:scale(.94);}
[data-aos].aos-animate{opacity:1!important;transform:none!important;}

/* ── SHOWCASE (image reveal, no pin) ── */
#showcase{background:var(--navy);padding:0;position:relative;overflow:hidden;}
.showcase-inner{
  position:relative;height:78vh;min-height:520px;width:100%;overflow:hidden;
}
.showcase-inner img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  transform:scale(1.12);will-change:transform;
}
.showcase-overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--white);padding:32px;
  background:linear-gradient(0deg,rgba(15,36,68,.85) 0%,rgba(15,36,68,.35) 50%,rgba(15,36,68,.6) 100%);
}
.showcase-overlay .so-label{
  font-size:.72rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);margin-bottom:16px;
}
.showcase-overlay h2{
  font-family:'DM Serif Display',serif;font-size:clamp(1.8rem,4.5vw,3.4rem);
  font-weight:400;line-height:1.15;max-width:760px;margin-bottom:18px;color:#fff;
}
.showcase-overlay p{font-size:1.05rem;color:rgba(255,255,255,.88);max-width:520px;}

/* parallax layers */
.parallax-deco{position:absolute;pointer-events:none;will-change:transform;}

/* reveal-on-scroll mask for images */
.img-reveal{position:relative;overflow:hidden;border-radius:var(--r-lg);}
.img-reveal img{will-change:transform;transform:scale(1.18);}

/* ── SVG ICONS (sizing in containers) ── */
.sc-icon svg{width:26px;height:26px;color:var(--gold);}
.pi-icon svg{width:22px;height:22px;color:var(--gold);}
.acc-icon-box svg{width:22px;height:22px;color:var(--gold);}
.val-icon svg{width:34px;height:34px;color:var(--navy);}
.trust-item .ti{display:inline-flex;align-items:center;}
.trust-item .ti svg{width:18px;height:18px;color:var(--navy);}
.calc-benefit-icon svg{width:24px;height:24px;color:var(--gold);}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .seguros-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .porque-layout{grid-template-columns:1fr;gap:40px;}
  .porque-img-side{display:none;}
  .testimonios-grid{grid-template-columns:1fr;}
  .calc-wrapper{grid-template-columns:1fr;}
  .renov-layout{grid-template-columns:1fr;}
  .valores-grid{grid-template-columns:repeat(2,1fr);}
  .mv-grid{grid-template-columns:1fr;}
  .mapa-layout{grid-template-columns:1fr;}
  .contacto-layout{grid-template-columns:1fr;}
  .acc-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .showcase-inner{height:60vh;min-height:400px;}
  .nav-menu{
    display:none;flex-direction:column;gap:4px;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(15,36,68,.98);backdrop-filter:blur(20px);
    padding:16px 20px 20px;
    border-top:1px solid rgba(255,255,255,.08);
  }
  .nav-menu.open{display:flex;}
  .hamburger{display:flex;}
  .nav-right .btn{display:none;}
  .hero-img-wrap{display:none;}
  .hero-actions{flex-direction:column;}
  .hero-stats{gap:24px;}
  .seguros-grid{grid-template-columns:1fr;}
  .testimonios-grid{grid-template-columns:1fr;}
  .calc-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .quote-card{padding:24px 18px;}
  .form-grid{grid-template-columns:1fr;}
  .renov-form .form-row{grid-template-columns:1fr;}
  .acc-grid{grid-template-columns:1fr;}
  .tabs-header{flex-wrap:wrap;}
  .tab-btn{min-width:calc(50% - 6px);}
  .horario-grid{flex-direction:column;}
  #agente-chat{width:310px;right:-5px;}
  .tl-row,.tl-row:nth-child(even){padding:0 0 0 56px;justify-content:flex-start;}
  .timeline-line-bg,.timeline-line-fill{left:20px;}
  .tl-dot{left:20px;}
  .tl-box{max-width:100%;}
}
@media(max-width:480px){
  .hero-stats{flex-direction:column;gap:20px;}
  .tabs-header{gap:4px;}
  .tab-btn{font-size:.78rem;padding:10px 12px;}
}
