/* Estilos básicos para la landing */
/* (paleta definida más abajo) */
* {
  box-sizing: border-box
}

html,
body {
  height: 100%;
  margin: 0;
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  color: #111827;
  background: var(--bg);
}

.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 2rem)
}

.site-header {
  background: linear-gradient(90deg, #fff, var(--green-50));
  border-bottom: 1px solid var(--green-100)
}

.nav-row {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between
}

.logo {
  font-weight: 700;
  color: var(--green-600);
  text-decoration: none;
  font-size: 1.25rem;
  display: inline-flex;
  align-items: center;
  gap: .5rem
}

.logo-img {
  width: clamp(36px, 4.5vw, 72px);
  height: auto;
  border-radius: 6px;
  display: inline-block;
  object-fit: cover
}

.logo-text {
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  color: var(--green-700);
}

.logo-text {
  line-height: 1
}

.main-nav {
  display: flex;
  gap: 1rem;
  z-index: 10;
}

/* Colores del menú: usar tono oscuro para accesibilidad; naranja como hover */
.navbar-nav a {
  color: var(--green-700);
  text-decoration: none;
  font-weight: 400;
  z-index: 10;
}

.navbar-nav a:hover,
.navbar-nav a:focus {
  color: var(--orange);
  outline: 2px solid rgba(255, 152, 0, 0.12);
  outline-offset: 3px
}


:root {
  /* Brand palette (from user) */
  --malachite: #04e762;
  /* primary bright green */
  --selective-yellow: #f5b700;
  /* yellow / orange accent */
  --celestial-blue: #00a1e4;
  /* blue accent */
  --mexican-pink: #dc0073;
  /* pink accent */
  --chartreuse: #89fc00;
  /* chartreuse accent */

  /* semantic mappings (keep existing variable names used across the CSS) */
  --bg: #fffefb;
  --muted: #21382a;

  --green-50: #e9fff2;
  --green-100: #bff6d7;
  --green-200: #8cf0b8;
  --green-300: #52e895;
  --green-400: #2adb74;
  --green: var(--malachite);
  --green-600: #03c653;
  --green-700: #028a3f;

  --orange-50: #fff8ef;
  --orange-100: #ffe6c9;
  --orange-200: #ffd1a0;
  --orange-300: #ffc077;
  --orange: var(--selective-yellow);
  --orange-600: #d9a600;
  --orange-700: #b78300;

  --blue: var(--celestial-blue);
  --pink: var(--mexican-pink);
  --chartreuse: var(--chartreuse);

  --gradient-top: linear-gradient(0deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-right: linear-gradient(90deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-bottom: linear-gradient(180deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-left: linear-gradient(270deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-top-right: linear-gradient(45deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-bottom-right: linear-gradient(135deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-top-left: linear-gradient(225deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-bottom-left: linear-gradient(315deg, var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));
  --gradient-radial: radial-gradient(var(--malachite), var(--selective-yellow), var(--celestial-blue), var(--mexican-pink), var(--chartreuse));

  --surface: #fffaf0;
  /* superficie suave con tinte cálido */
  --radius: 12px;
  --max-width: 1100px;
}

.btn {
  display: inline-block;
  padding: .6rem .9rem;
  border-radius: 8px;
  border: 1px solid var(--green-100);
  background: #fff;
  color: var(--green-700);
  text-decoration: none
}

.btn-primary {
  background: var(--green-700);
  color: #fff;
  border-color: var(--green-700)
}

.btn-primary:hover {
  background: var(--green-600)
}

.btn:focus {
  outline: 3px solid rgba(37, 211, 102, 0.16);
  outline-offset: 2px
}

.section {
  padding: 20px;
}

.about-grid {
  display: grid;
  gap: 1rem;
  margin-top: 1rem
}

.about-block {
  background: var(--surface);
  padding: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 1px 4px rgba(2, 6, 23, 0.06)
}

@media (min-width:700px) {
  .about-grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

.about-icon {
  display: block;
  margin: 0 auto .6rem;
  width: clamp(40px, 5vw, 64px);
  height: auto;
  color: var(--green-700);
  transition: color .18s ease
}

.about-icon:hover {
  color: var(--blue)
}

.about-block h3 {
  margin-top: 0;
  margin-bottom: .5rem;
  text-align: center
}

.about-block p,
.about-block .features {
  color: var(--muted);
  text-align: center
}

.features {
  margin-top: 1rem;
  display: grid;
  gap: .5rem
}

.features li {
  color: var(--muted)
}

.faq-list {
  margin-top: 1rem
}

.faq-item {
  border-top: 1px solid #eef2ff;
  padding: .75rem 0
}

.faq-q {
  width: 100%;
  text-align: left;
  background: none;
  border: 0;
  font-weight: 600;
  padding: 0;
  font-size: 1rem;
  cursor: pointer
}

.faq-a {
  margin-top: .5rem;
  color: var(--muted);
  display: none
}

.faq-q[aria-expanded="true"]+.faq-a {
  display: block
}

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin-top: 1rem
}

.card {
  background: var(--surface);
  padding: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.03)
}

.quote {
  margin: 0 0 .5rem
}

.by {
  color: var(--muted);
  font-size: .9rem;
  margin: 0
}

.case h3 {
  margin: .25rem 0
}

/* imágenes */
.hero-image img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
}

/* Contenedor para imagen + párrafo en el hero: centrado y responsivo */
.hero-figure {
  width: 100%;
  overflow: hidden;
  max-width: 100%;
}

/* usando la utilidad ratio de Bootstrap se mantiene cuadrados en móviles */
.hero-figure img {
  width: 100%;
  height: 100%;
  border-radius: 8px;
  object-fit: cover;
  display: block;
}

.hero-figure p {
  text-align: center;
  margin-top: .5rem;
  margin-bottom: 0;
}

/* Fijar 200x200 en pantallas de escritorio/portátil (>=992px) */
@media (min-width: 992px) {
  .hero-figure {
    width: 200px;
    height: 200px;
    max-width: 200px;
    max-height: 200px;
  }
}

/* New Year card: Bootstrap-styled, centered, responsive */
.newyear-card {
  max-width: 480px;
  width: 100%;
}
.newyear-card img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  margin-bottom: .5rem
}

.card .avatar {
  float: left;
  margin-right: .75rem
}

.case-image {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: .75rem
}

.card:after {
  content: '';
  display: block;
  clear: both
}

/* Carousel styles */
.carousel {
  position: relative;
  margin-top: 1rem;
  overflow: hidden
}

.carousel-track {
  display: flex;
  gap: 1rem;
  transition: transform .4s ease;
  will-change: transform;
  margin: 0;
  padding: 0
}

.carousel .card {
  min-width: 100%;
  flex: 0 0 100%
}

/* responsive carousel: 1 column mobile, 2 on medium, 3 on large */
@media (min-width:700px) {
  .carousel .card {
    flex: 0 0 50%;
    min-width: 50%
  }
}

@media (min-width:1000px) {
  .carousel .card {
    flex: 0 0 calc(33.333% - 0.666rem);
    min-width: calc(33.333% - 0.666rem)
  }
}

.carousel-prev,
.carousel-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--green-100);
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--green-700)
}

.carousel-prev {
  left: 8px
}

.carousel-next {
  right: 8px
}

.carousel-prev:focus,
.carousel-next:focus {
  outline: 2px solid var(--green-700)
}

.carousel-dots {
  display: flex;
  gap: .4rem;
  justify-content: center;
  margin-top: .75rem
}

.carousel-dots button {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 0;
  background: #e2e8f0;
  cursor: pointer
}

.carousel-dots button.active {
  background: var(--green-700)
}

@media (max-width:600px) {
  .carousel .card {
    min-width: 200px
  }

  .carousel-prev,
  .carousel-next {
    width: 34px;
    height: 34px
  }
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.25rem;
  margin-top: 1rem
}

.contact-form label {
  display: block;
  margin-bottom: .75rem
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: .6rem;
  border: 1px solid #e6eef8;
  border-radius: 8px
}

.contact-form textarea {
  min-height: 120px
}

.site-footer {
  border-top: 1px solid var(--green-100);
  padding: 1rem 0;
  margin-top: 2rem;
  color: var(--muted)
}

@media (max-width:900px) {
  .hero-inner {
    grid-template-columns: 1fr
  }

  .nav-toggle {
    display: inline-block
  }

  .main-nav {
    position: absolute;
    top: 64px;
    right: 0;
    background: #fff;
    padding: 1rem;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(2, 6, 23, 0.08);
    display: none;
    flex-direction: column
  }

  .main-nav.show {
    display: flex
  }

  .contact-grid {
    grid-template-columns: 1fr
  }
}

/* pequeños ajustes */
button {
  font-family: inherit
}

/* helper */
.hidden {
  display: none
}

/* Client-side validation / error styles */
input,
textarea {
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.input-error {
  border-color: var(--mexican-pink) !important;
  box-shadow: 0 0 0 4px rgba(220, 0, 115, 0.06);
}

#contact-status.error {
  color: var(--mexican-pink);
}

/* Field meta: counter and inline errors */
.field-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 0.4rem
}

.char-counter {
  font-size: .85rem;
  color: var(--muted)
}

.field-error {
  display: block;
  color: var(--mexican-pink);
  font-size: .85rem;
  margin-top: 0.25rem;
  min-height: 1.1em
}

.christmas-container {
  display: flex;
  justify-content: center;
  position: relative;
  height: 60px;
  margin-bottom: 1rem;
}

.christmas {
  display: flex;
  justify-content: center;
  background-color: #c8e5d5;
  margin: 0 auto;
  gap: 1rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  position: relative;
  height: auto;
  z-index: 5;
  position: fixed;
  border-color: #028a3f;
  border-radius: 5px;
  border: 1px solid #028a3f;
  color:#03c653
}

.christmas-flower {
  width: 20px;
  height: 20px;
  align-self: center;
}

@media (max-width: 768px) {
  #about, #faq, #testimonials, #cases, #contact {
    margin: 10px;
  }
}