/* ── Variables ── */
    :root {
      --ivory: #faf6f0;
      --carbon: #1c160e;
      --champagne: #c9a96e;
      --sand: #ede8df;
      --border: #ddd8cf;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      background: var(--ivory);
      color: var(--carbon);
      font-family: 'Jost', sans-serif;
      font-weight: 300;
      -webkit-font-smoothing: antialiased;
    }
    h1, h2, h3, h4, .font-display {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 400;
    }
    img { display: block; max-width: 100%; }
    a { text-decoration: none; color: inherit; }

    /* ── Utilities ── */
    .uppercase { text-transform: uppercase; }
    .italic { font-style: italic; }
    .text-champagne { color: var(--champagne); }
    .text-ivory { color: var(--ivory); }
    .bg-ivory { background: var(--ivory); }
    .bg-sand { background: var(--sand); }
    .bg-carbon { background: var(--carbon); }

    /* ── Navbar ── */
    nav.main-nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 50;
      backdrop-filter: blur(12px);
      background: rgba(250,246,240,0.75);
      border-bottom: 1px solid rgba(28,22,14,0.12);
    }
    .nav-inner {
      max-width: 1280px; margin: 0 auto;
      padding: 1.25rem 1.5rem;
      display: flex; align-items: center; justify-content: space-between;
    }
    .logo-we { display: block; font-family: 'Jost', sans-serif; font-size: 9px; letter-spacing: 0.45em; text-transform: uppercase; }
    .logo-glow { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; letter-spacing: 0.3em; }
    .nav-links { display: flex; gap: 2.5rem; }
    .nav-links a { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: rgba(28,22,14,0.8); transition: color .2s; }
    .nav-links a:hover { color: var(--carbon); }
    .nav-toggle { display: none; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; background: none; border: none; cursor: pointer; }
    .mobile-menu { display: none; flex-direction: column; gap: 1rem; padding: 1rem 1.5rem; border-top: 1px solid var(--border); background: var(--ivory); }
    .mobile-menu.open { display: flex; }
    .mobile-menu a { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; }
    @media (max-width: 767px) {
      .nav-links { display: none; }
      .nav-toggle { display: block; }
    }

    /* ── Hero ── */
    #inicio {
      position: relative; min-height: 100vh;
      display: flex; align-items: center;
      padding-top: 6rem; overflow: hidden;
    }
    .hero-bg { position: absolute; inset: 0; }
    .hero-bg img { width: 100%; height: 100%; object-fit: cover; }
    .hero-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to right, rgba(250,246,240,0.85) 0%, rgba(250,246,240,0.5) 50%, rgba(250,246,240,0.15) 100%);
    }
    .hero-content {
      position: relative; max-width: 1280px; margin: 0 auto;
      padding: 5rem 1.5rem; width: 100%;
    }
    .hero-text { animation: fadeUp 1s ease-out both; }
    .hero-kicker { font-size: 10px; letter-spacing: 0.5em; text-transform: uppercase; color: rgba(28,22,14,0.6); margin-bottom: 1.5rem; }
    .hero-h1-we { display: block; font-family: 'Jost', sans-serif; font-size: clamp(1.5rem, 4vw, 3rem); letter-spacing: 0.2em; text-transform: uppercase; }
    .hero-h1-glow { display: block; font-style: italic; color: var(--champagne); font-size: clamp(3.5rem, 9vw, 8rem); line-height: 1; }
    .hero-sub { margin-top: 1.5rem; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(1.2rem, 3vw, 1.75rem); color: rgba(28,22,14,0.8); }
    .hero-p { margin-top: 2rem; max-width: 28rem; color: rgba(28,22,14,0.7); line-height: 1.7; }
    .hero-cta { margin-top: 2.5rem; display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; }
    .btn-primary {
      display: inline-flex; align-items: center; gap: .75rem;
      background: var(--carbon); color: var(--ivory);
      padding: 1.25rem 2.5rem; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
      transition: background .2s, color .2s;
    }
    .btn-primary:hover { background: var(--champagne); color: var(--carbon); }
    .hero-tags { font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase; color: rgba(28,22,14,0.5); }

    /* ── Marquee ── */
    .marquee-wrap {
      border-top: 1px solid rgba(28,22,14,0.15);
      border-bottom: 1px solid rgba(28,22,14,0.15);
      background: #1c160e; color: var(--ivory);
      overflow: hidden;
    }
    .marquee-track {
      display: inline-flex; white-space: nowrap;
      animation: marquee 40s linear infinite;
      padding: 1rem 0;
    }
    .marquee-item {
      display: inline-flex; align-items: center;
      font-size: 10px; letter-spacing: 0.5em; text-transform: uppercase;
      margin-right: 2.5rem; flex-shrink: 0;
    }
    .marquee-star { color: var(--champagne); margin-left: .5rem; }
    @keyframes marquee {
      from { transform: translateX(0); }
      to { transform: translateX(-50%); }
    }

    /* ── Sections ── */
    section { padding: 6rem 1.5rem; }
    .section-kicker { font-size: 10px; letter-spacing: 0.5em; text-transform: uppercase; color: var(--champagne); margin-bottom: 1rem; }
    .section-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem, 5vw, 3.75rem); line-height: 1.1; }
    .max-w-3 { max-width: 48rem; margin: 0 auto; text-align: center; }
    .max-w-6 { max-width: 72rem; margin: 0 auto; }
    .max-w-4 { max-width: 56rem; margin: 0 auto; }
    .max-w-2 { max-width: 40rem; margin: 0 auto; }
    .grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
    @media (max-width: 767px) { .grid-2 { grid-template-columns: 1fr; } }

    /* ── Video section ── */
    .video-placeholder {
      position: relative; width: 100%; aspect-ratio: 16/9;
      border: 1px solid rgba(28,22,14,0.15); box-shadow: 0 25px 50px rgba(0,0,0,.15);
      overflow: hidden; margin: 3rem auto;
    }
    .video-placeholder img { width: 100%; height: 100%; object-fit: cover; opacity: .6; }
    .video-overlay {
      position: absolute; inset: 0;
      display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem;
    }
    .play-btn {
      width: 4rem; height: 4rem; border-radius: 50%;
      border: 2px solid rgba(28,22,14,0.4);
      display: flex; align-items: center; justify-content: center;
    }
    .play-btn svg { color: rgba(28,22,14,0.6); margin-left: 4px; }

    /* ── Photo strip ── */
    .strip-mask {
      -webkit-mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
      mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
    }
    .strip-track {
      display: flex; gap: 12px;
      animation: photoMarquee 50s linear infinite;
      will-change: transform;
    }
    .strip-track:hover { animation-play-state: paused; }
    .strip-item { flex-shrink: 0; width: 260px; height: 340px; overflow: hidden; }
    .strip-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(0.23,1,0.32,1); }
    .strip-item img:hover { transform: scale(1.05); }
    @keyframes photoMarquee {
      from { transform: translateX(0); }
      to { transform: translateX(-50%); }
    }

    /* ── Pilares grid ── */
    .pilares-grid {
      display: grid; grid-template-columns: repeat(5,1fr);
      border: 1px solid var(--border);
    }
    @media (max-width: 767px) { .pilares-grid { grid-template-columns: 1fr 1fr; } }
    .pilar { background: var(--ivory); padding: 2.5rem; border-right: 1px solid var(--border); transition: background .2s; }
    .pilar:last-child { border-right: none; }
    .pilar:hover { background: var(--sand); }
    .pilar-n { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--champagne); font-size: 1.5rem; }
    .pilar-t { font-family: 'Cormorant Garamond', serif; font-size: 1.75rem; margin-top: 1rem; }
    .pilar-d { margin-top: 1rem; font-size: .875rem; color: rgba(28,22,14,0.7); line-height: 1.6; }

    /* ── Avatar ── */
    .avatar-list { margin-top: 2.5rem; list-style: none; }
    .avatar-list li {
      display: flex; gap: 1rem;
      border-bottom: 1px solid rgba(250,246,240,0.15);
      padding-bottom: 1.25rem; margin-bottom: 1.25rem;
      color: rgba(250,246,240,0.85);
    }
    .avatar-star { color: var(--champagne); font-family: 'Cormorant Garamond', serif; font-style: italic; }
    .btn-outline-champagne {
      display: inline-flex; align-items: center; gap: .75rem;
      border: 1px solid var(--champagne); color: var(--champagne);
      padding: 1.25rem 2.5rem; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
      transition: background .2s, color .2s; margin-top: 2.5rem;
    }
    .btn-outline-champagne:hover { background: var(--champagne); color: var(--carbon); }

    /* ── Manifiesto ── */
    .manifiesto-lines { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.3rem, 3vw, 1.75rem); line-height: 1.8; color: rgba(28,22,14,0.85); margin-top: 3rem; }
    .divider { width: 1px; height: 4rem; background: var(--champagne); margin: 2rem auto; }

    /* ── Steps ── */
    .steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2.5rem; }
    @media (max-width: 767px) { .steps-grid { grid-template-columns: 1fr 1fr; } }
    .step { border-top: 1px solid rgba(28,22,14,0.2); padding-top: 1.5rem; }
    .step-n { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--champagne); font-size: 1.25rem; }
    .step-t { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; margin-top: .75rem; }
    .step-d { margin-top: .75rem; font-size: .875rem; color: rgba(28,22,14,0.7); line-height: 1.6; }

    /* ── Deseo ── */
    .deseo-section { padding: 8rem 1.5rem; background: var(--carbon); color: var(--ivory); text-align: center; }
    .deseo-sub { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.2rem, 3vw, 1.75rem); font-style: italic; color: rgba(250,246,240,0.7); }
    .deseo-main { margin-top: 2.5rem; font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem, 5vw, 3.75rem); line-height: 1.2; }
    .deseo-cta { font-style: italic; color: var(--champagne); }

    /* ── Form ── */
    .form-box { background: var(--sand); padding: 3.5rem; }
    @media (max-width: 767px) { .form-box { padding: 2rem; } }
    .form-title { font-family: 'Cormorant Garamond', serif; font-size: 1.875rem; text-align: center; margin-bottom: .5rem; }
    .form-field {
      width: 100%; background: transparent;
      border: none; border-bottom: 1px solid rgba(28,22,14,0.3);
      padding: .75rem .25rem; font-family: 'Jost', sans-serif;
      font-size: .875rem; color: var(--carbon); outline: none;
      transition: border-color .2s;
    }
    .form-field:focus { border-color: var(--champagne); }
    .form-field::placeholder { color: rgba(28,22,14,0.4); }
    .form-gap { display: flex; flex-direction: column; gap: 1.25rem; margin-top: 1.25rem; }
    .radio-group { margin-top: 1.5rem; }
    .radio-label { font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: rgba(28,22,14,0.6); margin-bottom: .75rem; display: block; }
    .radio-opt { display: flex; align-items: center; gap: .75rem; font-size: .875rem; cursor: pointer; padding: .4rem 0; transition: color .2s; }
    .radio-opt:hover { color: var(--champagne); }
    .btn-submit {
      width: 100%; background: var(--carbon); color: var(--ivory);
      border: none; padding: 1.25rem; font-family: 'Jost', sans-serif;
      font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
      cursor: pointer; transition: background .2s, color .2s; margin-top: 1.5rem;
    }
    .btn-submit:hover { background: var(--champagne); color: var(--carbon); }
    .form-note { font-size: .75rem; text-align: center; color: rgba(28,22,14,0.55); font-style: italic; font-weight: 300; margin-top: .75rem; }
    .cta-row { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-top: 2.5rem; }
    .btn-outline {
      display: inline-flex; align-items: center; gap: .75rem;
      border: 1px solid var(--carbon); color: var(--carbon);
      padding: 1.25rem 2.5rem; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
      transition: background .2s, color .2s;
    }
    .btn-outline:hover { background: var(--carbon); color: var(--ivory); }

    /* ── Footer ── */
    footer {
      border-top: 1px solid var(--border); padding: 3rem 1.5rem;
      text-align: center;
    }
    .footer-year { margin-top: 1.5rem; font-size: .75rem; color: rgba(28,22,14,0.5); }

    /* ── Animations ── */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(20px); }
      to { opacity: 1; transform: translateY(0); }
    }

    /* ── Responsive helpers ── */
    .text-center { text-align: center; }
    .mt-1 { margin-top: .5rem; }
    .mt-2 { margin-top: 1rem; }
    .mt-3 { margin-top: 1.5rem; }
    .mt-4 { margin-top: 2rem; }
    .mt-5 { margin-top: 2.5rem; }
    .mt-6 { margin-top: 3rem; }