/* ============================================================
   JAZMIN BRONSTEIN — style.css
   Mobile-first, CSS custom properties, no framework
   ============================================================ */

/* ----------------------------------------------------------
   1. CUSTOM PROPERTIES
   ---------------------------------------------------------- */
:root {
  /* Colors — paleta cálida */
  --color-bg:           #FBF5EC;
  --color-bg-alt:       #FFFDF8;
  --color-bg-dark:      #1A0E05;
  --color-text:         #1A0E05;
  --color-text-muted:   #8A6B52;
  --color-text-light:   #f0f0f0;
  --color-accent:       #F08060;
  --color-accent-hover: #A84F28;
  --color-border:       #E8D2B8;
  --color-border-dark:  rgba(255, 210, 160, 0.10);

  /* Typography */
  --font-heading: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;

  /* Spacing scale */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* Layout */
  --container-max:    1200px;
  --container-narrow: 800px;
  --container-px:     1.25rem;

  /* Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-full: 999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(26,25,24,0.08);
  --shadow-md: 0 4px 16px rgba(26,25,24,0.10);
  --shadow-lg: 0 8px 32px rgba(26,25,24,0.12);

  /* Transitions */
  --transition-fast: 180ms ease-out;
  --transition-base: 280ms ease-out;
  --transition-slow: 400ms ease-out;

  /* Navbar */
  --navbar-h: 68px;
}

@media (min-width: 768px) {
  :root {
    --container-px: 2rem;
  }
}

@media (min-width: 1024px) {
  :root {
    --container-px: 3rem;
    --navbar-h: 72px;
  }
}


/* ----------------------------------------------------------
   2. RESET & BASE
   ---------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--navbar-h) + 16px);
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.65;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, svg {
  display: block;
  max-width: 100%;
}

ul[role="list"],
ol[role="list"] {
  list-style: none;
}

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

button {
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
  border: none;
  background: none;
}

/* Accessible focus styles */
:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}


/* ----------------------------------------------------------
   3. UTILITIES & LAYOUT
   ---------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-px);
}

.container--narrow {
  max-width: var(--container-narrow);
}

.section {
  padding-block: var(--space-20);
}

@media (min-width: 768px) {
  .section {
    padding-block: var(--space-24);
  }
}

.section--dark {
  background: linear-gradient(145deg, #2a1f2d 0%, #3d2b42 50%, #2a1f2d 100%);
  color: var(--color-text-light);
}

.section-header {
  margin-bottom: var(--space-12);
  text-align: center;
}

.section-label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
  position: relative;
}

/* Underline que crece al hacer scroll */
.section-label::after {
  content: '';
  display: block;
  height: 1.5px;
  width: 0;
  background-color: #88678f;
  margin-top: 3px;
  transition: width 700ms var(--ease-spring) 400ms;
}

.section-header.is-visible .section-label::after {
  width: 100%;
}

.section-label--light {
  color: rgba(248,245,240,0.6);
}

.section-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  line-height: 1.2;
  color: inherit;
  margin-bottom: var(--space-4);
}

.section--dark .section-title {
  color: var(--color-text-light);
}

.section-subtitle {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
  max-width: 56ch;
  margin-inline: auto;
  line-height: 1.7;
}

.section--dark .section-subtitle {
  color: rgba(248,245,240,0.65);
}


/* ----------------------------------------------------------
   4. BUTTONS
   ---------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.01em;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast),
    transform var(--transition-fast),
    box-shadow var(--transition-fast);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(0);
}

.btn--primary {
  background-color: var(--color-text);
  color: var(--color-text-light);
  border: 1.5px solid var(--color-text);
}

.btn--primary:hover {
  background-color: #333;
  border-color: #333;
}

.btn--light {
  background-color: #F08060;
  color: var(--color-bg-dark);
  border: 1.5px solid #F08060;
}

.btn--light:hover {
  background-color: var(--color-border);
  border-color: var(--color-border);
}

.btn--ghost-light {
  background-color: transparent;
  color: var(--color-text-light);
  border: 1.5px solid rgba(248,245,240,0.35);
}

.btn--ghost-light:hover {
  background-color: rgba(248,245,240,0.1);
  border-color: rgba(248,245,240,0.6);
}

.btn--accent {
  background-color: var(--color-accent);
  color: #fff;
  border: 1.5px solid var(--color-accent);
}

.btn--accent:hover {
  background-color: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
}

.btn--sm {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
}

.btn--full {
  width: 100%;
  justify-content: center;
}


/* ----------------------------------------------------------
   5. NAVBAR
   ---------------------------------------------------------- */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--navbar-h);
  display: flex;
  align-items: center;
 background-color: rgba(248,245,240,0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

.navbar.is-scrolled {
  border-bottom-color: var(--color-border);
  box-shadow: var(--shadow-sm);
}

.navbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  width: 100%;
}

.navbar__logo {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-text);
  white-space: nowrap;
  flex-shrink: 0;
}

.navbar__nav {
  display: none;
}

.navbar__list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
}

.navbar__link {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  transition: color 350ms ease, transform 350ms ease;
  position: relative;
  display: inline-block;
}

/* Bloom glow sutil — radial warm glow behind nav link */
.navbar__link::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-sm);
  opacity: 0;
  background: radial-gradient(ellipse at 50% 80%, rgba(255,107,107,0.18) 0%, rgba(78,205,196,0.12) 40%, transparent 70%);
  transform: scale(0.7);
  transition: opacity 400ms ease, transform 500ms var(--ease-spring);
  z-index: -1;
  pointer-events: none;
}

.navbar__link:hover::before {
  opacity: 1;
  transform: scale(1.5);
}

/* Underline sutil que entra desde la izquierda */
.navbar__link::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: var(--space-3);
  right: var(--space-3);
  height: 1.5px;
  background: var(--color-accent);
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 400ms var(--ease-spring);
  opacity: 0.7;
}

.navbar__link:hover {
  color: var(--color-text);
  transform: translateY(-1px);
}

.navbar__link:hover::after {
  transform: scaleX(1);
}

.navbar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* Hamburger */
.navbar__hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 6px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.navbar__hamburger:hover {
  background-color: var(--color-border);
}

.hamburger__bar {
  display: block;
  width: 100%;
  height: 1.5px;
  background-color: var(--color-text);
  border-radius: 2px;
  transition: transform var(--transition-base), opacity var(--transition-base);
  transform-origin: center;
}

.navbar__hamburger[aria-expanded="true"] .hamburger__bar:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.navbar__hamburger[aria-expanded="true"] .hamburger__bar:nth-child(2) {
  opacity: 0;
}
.navbar__hamburger[aria-expanded="true"] .hamburger__bar:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

/* Mobile nav open state */
@media (max-width: 1023px) {
  .navbar__nav {
    position: fixed;
    inset: var(--navbar-h) 0 0 0;
    background-color: var(--color-bg);
    padding: var(--space-8) var(--container-px);
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform var(--transition-base);
    display: flex;
  }

  .navbar__nav.is-open {
    transform: translateX(0);
  }

  .navbar__list {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    width: 100%;
  }

  .navbar__link {
    font-size: 1.25rem;
    padding: var(--space-3) 0;
    display: block;
    width: 100%;
    border-bottom: 1px solid var(--color-border);
    border-radius: 0;
    color: var(--color-text);
  }

  .navbar__link::before,
  .navbar__link::after {
    display: none;
  }

  .navbar__link:hover {
    transform: none;
  }

  .navbar__actions .btn:not(.btn--sm) {
    display: none;
  }
}

@media (min-width: 1024px) {
  .navbar__nav {
    display: flex !important;
    position: static;
    transform: none;
    padding: 0;
    background: transparent;
    inset: auto;
    flex-direction: row;
    align-items: center;
    overflow: visible;
  }

  .navbar__hamburger {
    display: none;
  }

  .navbar__actions .btn--sm {
    display: inline-flex;
  }
}


/* ----------------------------------------------------------
   6. HERO
   ---------------------------------------------------------- */
.hero {
  background: linear-gradient(135deg, #1e1224 0%, #3d2b42 30%, #6b4f72 60%, #2a1f2d 100%);
  color: var(--color-text-light);
  padding-top: calc(var(--space-20) + var(--space-8));
  padding-bottom: var(--space-20);
  position: relative;
  overflow: hidden;
}

/* Warm orb glow */
.hero::before {
  content: '';
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(196, 102, 58, 0.14) 0%, transparent 70%);
  top: -200px;
  right: -150px;
  pointer-events: none;
  animation: orb-drift 9s ease-in-out infinite;
}

/* Second orb (bottom-left) */
.hero::after {
  content: '';
  position: absolute;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(196, 102, 58, 0.07) 0%, transparent 70%);
  bottom: -100px;
  left: -80px;
  pointer-events: none;
  animation: orb-drift 12s ease-in-out infinite reverse;
}

@keyframes orb-drift {
  0%, 100% { transform: translate(0, 0); }
  50%       { transform: translate(-25px, 25px); }
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
  position: relative;
}

@media (min-width: 768px) {
  .hero__inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
  }
}

.hero__eyebrow {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 400;
  line-height: 1.08;
  color: #EDE0F0;
  margin-bottom: var(--space-6);
}

.hero__title em {
  font-style: italic;
 background: linear-gradient(135deg, #F08060 0%, #E8603A 40%, #F5A080 70%, #E8603A 100%);
  background-size: 250% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer-text 4s linear infinite;
}

@keyframes shimmer-text {
  from { background-position: 0% center; }
  to   { background-position: 250% center; }
}

.hero__subtitle {
  font-size: 1.0625rem;
  color: #EDE0F0;
  line-height: 1.75;
  margin-bottom: var(--space-8);
  max-width: 46ch;
}

.hero__subtitle--bold {
  font-weight: 600;
  color: rgba(240,235,228,0.95);
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

/* Photo placeholder */
.hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero__photo {
  width: 100%;
  max-width: 400px;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: 55% 20%;
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  display: block;
  margin: 0 auto;
}

/* Scroll indicator */
.hero__scroll-indicator {
  display: flex;
  justify-content: center;
  margin-top: var(--space-16);
  position: relative;
}

.scroll-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: rgba(255,255,255,0.3);
  animation: scroll-pulse 2s ease-in-out infinite;
}

@keyframes scroll-pulse {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50%       { opacity: 0.8; transform: scale(1.4); }
}


/* ----------------------------------------------------------
   7. SERVICIOS
   ---------------------------------------------------------- */
.servicios {
  overflow: hidden; /* contain bloom dots within section */
}

.servicios__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .servicios__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.servicio-card {
  background-color: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  overflow: visible;
  transition:
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-base);
}

/* Línea lateral de color que crece al hacer hover */
.servicio-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 0;
  background: var(--color-accent);
  transition: height 400ms var(--ease-spring);
  border-radius: 2px;
  z-index: 2;
}

/* Background layer to cover bloom behind card content */
.servicio-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  z-index: 0;
}

.servicio-card:hover::before {
  height: 100%;
}

.servicio-card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 12px 48px rgba(196, 102, 58, 0.18);
  transform: translateY(-6px);
}

/* Bloom dots — tropical "florecimiento" on hover */
.bloom-dots {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.bloom-dot {
  position: absolute;
  border-radius: 50%;
  opacity: 0;
  transform: scale(0);
  transition:
    transform 600ms var(--ease-spring),
    opacity 500ms ease;
  will-change: transform, opacity;
}

.servicio-card:hover .bloom-dot {
  opacity: 0.75;
}

/* Coral — top-right, escapes card */
.bloom-dot--1 {
  width: 100px;
  height: 100px;
  background: radial-gradient(circle, #FF6B6B 0%, rgba(255,107,107,0.3) 50%, transparent 70%);
  top: -30px;
  right: -28px;
}
.servicio-card:hover .bloom-dot--1 {
  transform: scale(2);
  transition-delay: 0ms;
}

/* Teal — bottom-left */
.bloom-dot--2 {
  width: 85px;
  height: 85px;
  background: radial-gradient(circle, #4ECDC4 0%, rgba(78,205,196,0.3) 50%, transparent 70%);
  bottom: -25px;
  left: -22px;
}
.servicio-card:hover .bloom-dot--2 {
  transform: scale(1.9);
  transition-delay: 50ms;
}

/* Yellow — middle-right */
.bloom-dot--3 {
  width: 70px;
  height: 70px;
  background: radial-gradient(circle, #FFD93D 0%, rgba(255,217,61,0.3) 50%, transparent 70%);
  top: 35%;
  right: -30px;
}
.servicio-card:hover .bloom-dot--3 {
  transform: scale(2.2);
  transition-delay: 100ms;
}

/* Magenta — top-left */
.bloom-dot--4 {
  width: 80px;
  height: 80px;
  background: radial-gradient(circle, #E040A0 0%, rgba(224,64,160,0.3) 50%, transparent 70%);
  top: -20px;
  left: 18%;
}
.servicio-card:hover .bloom-dot--4 {
  transform: scale(1.8);
  transition-delay: 70ms;
}

/* Lime — bottom-right */
.bloom-dot--5 {
  width: 90px;
  height: 90px;
  background: radial-gradient(circle, #A8E06C 0%, rgba(168,224,108,0.3) 50%, transparent 70%);
  bottom: -28px;
  right: 12%;
}
.servicio-card:hover .bloom-dot--5 {
  transform: scale(2);
  transition-delay: 120ms;
}

/* Orange extra glow — center-bottom, for extra drama */
.bloom-dot--6 {
  width: 60px;
  height: 60px;
  background: radial-gradient(circle, #FF8C42 0%, rgba(255,140,66,0.25) 50%, transparent 70%);
  bottom: 20%;
  left: -18px;
}
.servicio-card:hover .bloom-dot--6 {
  transform: scale(2.1);
  transition-delay: 160ms;
}

/* ---- Per-card bloom variation via nth-child ---- */

/* Card 2: flip bloom positions horizontally */
.servicio-card:nth-child(2) .bloom-dot--1 { top: auto; bottom: -30px; right: auto; left: -20px; }
.servicio-card:nth-child(2) .bloom-dot--2 { bottom: auto; top: -20px; left: auto; right: -18px; }
.servicio-card:nth-child(2) .bloom-dot--3 { top: auto; bottom: 25%; right: auto; left: -24px; }
.servicio-card:nth-child(2) .bloom-dot--4 { top: auto; bottom: -15px; left: auto; right: 25%; }
.servicio-card:nth-child(2) .bloom-dot--5 { bottom: auto; top: -22px; right: auto; left: 10%; }
.servicio-card:nth-child(2) .bloom-dot--6 { bottom: auto; top: 30%; left: auto; right: -22px; }

/* Card 3: center-burst pattern */
.servicio-card:nth-child(3) .bloom-dot--1 { top: -35px; right: 40%; }
.servicio-card:nth-child(3) .bloom-dot--2 { bottom: -30px; left: 35%; }
.servicio-card:nth-child(3) .bloom-dot--3 { top: 20%; right: -32px; }
.servicio-card:nth-child(3) .bloom-dot--4 { top: 50%; left: -28px; }
.servicio-card:nth-child(3) .bloom-dot--5 { bottom: -20px; right: -18px; }
.servicio-card:nth-child(3) .bloom-dot--6 { top: -18px; left: -14px; }

/* Card 4: diagonal scatter */
.servicio-card:nth-child(4) .bloom-dot--1 { top: -28px; right: 15%; }
.servicio-card:nth-child(4) .bloom-dot--2 { bottom: -28px; left: 40%; }
.servicio-card:nth-child(4) .bloom-dot--3 { top: 60%; right: -28px; }
.servicio-card:nth-child(4) .bloom-dot--4 { top: -25px; left: -20px; }
.servicio-card:nth-child(4) .bloom-dot--5 { bottom: 15%; right: -24px; }
.servicio-card:nth-child(4) .bloom-dot--6 { bottom: -22px; left: -16px; }

/* Card 5: corners emphasis */
.servicio-card:nth-child(5) .bloom-dot--1 { top: -32px; right: -24px; }
.servicio-card:nth-child(5) .bloom-dot--2 { bottom: -28px; left: -20px; }
.servicio-card:nth-child(5) .bloom-dot--3 { top: -24px; left: -18px; }
.servicio-card:nth-child(5) .bloom-dot--4 { bottom: -20px; right: -22px; }
.servicio-card:nth-child(5) .bloom-dot--5 { top: 45%; left: -26px; }
.servicio-card:nth-child(5) .bloom-dot--6 { top: 45%; right: -20px; }

/* Card content must sit above the bloom dots */
.servicio-card__title,
.servicio-card__desc,
.servicio-card__para-que,
.servicio-card__entregables,
.servicio-card__cta {
  position: relative;
  z-index: 1;
}

.servicio-card__title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.25;
}

.servicio-card__desc {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

.servicio-card__para-que,
.servicio-card__entregables {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}

.servicio-card__para-que strong,
.servicio-card__entregables strong {
  color: var(--color-text);
  font-weight: 500;
}

.servicio-card__cta {
  margin-top: auto;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-accent);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.servicio-card__cta:hover {
  color: var(--color-accent-hover);
  gap: var(--space-3);
}


/* ----------------------------------------------------------
   8. CONTACT BAR
   ---------------------------------------------------------- */
.contact-bar {
  background-color: #FAE0D5;
  padding-block: var(--space-6);
}

.contact-bar--dark {
  background-color: var(--color-bg-dark);
}

.contact-bar .container {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: center;
  text-align: center;
}

@media (min-width: 640px) {
  .contact-bar .container {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

.contact-bar__text {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.contact-bar--dark .contact-bar__text {
  color: rgba(248,245,240,0.5);
}

.contact-bar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
}

.contact-bar__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-alt);
  transition:
    color var(--transition-fast),
    border-color var(--transition-fast),
    background-color var(--transition-fast);
}

.contact-bar__btn:hover {
  color: var(--color-text);
  border-color: var(--color-text);
  background-color: var(--color-bg);
}

.contact-bar__btn--light {
  color: rgba(248,245,240,0.6);
  border-color: rgba(248,245,240,0.15);
  background-color: transparent;
}

.contact-bar__btn--light:hover {
  color: #1A0E05 #88678f;
  border-color: rgba(248,245,240,0.4);
  background-color: rgba(248,245,240,0.05);
}


/* ----------------------------------------------------------
   9. PARA QUIÉN
   ---------------------------------------------------------- */
.para-quien {
  background-color: #FFF3E5;
}

.para-quien__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 480px) {
  .para-quien__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 900px) {
  .para-quien__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.pq-card {
  position: relative;
  overflow: visible;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  background-color: var(--color-bg-alt);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color var(--transition-base), transform var(--transition-base);
}

.pq-card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 8px 32px rgba(196, 102, 58, 0.14);
  transform: translateY(-5px);
}

.pq-card:hover .bloom-dot {
  opacity: 0.75;
  transform: scale(2);
}

.pq-card .bloom-dot--1 { top: -30px; right: -28px; transition-delay: 0ms; }
.pq-card .bloom-dot--2 { bottom: -25px; left: -22px; transition-delay: 50ms; }
.pq-card .bloom-dot--3 { top: 35%; right: -30px; transition-delay: 100ms; }
.pq-card .bloom-dot--4 { top: -20px; left: 18%; transition-delay: 70ms; }
.pq-card .bloom-dot--5 { bottom: -28px; right: 12%; transition-delay: 120ms; }
.pq-card .bloom-dot--6 { bottom: 20%; left: -18px; transition-delay: 160ms; }
  border-color: var(--color-accent);
  box-shadow: 0 8px 32px rgba(196, 102, 58, 0.14);
  transform: translateY(-5px);
}

.pq-card__icon {
  color: var(--color-accent);
  width: 32px;
  height: 32px;
  transition: transform var(--transition-base), filter var(--transition-base);
}

.pq-card:hover .pq-card__icon {
  transform: scale(1.25);
  filter: drop-shadow(0 0 8px rgba(201, 98, 50, 0.5));
}

.pq-card__title {
  font-family: var(--font-heading);
  font-size: 1.1875rem;
  font-weight: 500;
  color: var(--color-text);
}

.pq-card__text {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.65;
}


/* ----------------------------------------------------------
   10. PROCESO
   ---------------------------------------------------------- */
.proceso__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  position: relative;
}

@media (min-width: 768px) {
  .proceso__steps {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
  }
}

.proceso-step {
  position: relative;
  display: flex;
  flex-direction: row;
  gap: var(--space-4);
  align-items: flex-start;
}

@media (min-width: 768px) {
  .proceso-step {
    flex-direction: column;
    gap: var(--space-4);
  }
}

.proceso-step__num {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 400;
  color: var(--color-accent);
  opacity: 0.7;
  line-height: 1;
  flex-shrink: 0;
  width: 2rem;
}

.proceso-step__content {
  flex: 1;
}

.proceso-step__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--color-text-light);
  margin-bottom: var(--space-3);
}

.proceso-step__text {
  font-size: 0.9rem;
  color: rgba(248,245,240,0.6);
  line-height: 1.7;
}


/* ----------------------------------------------------------
   11. CLIENTES / TRUST
   ---------------------------------------------------------- */
.clientes__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background-color: var(--color-border);
}

@media (min-width: 640px) {
  .clientes__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.cliente-logo {
  background-color: var(--color-bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
  min-height: 100px;
  transition: background-color var(--transition-fast);
}

.cliente-logo:hover {
  background-color: var(--color-bg);
}

.cliente-logo__text {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.3;
  letter-spacing: 0.03em;
  transition: color var(--transition-fast);
}

.cliente-logo:hover .cliente-logo__text {
  color: var(--color-text);
}


/* ----------------------------------------------------------
   12. FAQ ACCORDION
   ---------------------------------------------------------- */
.faq__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--color-border);
}

.faq-item {
  border-bottom: 1px solid var(--color-border);
}

.faq-item__trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  text-align: left;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color var(--transition-fast);
  line-height: 1.5;
}

.faq-item__trigger:hover {
  color: var(--color-accent);
}

.faq-item__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1.5px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.faq-item__icon::before,
.faq-item__icon::after {
  content: '';
  position: absolute;
  background-color: var(--color-text-muted);
  border-radius: 2px;
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.faq-item__icon::before {
  width: 10px;
  height: 1.5px;
}

.faq-item__icon::after {
  width: 1.5px;
  height: 10px;
}

.faq-item__trigger[aria-expanded="true"] .faq-item__icon {
  border-color: var(--color-accent);
  background-color: var(--color-accent);
}

.faq-item__trigger[aria-expanded="true"] .faq-item__icon::before {
  background-color: #fff;
}

.faq-item__trigger[aria-expanded="true"] .faq-item__icon::after {
  transform: rotate(90deg);
  opacity: 0;
  background-color: #fff;
}

.faq-item__body {
  overflow: hidden;
  max-height: 0;
  transition: max-height var(--transition-slow), padding var(--transition-base);
}

.faq-item__body.is-open {
  max-height: 400px;
}

.faq-item__body p {
  padding-bottom: var(--space-5);
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.75;
}


/* ----------------------------------------------------------
   13. CONTACTO
   ---------------------------------------------------------- */
.contacto__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}

@media (min-width: 900px) {
  .contacto__inner {
    grid-template-columns: 1fr 1.2fr;
    gap: var(--space-16);
  }
}

.contacto .section-title {
  margin-bottom: var(--space-4);
  color: #F08060;
}

.contacto__desc {
  font-size: 0.9375rem;
  color: rgba(248,245,240,0.65);
  line-height: 1.8;
  margin-bottom: var(--space-8);
}

.contacto__channels {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.contacto__channel-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.9rem;
  color: rgba(248,245,240,0.55);
  transition: color var(--transition-fast);
}

.contacto__channel-link:hover {
  color: var(--color-text-light);
}

/* Form */
.contacto__form-wrap {
  background-color: rgba(255,255,255,0.04);
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}

.contacto__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(248,245,240,0.7);
  letter-spacing: 0.02em;
}

.form-input {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: rgba(136, 103, 143, 0.35);
 border: 1px solid rgba(136, 103, 143, 0.6);
  border-radius: var(--radius-md);
  color: var(--color-text-light);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.5;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
  appearance: none;
  -webkit-appearance: none;
}

.form-input::placeholder {
  color: rgba(248,245,240,0.3);
}

.form-input:focus {
  outline: none;
  border-color: var(--color-accent);
  background-color: rgba(255,255,255,0.08);
}

.form-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(248,245,240,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

.form-select option {
  background-color: #1A1918;
  color: #F8F5F0;
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
}

.form-confirmation {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background-color: rgba(155, 123, 90, 0.15);
  border: 1px solid rgba(155, 123, 90, 0.3);
  border-radius: var(--radius-md);
  color: var(--color-accent);
  font-size: 0.9rem;
}

.form-confirmation[hidden],
.form-error[hidden] {
  display: none;
}

.form-error {
  padding: var(--space-4);
  background-color: rgba(220, 80, 80, 0.1);
  border: 1px solid rgba(220, 80, 80, 0.25);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  color: #ffb3b3;
}

.form-error a {
  color: inherit;
  text-decoration: underline;
}


/* ----------------------------------------------------------
   14. FOOTER
   ---------------------------------------------------------- */
.footer {
  background-color: var(--color-bg-dark);
  color: rgba(248,245,240,0.5);
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-block: var(--space-10);
}

.footer__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

@media (min-width: 640px) {
  .footer__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-8);
    flex-wrap: wrap;
  }
}

.footer__name {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 500;
  color: rgba(248,245,240,0.8);
  margin-bottom: var(--space-1);
}

.footer__tagline {
  font-size: 0.8125rem;
  color: rgba(248,245,240,0.35);
}

.footer__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.footer__link {
  font-size: 0.8125rem;
  color: rgba(248,245,240,0.45);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast);
}

.footer__link:hover {
  color: rgba(248,245,240,0.8);
}

.footer__social {
  display: flex;
  gap: var(--space-3);
}

.footer__social-link {
  color: rgba(248,245,240,0.4);
  transition: color var(--transition-fast);
  display: flex;
  align-items: center;
}

.footer__social-link:hover {
  color: rgba(248,245,240,0.8);
}

.footer__copy {
  font-size: 0.75rem;
  color: rgba(248,245,240,0.25);
  text-align: center;
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,0.05);
}


/* ----------------------------------------------------------
   15. SCROLL ANIMATIONS
   ---------------------------------------------------------- */

/* Easing personalizado tipo spring */
:root {
  --ease-spring: cubic-bezier(0.16, 1, 0.3, 1);
}

.animate-fade-up {
  opacity: 0;
  transform: translateY(36px);
  transition:
    opacity 650ms var(--ease-spring),
    transform 650ms var(--ease-spring);
}

.animate-fade-in {
  opacity: 0;
  transform: scale(0.95);
  transition:
    opacity 650ms var(--ease-spring),
    transform 650ms var(--ease-spring);
}

.animate-slide-left {
  opacity: 0;
  transform: translateX(-52px);
  transition:
    opacity 750ms var(--ease-spring),
    transform 750ms var(--ease-spring);
}

.animate-slide-right {
  opacity: 0;
  transform: translateX(52px);
  transition:
    opacity 750ms var(--ease-spring),
    transform 750ms var(--ease-spring);
}

.animate-scale-up {
  opacity: 0;
  transform: scale(0.88);
  transition:
    opacity 600ms var(--ease-spring),
    transform 600ms var(--ease-spring);
}

/* Stagger delays */
.animate-delay-1 { transition-delay: 100ms; }
.animate-delay-2 { transition-delay: 200ms; }
.animate-delay-3 { transition-delay: 300ms; }
.animate-delay-4 { transition-delay: 400ms; }
.animate-delay-5 { transition-delay: 500ms; }
.animate-delay-6 { transition-delay: 600ms; }

.is-visible {
  opacity: 1 !important;
  transform: none !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .animate-fade-up,
  .animate-fade-in,
  .animate-slide-left,
  .animate-slide-right,
  .animate-scale-up {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


/* ----------------------------------------------------------
   16. MARQUEE (logos infinito)
   ---------------------------------------------------------- */
.marquee-wrapper {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 8%,
    black 92%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 8%,
    black 92%,
    transparent 100%
  );
  padding-block: var(--space-6);
}

.marquee-track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: marquee-scroll 28s linear infinite;
}

.marquee-track:hover {
  animation-play-state: paused;
}

@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.marquee-item {
  display: flex;
  align-items: center;
  padding-inline: clamp(1.5rem, 4vw, 3rem);
  white-space: nowrap;
}

.marquee-item__text {
  font-family: var(--font-heading);
  font-size: clamp(1rem, 1.8vw, 1.25rem);
  font-weight: 500;
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
  transition: color var(--transition-fast);
}

.marquee-item:hover .marquee-item__text {
  color: var(--color-text);
}

.marquee-divider {
  color: var(--color-accent);
  font-size: 1.25rem;
  opacity: 0.5;
  flex-shrink: 0;
}


/* ----------------------------------------------------------
   17. CURSOR GLOW
   ---------------------------------------------------------- */
.cursor-glow {
  position: fixed;
  top: 0;
  left: 0;
  width: 480px;
  height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201, 98, 50, 0.07) 0%, transparent 65%);
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: opacity 0.4s ease;
  mix-blend-mode: multiply;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .cursor-glow { display: none; }
}


/* ----------------------------------------------------------
   18. MARQUEE LOGOS
   ---------------------------------------------------------- */
.marquee-logo {
  height: 38px;
  width: auto;
  display: block;
  opacity: 0.7;
  transition: opacity 300ms ease;
}

.marquee-item:hover .marquee-logo {
  opacity: 1;
}

/* Increase marquee item padding for image logos */
.marquee-wrapper .marquee-item {
  padding-inline: clamp(2rem, 5vw, 4.5rem);
}


/* ----------------------------------------------------------
   20. TRUST BAR (logos después del hero, siempre en color)
   ---------------------------------------------------------- */
.trust-bar {
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-8);
}

.trust-bar__label {
  text-align: center;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
}

.trust-bar__scroll {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, black 6%, black 94%, transparent);
  mask-image: linear-gradient(to right, transparent, black 6%, black 94%, transparent);
}

.trust-bar__track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: marquee-scroll 22s linear infinite;
}

.trust-bar__logo {
  height: 36px;
  width: auto;
  display: block;
  padding-inline: clamp(1.5rem, 3.5vw, 3rem);
}


/* ----------------------------------------------------------
   21. PROMO STRIP (franja diagonal de texto)
   ---------------------------------------------------------- */
.promo-strip {
  background: #6b4f72;
  padding-block: var(--space-4);
  overflow: hidden;
  transform: skewY(-1.8deg);
  position: relative;
  z-index: 1;
  margin-block: var(--space-2);
}

.promo-strip__track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: marquee-scroll 18s linear infinite reverse;
  transform: skewY(1.8deg);
}

.promo-strip__word {
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2.5vw, 1.5rem);
  font-weight: 600;
  font-style: italic;
  color: #fff;
  white-space: nowrap;
  letter-spacing: 0.06em;
  padding-inline: var(--space-6);
}

.promo-strip__bullet {
  color: rgba(255,255,255,0.5);
  font-size: 1rem;
  flex-shrink: 0;
}


/* ----------------------------------------------------------
   19. HERO PHOTO FLOAT
   ---------------------------------------------------------- */
@keyframes photo-float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-14px); }
}

.hero__photo {
  animation: photo-float 5.5s ease-in-out infinite;
}
