/* landing-styles.css */

/* Paleta: verde aceituna, dorado, gris */
:root{
  --olive-900: #3b4a2b;    /* verde aceituna oscuro */
  --olive-700: #5a6b3d;
  --gold-500: #b88b2f;     /* dorado */
  --gold-400: #d1a84a;
  --gray-100: #f5f5f6;
  --gray-300: #d9d9db;
  --text: #222;
  --glass-bg: rgba(255,255,255,0.06);
}

*{box-sizing:border-box}
body.landing{
  font-family: Inter, system-ui, -apple-system, "Helvetica Neue", Arial;
  color:var(--text);
  margin:0;
  background: #fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Utility container and grid */
.container{max-width:1100px;margin:0 auto;padding:20px}
.grid{display:grid;gap:24px}
.grid--2col{grid-template-columns:1fr 1fr;align-items:center}

/* Header */
.header{
  position:relative;
  overflow:hidden;
  padding:80px 0 60px;
  color:#fff;
  background: linear-gradient(180deg, rgba(59,74,43,0.9) 0%, rgba(59,74,43,0.85) 100%);
}
.header__bg-img{
  position:absolute;
  top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0.25;
  pointer-events:none;
}
.header__content{position:relative;z-index:2}
.header__title{font-size:2.1rem;margin:0 0 12px;line-height:1.05}
.header__title .highlight{
  color:var(--gold-500);
  font-weight:700;
}
.header__subtitle{opacity:0.95;margin-bottom:18px}

/* social proof badges */
.header__social-proofs{display:flex;gap:10px;margin-bottom:18px}
.social-proof{background:rgba(255,255,255,0.08);padding:8px 12px;border-radius:8px;font-size:0.9rem}

/* CTA */
.cta{display:inline-block;padding:12px 18px;border-radius:10px;text-decoration:none;font-weight:600}
.cta--primary{background:var(--gold-500);color:#fff;box-shadow:0 6px 18px rgba(0,0,0,0.18)}
.cta__em{display:inline-block;margin-left:8px;font-weight:500;opacity:0.95;}

/* Identificacion */
.identificacion{padding:60px 0}
.identificacion__title{font-size:1.6rem;margin-bottom:12px}
.identificacion__bullets{list-style:disc;margin-left:18px}
.identificacion__img{width:100%;border-radius:10px;object-fit:cover}
.large{font-size:1.05rem;font-weight:600;margin-top:18px}

/* Necesito (grid de 8 cards) */
.necesito{padding:60px 0;background:linear-gradient(180deg, #fff 0%, #fbfbfb 100%)}
.necesito__title{font-size:1.5rem;margin-bottom:18px;text-align:center}
.necesito__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:18px;
}
.necesito__card{padding:18px;border-radius:12px;backdrop-filter: blur(6px);background:var(--glass-bg);border:1px solid rgba(255,255,255,0.03)}
.card__title{font-size:1.05rem;margin-bottom:8px}
.card__situation{margin-top:12px;font-size:0.9rem;color:var(--olive-700)}

/* Confian */
.confian{padding:60px 0}
.confian__title{font-size:1.5rem;margin-bottom:12px}
.confian__img{width:100%;border-radius:10px}
.confian__bullets{list-style:none;padding:0;margin:0}
.confian__bullets li{margin-bottom:10px;padding-left:14px;position:relative}
.confian__bullets li:before{content:"";width:8px;height:8px;background:var(--gold-500);display:inline-block;position:absolute;left:0;top:6px;border-radius:2px}

/* Testimonial slider */
.testimonial{padding:60px 0;background:var(--gray-100)}
.testimonial__title{text-align:center;margin-bottom:18px}
.testimonial__slider{position:relative;max-width:880px;margin:0 auto;padding:18px;border-radius:12px;background:#fff;border:1px solid var(--gray-300)}
.slider__track{position:relative;overflow:hidden;height:180px}
.slider__slide{position:absolute;inset:0;padding:18px;opacity:0;transition:opacity .6s ease;display:flex;flex-direction:column;justify-content:center}
.slider__slide.active{opacity:1}
.slide__name{font-weight:700;margin-bottom:8px}
.slide__text{font-size:1rem;margin-bottom:10px;opacity:0;transform:translateY(6px);transition:opacity .45s ease .15s, transform .45s ease .15s}
.slide__thanks{font-weight:600;margin-bottom:6px;opacity:0;transform:translateY(8px);transition:opacity .45s ease .30s, transform .45s ease .30s}
.slide__date{font-size:0.85rem;color:#666;opacity:0;transform:translateY(10px);transition:opacity .45s ease .45s, transform .45s ease .45s}

/* arrows and dots */
.slider__arrow{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;font-size:28px;padding:8px;cursor:pointer;color:var(--olive-900)}
.slider__arrow--prev{left:8px}
.slider__arrow--next{right:8px}
.slider__dots{display:flex;gap:8px;justify-content:center;margin-top:12px}
.slider__dots button{width:10px;height:10px;border-radius:50%;border:none;background:var(--gray-300);opacity:.7}
.slider__dots button.active{background:var(--olive-900);opacity:1}

/* Footer */
.site-footer{background:#222;color:#fff;padding:24px 0;margin-top:40px}
.footer__grid{display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap}

/* Responsive */
@media (max-width:900px){
  .grid--2col{grid-template-columns:1fr}
  .header{padding:60px 0}
  .header__title{font-size:1.6rem}
}


/* -------------------------
   BOTÓN FLOTANTE WHATSAPP
-------------------------- */
.btn-whatsapp {
  position: fixed;
  right: 30px;
  bottom: 50%;
  transform: translateY(50%);
  background-color: #3c5b47; /* verde aceituna oscuro */
  color: #fff;
  padding: 14px 26px;
  border-radius: 50px;
  font-weight: 600;
  letter-spacing: 0.5px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.25);
  text-decoration: none;
  z-index: 1000;
  transition: all 0.3s ease;
  overflow: hidden;
}

.btn-whatsapp::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 0%; height: 100%;
  background: rgba(255, 215, 0, 0.25); /* overlay dorado */
  transition: width 0.4s ease;
  border-radius: 50px;
  z-index: -1;
}

.btn-whatsapp:hover {
  color: #fff;
  transform: translateY(50%) scale(1.05);
}

.btn-whatsapp:hover::before {
  width: 100%;
}

/* -------------------------
   FOOTER
-------------------------- */
.footer {
  background-color: #f5f5f5;
  color: #333;
  padding: 3rem 1rem;
  border-top: 4px solid #c5a237; /* dorado */
  font-family: 'Poppins', sans-serif;
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 2rem;
  align-items: center;
  text-align: center;
}

.footer__col--left {
  text-align: left;
}

.footer__col--center {
  text-align: center;
}

.footer__col--right {
  text-align: right;
}

.footer__social {
  margin-bottom: 0.5rem;
}

.social-link {
  color: #3c5b47;
  font-weight: 500;
  margin-right: 15px;
  text-decoration: none;
  transition: color 0.3s ease;
}

.social-link:hover {
  color: #c5a237;
}

.privacy-link {
  color: #666;
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.3s ease;
}

.privacy-link:hover {
  color: #3c5b47;
}

.footer__legend {
  font-size: 0.85rem;
  color: #777;
  margin-top: 10px;
}

.footer__logo {
  max-width: 240px;
  height: auto;
}

.footer__nav {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer__link {
  color: #3c5b47;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.3s ease;
}

.footer__link:hover {
  color: #c5a237;
}

/* Responsive */
@media (max-width: 768px) {
  .footer__col--left,
  .footer__col--center,
  .footer__col--right {
    text-align: center;
  }
  .btn-whatsapp {
    right: 20px;
    bottom: 20px;
    transform: none;
  }
}

/* ===========================
   Glass cards — estilo general
   =========================== */

.cards-section {
  padding: 3rem 1rem;
  max-width: 1200px;
  margin: 0 auto;
  color: #0b1220;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

.cards-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(1, 1fr);
}

/* responsive: 2 cols on medium, 3 on large */
@media (min-width: 700px) {
  .cards-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px) {
  .cards-grid { grid-template-columns: repeat(3, 1fr); }
}

.glass-card {
  position: relative;
  padding: 1.6rem;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,0.50), rgba(255,255,255,0.18));
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  box-shadow: 0 8px 24px rgba(11,18,32,0.12), inset 0 1px 0 rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  transition: transform .28s cubic-bezier(.2,.9,.3,1), box-shadow .28s;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* slight lift on hover/focus */
.glass-card:hover,
.glass-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(11,18,32,0.16), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* Title */
.card-title {
  font-size: 1.06rem;
  margin: 0 0 .6rem 0;
  color: #071a2b;
  font-weight: 700;
  letter-spacing: -0.02em;
}

/* Bullets */
.card-bullets {
  margin: 0 0 1.2rem 0;
  padding-left: 1.15rem;
  list-style: disc;
  color: #0f2a3f;
  line-height: 1.45;
  font-size: .95rem;
}

/* CTA button */
.card-cta {
  display: inline-block;
  align-self: stretch;
  text-align: center;
  padding: .68rem .9rem;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  background: linear-gradient(90deg, rgba(2,99,190,0.95), rgba(3,150,220,0.95));
  color: #fff;
  box-shadow: 0 8px 20px rgba(3,150,220,0.18);
  transition: transform .18s, box-shadow .18s, filter .18s;
  border: none;
  cursor: pointer;
}

/* subtle hover states for CTA */
.card-cta:hover,
.card-cta:focus {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(3,150,220,0.22);
  filter: saturate(1.08);
  outline: none;
}

/* Ensuring sufficient contrast for focus (accessibility) */
.card-cta:focus-visible {
  outline: 3px solid rgba(3,150,220,0.22);
  outline-offset: 3px;
}

/* small-screen spacing polish */
@media (max-width: 420px) {
  .glass-card { padding: 1.2rem; border-radius: 12px; }
  .card-title { font-size: 1rem; }
  .card-bullets { font-size: .92rem; }
  .card-cta { padding: .58rem; font-size: .95rem; }
}

/* Utility: visually-hidden (sr-only) */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}
