/* Renovación page styles */

  :root {
    --red: #C1272D;
    --red-deep: #7A1418;
    --red-bright: #E63946;
    --cream: #F5EFE6;
    --ink: #0A0A0A;
    --ink-soft: #1A1A1A;
  }

  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }

  body {
    font-family: 'Sora', sans-serif;
    background: var(--ink);
    color: var(--cream);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }

  .display { font-family: 'Anton', sans-serif; line-height: 0.9; text-transform: uppercase; letter-spacing: 0.005em; }
  .it { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; text-transform: lowercase; letter-spacing: -0.01em; }

  /* ================= NAV ================= */
  nav.top {
    position: fixed; top: 0; left: 0; right: 0;
    padding: 22px 40px;
    display: flex; justify-content: space-between; align-items: center;
    z-index: 50;
    color: var(--cream);
    background: linear-gradient(180deg, rgba(10,10,10,0.88) 0%, rgba(10,10,10,0.55) 75%, transparent);
  }
  nav.top .brand { font-family: 'Anton', sans-serif; font-size: 22px; letter-spacing: 0.08em; }
  nav.top .brand .dot { color: var(--red-bright); margin: 0 6px; }
  nav.top ul { display: flex; gap: 32px; list-style: none; font-size: 12px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; margin: 0; padding: 0; }
  nav.top ul a { color: var(--cream); text-decoration: none; }
  nav.top ul a.menu-soon { opacity: 0.45; cursor: default; }
  nav.top ul a.menu-soon::after { content: ''; }

  /* Hamburger button (hidden on desktop) */
  #nav-toggle { display: none; }
  .hamburger {
    display: none;
    width: 36px; height: 36px;
    cursor: pointer;
    position: relative;
    z-index: 60;
  }
  .hamburger span {
    position: absolute; left: 6px; right: 6px;
    height: 2px; background: var(--cream);
    transition: transform .35s ease, top .35s ease, opacity .25s;
  }
  .hamburger span:nth-child(1) { top: 11px; }
  .hamburger span:nth-child(2) { top: 17px; }
  .hamburger span:nth-child(3) { top: 23px; }
  #nav-toggle:checked ~ .hamburger span:nth-child(1) { top: 17px; transform: rotate(45deg); }
  #nav-toggle:checked ~ .hamburger span:nth-child(2) { opacity: 0; }
  #nav-toggle:checked ~ .hamburger span:nth-child(3) { top: 17px; transform: rotate(-45deg); }

  /* ================= HERO ================= */
  .hero {
    min-height: 100vh;
    position: relative;
    overflow: hidden;
    background: var(--ink);
  }

  /* Background image with overlay */
  .hero-bg {
    position: absolute; inset: 0;
    background-image: url('fotos/_MG_8111.JPG');
    background-size: cover; background-position: center 35%;
    filter: contrast(1.05) saturate(1.05);
    animation: slowZoom 20s ease-in-out infinite alternate;
  }
  @keyframes slowZoom {
    from { transform: scale(1.0); }
    to { transform: scale(1.12); }
  }
  .hero-bg::after {
    content: ''; position: absolute; inset: 0;
    background:
      linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.4) 40%, rgba(10,10,10,0.95) 100%),
      linear-gradient(90deg, rgba(193,39,45,0.35) 0%, transparent 50%);
  }
  /* Grain */
  .hero::before {
    content: ''; position: absolute; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.07 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    pointer-events: none; z-index: 5; mix-blend-mode: overlay;
  }

  .hero-inner {
    position: relative; z-index: 10;
    min-height: 100vh;
    padding: 140px 40px 120px;
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 60px;
    align-items: end;
  }

  .eyebrow {
    display: inline-flex; align-items: center; gap: 14px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.28em; text-transform: uppercase;
    margin-bottom: 32px;
  }
  .eyebrow::before {
    content: ''; width: 36px; height: 2px; background: var(--red-bright);
  }
  .eyebrow .live {
    width: 8px; height: 8px; border-radius: 50%; background: var(--red-bright);
    animation: blink 1.4s ease-in-out infinite;
  }
  @keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

  .hero h1 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(64px, 11vw, 180px);
    line-height: 0.86;
    text-transform: uppercase;
    margin-bottom: 32px;
    letter-spacing: -0.005em;
  }
  .hero h1 span { display: block; overflow: hidden; }
  .hero h1 span > i { display: inline-block; font-style: normal; }
  .hero h1 .word-rise i {
    animation: rise 1s cubic-bezier(.2,.8,.2,1) both;
  }
  .hero h1 .l1 i { animation-delay: 0.1s; }
  .hero h1 .l2 i { animation-delay: 0.25s; }
  .hero h1 .l3 i { animation-delay: 0.4s; }

  @keyframes rise {
    0% { transform: translateY(110%); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
  }

  .hero h1 .accent {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    text-transform: lowercase;
    color: var(--red-bright);
    font-size: 0.85em;
    letter-spacing: -0.02em;
  }

  .hero .lead {
    font-size: 17px; line-height: 1.6; max-width: 480px;
    color: rgba(245, 239, 230, 0.78);
    margin-bottom: 40px;
    animation: fade .9s ease 0.7s both;
  }
  @keyframes fade { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

  .cta-row { display: flex; gap: 14px; flex-wrap: wrap; animation: fade .9s ease 0.85s both; }
  .btn {
    display: inline-flex; align-items: center; gap: 14px;
    padding: 18px 30px;
    font-size: 13px; font-weight: 600;
    letter-spacing: 0.12em; text-transform: uppercase;
    text-decoration: none;
    transition: all .3s ease;
    cursor: pointer; border: none;
    position: relative; overflow: hidden;
  }
  .btn-primary { background: var(--red-bright); color: var(--cream); }
  .btn-primary::before {
    content: ''; position: absolute; inset: 0;
    background: var(--cream);
    transform: translateY(100%);
    transition: transform .35s ease;
  }
  .btn-primary:hover::before { transform: translateY(0); }
  .btn-primary span { position: relative; z-index: 2; transition: color .35s; }
  .btn-primary:hover span { color: var(--ink); }

  .btn-ghost { background: transparent; color: var(--cream); border: 1px solid rgba(245,239,230,0.4); }
  .btn-ghost:hover { background: var(--cream); color: var(--ink); }

  /* Hero side: floating image collage */
  .hero-side { position: relative; height: 480px; animation: fade 1.2s ease 0.9s both; }

  .float-card {
    position: absolute;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,0.5);
  }
  .float-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .float-card.f1 {
    width: 240px; height: 320px;
    top: 20px; right: 60px;
    transform: rotate(4deg);
    animation: float1 6s ease-in-out infinite;
  }
  .float-card.f2 {
    width: 200px; height: 260px;
    bottom: 20px; right: 200px;
    transform: rotate(-6deg);
    animation: float2 7s ease-in-out infinite;
    z-index: 2;
  }
  .float-card.f3 {
    width: 160px; height: 200px;
    top: 100px; right: 280px;
    transform: rotate(8deg);
    animation: float3 5s ease-in-out infinite;
  }
  @keyframes float1 { 0%,100% { transform: rotate(4deg) translateY(0); } 50% { transform: rotate(4deg) translateY(-14px); } }
  @keyframes float2 { 0%,100% { transform: rotate(-6deg) translateY(0); } 50% { transform: rotate(-6deg) translateY(-10px); } }
  @keyframes float3 { 0%,100% { transform: rotate(8deg) translateY(0); } 50% { transform: rotate(8deg) translateY(-18px); } }

  /* Sticker badge */
  .badge {
    position: absolute;
    top: -10px; right: 10px;
    width: 110px; height: 110px;
    background: var(--red-bright); color: var(--cream);
    border-radius: 50%;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    font-family: 'Anton', sans-serif;
    transform: rotate(-12deg);
    z-index: 5;
    animation: spin 16s linear infinite;
    box-shadow: 0 14px 30px rgba(193,39,45,0.4);
  }
  .badge .b1 { font-size: 10px; letter-spacing: 0.2em; opacity: .9; }
  .badge .b2 { font-size: 30px; line-height: 1; margin: 4px 0; }
  .badge .b3 { font-size: 10px; letter-spacing: 0.2em; opacity: .9; }
  @keyframes spin { from { transform: rotate(-12deg); } to { transform: rotate(348deg); } }

  /* Ticker at bottom of hero */
  .ticker {
    position: absolute; bottom: 0; left: 0; right: 0;
    background: var(--red);
    padding: 18px 0;
    overflow: hidden;
    z-index: 15;
    border-top: 1px solid rgba(245,239,230,0.15);
  }
  .ticker-track {
    display: flex; gap: 60px;
    white-space: nowrap;
    animation: marquee 32s linear infinite;
    font-family: 'Anton', sans-serif;
    font-size: 22px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--cream);
  }
  .ticker-track .star { color: rgba(245,239,230,0.5); }
  @keyframes marquee {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }

  /* ================= STATS BAND ================= */
  .stats-band {
    background: var(--ink);
    padding: 60px 40px;
    border-bottom: 1px solid rgba(245,239,230,0.1);
  }
  .stats-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 40px;
  }
  .stat-item {
    border-left: 2px solid var(--red-bright);
    padding-left: 24px;
  }
  .stat-num {
    font-family: 'Anton', sans-serif;
    font-size: 84px; line-height: 0.95;
    color: var(--cream);
  }
  .stat-num .plus { color: var(--red-bright); }
  .stat-lbl {
    font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
    color: rgba(245,239,230,0.6);
    margin-top: 8px;
  }

  /* ================= SERVICES ================= */
  .services {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px 100px;
    position: relative;
  }
  .services-header {
    max-width: 1400px; margin: 0 auto 70px;
    display: grid; grid-template-columns: 1.5fr 1fr;
    gap: 60px; align-items: end;
  }
  .section-tag {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--red);
    margin-bottom: 24px;
  }
  .section-tag::before { content: ''; width: 32px; height: 2px; background: var(--red); }

  .services-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(56px, 7vw, 110px);
    line-height: 0.92;
    text-transform: uppercase;
  }
  .services-header h2 .it { color: var(--red); }
  .services-header p { font-size: 16px; line-height: 1.6; color: var(--ink-soft); max-width: 420px; opacity: .85; }

  .services-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(12, 1fr);
    gap: 20px;
  }

  .card {
    position: relative;
    overflow: hidden;
    min-height: 480px;
    cursor: pointer;
    text-decoration: none;
    color: var(--cream);
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 36px 32px;
    isolation: isolate;
  }
  .card-1 { grid-column: span 7; min-height: 540px; }
  .card-2 { grid-column: span 5; min-height: 540px; }
  .card-3 { grid-column: span 5; }
  .card-4 { grid-column: span 7; }

  .card-img {
    position: absolute; inset: 0; z-index: -2;
    background-size: cover; background-position: center;
    transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
  }
  .card:hover .card-img { transform: scale(1.08); }

  .card::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(180deg, transparent 30%, rgba(10,10,10,0.4) 60%, rgba(10,10,10,0.92) 100%);
    transition: background .4s;
  }
  .card:hover::before {
    background: linear-gradient(180deg, transparent 10%, rgba(10,10,10,0.55) 50%, rgba(10,10,10,0.96) 100%);
  }
  .card-2::before {
    background: linear-gradient(180deg, rgba(193,39,45,0.2) 0%, rgba(122,20,24,0.6) 60%, rgba(122,20,24,0.95) 100%);
  }
  .card-2:hover::before {
    background: linear-gradient(180deg, rgba(193,39,45,0.3) 0%, rgba(122,20,24,0.75) 50%, rgba(122,20,24,0.98) 100%);
  }

  .card-num {
    position: absolute; top: 32px; left: 32px;
    font-family: 'Anton', sans-serif;
    font-size: 13px; letter-spacing: 0.25em;
    opacity: .85;
  }
  .card-tag {
    position: absolute; top: 32px; right: 32px;
    font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
    padding: 8px 14px; border: 1px solid rgba(245,239,230,0.4); border-radius: 99px;
  }
  .card-title {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 4vw, 64px);
    line-height: 0.92;
    text-transform: uppercase;
    margin-bottom: 12px;
    transition: transform .5s;
  }
  .card:hover .card-title { transform: translateY(-4px); }
  .card-title .em { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; text-transform: lowercase; color: var(--red-bright); }
  .card-2 .card-title .em { color: var(--cream); opacity: .7; }

  .card-desc {
    font-size: 14px; line-height: 1.55; opacity: .82;
    max-width: 420px; margin-bottom: 24px;
    max-height: 0; overflow: hidden;
    transition: max-height .5s ease, margin-bottom .5s ease;
  }
  .card:hover .card-desc { max-height: 100px; margin-bottom: 24px; }

  .card-cta {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    transition: gap .3s;
  }
  .card:hover .card-cta { gap: 22px; }
  .card-cta .arr {
    display: inline-block; width: 26px; height: 1px; background: currentColor; position: relative;
  }
  .card-cta .arr::after {
    content: ''; position: absolute; right: 0; top: -3px;
    width: 7px; height: 7px;
    border-top: 1px solid currentColor; border-right: 1px solid currentColor;
    transform: rotate(45deg);
  }

  /* ================= CLUB (SOBRE NOSOTROS) ================= */
  .club {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px 120px;
    position: relative;
    overflow: hidden;
  }
  .club-inner {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 80px;
    align-items: center;
    position: relative;
    z-index: 2;
  }
  .club-text .section-tag { color: var(--red); }
  .club-text h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 6vw, 96px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 32px;
  }
  .club-text h2 .it { color: var(--red); }
  .club-text p {
    font-size: 16px; line-height: 1.7;
    color: var(--ink-soft);
    margin-bottom: 20px;
    max-width: 540px;
  }
  .club-text p strong { color: var(--ink); font-weight: 600; }
  .club-cta {
    display: inline-flex; align-items: center; gap: 14px;
    margin-top: 24px;
    padding: 18px 30px;
    background: var(--ink); color: var(--cream);
    font-size: 13px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
    text-decoration: none;
    transition: background .3s, transform .3s;
  }
  .club-cta:hover { background: var(--red); transform: translateY(-2px); }

  /* Big EST 2010 monogram on left */
  .club-mono {
    position: absolute;
    top: 40px; left: -20px;
    font-family: 'Anton', sans-serif;
    font-size: 280px; line-height: 0.85;
    color: var(--red);
    opacity: 0.06;
    pointer-events: none;
    letter-spacing: -0.04em;
    z-index: 1;
  }

  /* Photo composition right side */
  .club-photo-wrap {
    position: relative;
    height: 580px;
  }
  .club-photo-main {
    position: absolute;
    top: 0; right: 0;
    width: 100%; height: 100%;
    overflow: hidden;
    background-size: cover; background-position: center;
  }
  .club-photo-tag {
    position: absolute;
    bottom: -28px; left: -28px;
    background: var(--red);
    color: var(--cream);
    padding: 28px 36px;
    font-family: 'Anton', sans-serif;
    z-index: 3;
    box-shadow: 0 20px 50px rgba(193,39,45,0.3);
  }
  .club-photo-tag .yr { font-size: 64px; line-height: 0.9; }
  .club-photo-tag .lb { font-size: 11px; letter-spacing: 0.25em; opacity: .85; margin-top: 6px; font-family: 'Sora', sans-serif; font-weight: 600; }

  /* ================= PILARES ================= */
  .pillars {
    background: var(--ink);
    color: var(--cream);
    padding: 120px 40px;
    position: relative;
    overflow: hidden;
  }
  .pillars::before {
    content: ''; position: absolute;
    top: -50%; right: -10%;
    width: 60%; height: 200%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.15) 0%, transparent 60%);
    pointer-events: none;
  }
  .pillars-header {
    max-width: 1400px; margin: 0 auto 70px;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 60px; align-items: end;
    position: relative; z-index: 2;
  }
  .pillars-header .section-tag { color: var(--red-bright); }
  .pillars-header .section-tag::before { background: var(--red-bright); }
  .pillars-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 6vw, 96px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .pillars-header h2 .it { color: var(--red-bright); }
  .pillars-header p {
    font-size: 15px; line-height: 1.6;
    color: rgba(245,239,230,0.75);
    max-width: 380px;
  }

  .pillars-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid rgba(245,239,230,0.15);
    position: relative; z-index: 2;
  }
  .pillar {
    padding: 48px 32px 40px;
    border-right: 1px solid rgba(245,239,230,0.15);
    position: relative;
    transition: background .35s;
  }
  .pillar:last-child { border-right: none; }
  .pillar:hover { background: rgba(193,39,45,0.08); }
  .pillar::after {
    content: ''; position: absolute;
    bottom: 0; left: 0;
    width: 0; height: 3px;
    background: var(--red-bright);
    transition: width .4s ease;
  }
  .pillar:hover::after { width: 100%; }
  .pillar-num {
    font-family: 'Anton', sans-serif;
    font-size: 14px; letter-spacing: 0.25em;
    color: var(--red-bright);
    margin-bottom: 32px;
  }
  .pillar-icon {
    width: 44px; height: 44px;
    margin-bottom: 24px;
    color: var(--cream);
  }
  .pillar h3 {
    font-family: 'Anton', sans-serif;
    font-size: 32px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 16px;
  }
  .pillar p {
    font-size: 14px; line-height: 1.55;
    color: rgba(245,239,230,0.7);
  }

  /* ================= PATROCINADORES ================= */
  .sponsors {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px 120px;
  }
  .sponsors-header {
    max-width: 1400px; margin: 0 auto 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .sponsors-header .section-tag { color: var(--red); }
  .sponsors-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 6vw, 96px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .sponsors-header h2 .it { color: var(--red); }
  .sponsors-header p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); max-width: 380px; opacity: .85; }

  .sponsors-featured {
    max-width: 1400px; margin: 0 auto 24px;
    display: grid; grid-template-columns: 1.6fr 1fr;
    gap: 24px;
  }
  .feat {
    padding: 44px 40px;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    display: flex; flex-direction: column; justify-content: space-between;
    min-height: 320px;
    transition: transform .3s;
  }
  .feat:hover { transform: translateY(-4px); }
  .feat-main { background: var(--ink); color: var(--cream); }
  .feat-side { background: var(--red); color: var(--cream); }
  .feat-label {
    font-size: 10px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
    opacity: .65; margin-bottom: 20px;
  }
  .feat-logo {
    margin-bottom: 28px;
    height: 80px;
    display: flex; align-items: center;
  }
  .feat-logo img { max-height: 80px; max-width: 240px; filter: brightness(0) invert(1); }
  .feat-main .feat-name {
    font-family: 'Anton', sans-serif;
    font-size: 44px; line-height: 1; text-transform: uppercase; margin-bottom: 12px;
  }
  .feat-side .feat-name {
    font-family: 'Anton', sans-serif;
    font-size: 44px; line-height: 1; text-transform: uppercase; margin-bottom: 12px;
  }
  .feat-desc {
    font-size: 14px; line-height: 1.55; opacity: .82;
    max-width: 480px; margin-bottom: 24px;
  }
  .feat-cta {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    transition: gap .3s;
  }
  .feat:hover .feat-cta { gap: 20px; }
  .feat-cta .arr { display: inline-block; width: 24px; height: 1px; background: currentColor; position: relative; }
  .feat-cta .arr::after { content: ''; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-top: 1px solid currentColor; border-right: 1px solid currentColor; transform: rotate(45deg); }

  .discount-chip {
    display: inline-flex; align-items: center; gap: 10px;
    background: rgba(245,239,230,0.15);
    border: 1px dashed rgba(245,239,230,0.5);
    padding: 10px 14px;
    font-family: 'Anton', sans-serif;
    font-size: 16px; letter-spacing: 0.05em;
    margin-top: 10px; align-self: flex-start;
  }
  .discount-chip .pct { color: var(--cream); }
  .discount-chip .code {
    background: var(--cream); color: var(--red);
    padding: 4px 10px;
    letter-spacing: 0.1em;
  }

  .sponsors-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    border-top: 1px solid rgba(10,10,10,0.12);
    border-left: 1px solid rgba(10,10,10,0.12);
  }
  .sp {
    aspect-ratio: 3 / 2;
    border-right: 1px solid rgba(10,10,10,0.12);
    border-bottom: 1px solid rgba(10,10,10,0.12);
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
    text-decoration: none;
    color: var(--ink-soft);
    font-family: 'Anton', sans-serif;
    font-size: 18px; text-transform: uppercase; letter-spacing: 0.04em;
    text-align: center;
    transition: background .3s, color .3s;
    opacity: .65;
  }
  .sp:hover { background: var(--ink); color: var(--cream); opacity: 1; }

  .sponsors-cta {
    max-width: 1400px; margin: 60px auto 0;
    padding: 36px 44px;
    background: var(--ink); color: var(--cream);
    display: flex; justify-content: space-between; align-items: center; gap: 30px;
    flex-wrap: wrap;
  }
  .sponsors-cta h4 {
    font-family: 'Anton', sans-serif;
    font-size: 28px; text-transform: uppercase;
  }
  .sponsors-cta h4 .it { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; color: var(--red-bright); text-transform: lowercase; }
  .sponsors-cta p { font-size: 14px; color: rgba(245,239,230,0.7); max-width: 480px; margin-top: 6px; }
  .sponsors-cta .btn-primary { background: var(--red-bright); padding: 16px 26px; }

  /* ================= NOTICIAS ================= */
  .news {
    background: var(--ink);
    color: var(--cream);
    padding: 130px 40px 120px;
    position: relative;
  }
  .news-header {
    max-width: 1400px; margin: 0 auto 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .news-header .section-tag { color: var(--red-bright); }
  .news-header .section-tag::before { background: var(--red-bright); }
  .news-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 6vw, 96px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .news-header h2 .it { color: var(--red-bright); }
  .news-header .news-link {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--cream); text-decoration: none;
    align-self: end; justify-self: end;
    transition: gap .3s;
  }
  .news-header .news-link:hover { gap: 20px; color: var(--red-bright); }
  .news-header .news-link .arr { display: inline-block; width: 30px; height: 1px; background: currentColor; position: relative; }
  .news-header .news-link .arr::after { content: ''; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-top: 1px solid currentColor; border-right: 1px solid currentColor; transform: rotate(45deg); }

  .news-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .news-card {
    background: var(--ink-soft);
    text-decoration: none; color: var(--cream);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .35s;
    border: 1px solid rgba(245,239,230,0.08);
  }
  .news-card:hover { transform: translateY(-6px); }
  .news-card-img {
    aspect-ratio: 16 / 10;
    background-size: cover; background-position: center;
    position: relative; overflow: hidden;
  }
  .news-card-img::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(10,10,10,0.4) 100%);
  }
  .news-card-cat {
    position: absolute; top: 16px; left: 16px;
    background: var(--red-bright); color: var(--cream);
    padding: 6px 12px;
    font-size: 10px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    z-index: 2;
  }
  .news-card-body { padding: 28px 26px 30px; }
  .news-card-date {
    font-size: 11px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase;
    color: rgba(245,239,230,0.55);
    margin-bottom: 14px;
  }
  .news-card h3 {
    font-family: 'Anton', sans-serif;
    font-size: 26px; line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .news-card p {
    font-size: 14px; line-height: 1.55;
    color: rgba(245,239,230,0.7);
    margin-bottom: 20px;
  }
  .news-card .more {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--red-bright);
    transition: gap .3s;
  }
  .news-card:hover .more { gap: 18px; }

  /* ================= GALLERY MARQUEE ================= */
  .gallery-marquee {
    background: var(--cream);
    padding: 60px 0 100px;
    overflow: hidden;
  }
  .gm-track {
    display: flex; gap: 24px;
    animation: marquee 40s linear infinite;
  }
  .gm-track img {
    width: 360px; height: 240px; object-fit: cover;
    flex-shrink: 0;
    filter: grayscale(0.15);
    transition: filter .3s, transform .3s;
  }
  .gm-track img:hover { filter: none; transform: scale(1.03); }

  /* ================= CTA FINAL ================= */
  .final-cta {
    position: relative;
    min-height: 600px;
    overflow: hidden;
    display: flex; align-items: center;
    padding: 100px 40px;
    color: var(--cream);
  }
  .final-cta-bg {
    position: absolute; inset: 0;
    background-image: url('fotos/_MG_8111.JPG');
    background-size: cover; background-position: center 25%;
    filter: contrast(1.05);
    animation: slowZoom 25s ease-in-out infinite alternate;
  }
  .final-cta-bg::after {
    content: ''; position: absolute; inset: 0;
    background:
      linear-gradient(135deg, rgba(193,39,45,0.85) 0%, rgba(122,20,24,0.7) 50%, rgba(10,10,10,0.85) 100%);
  }
  .final-cta-inner {
    position: relative; z-index: 2;
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 80px; align-items: center; width: 100%;
  }
  .final-cta .eyebrow { margin-bottom: 28px; }
  .final-cta h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(56px, 8vw, 140px);
    line-height: 0.9;
    text-transform: uppercase;
    margin-bottom: 28px;
  }
  .final-cta h2 .it { color: var(--cream); opacity: .65; }
  .final-cta p {
    font-size: 17px; line-height: 1.6;
    color: rgba(245,239,230,0.85);
    margin-bottom: 36px;
    max-width: 540px;
  }
  .final-cta-right {
    text-align: left;
  }
  .deadline-box {
    background: var(--ink);
    padding: 32px 32px 28px;
    border: 1px solid rgba(245,239,230,0.15);
  }
  .deadline-box .dl-label {
    font-size: 10px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 14px;
  }
  .deadline-box .dl-date {
    font-family: 'Anton', sans-serif;
    font-size: 56px; line-height: 1;
    margin-bottom: 8px;
  }
  .deadline-box .dl-sub {
    font-size: 13px; color: rgba(245,239,230,0.7);
    margin-bottom: 24px;
  }
  .deadline-box .dl-stat {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 14px 0;
    border-top: 1px solid rgba(245,239,230,0.12);
    font-size: 13px;
  }
  .deadline-box .dl-stat span:last-child { font-family: 'Anton', sans-serif; font-size: 22px; color: var(--red-bright); }

  /* ================= FOOTER ================= */
  footer {
    background: var(--ink);
    color: var(--cream);
    padding: 100px 40px 30px;
    border-top: 1px solid rgba(245,239,230,0.08);
  }
  .footer-top {
    max-width: 1400px; margin: 0 auto 80px;
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 60px;
  }
  .footer-brand h3 {
    font-family: 'Anton', sans-serif;
    font-size: 36px; text-transform: uppercase; letter-spacing: 0.04em;
    margin-bottom: 20px;
  }
  .footer-brand h3 .dot { color: var(--red-bright); }
  .footer-brand p {
    font-size: 14px; line-height: 1.6;
    color: rgba(245,239,230,0.65);
    max-width: 340px;
    margin-bottom: 28px;
  }
  .socials { display: flex; gap: 12px; }
  .socials a {
    width: 42px; height: 42px;
    border: 1px solid rgba(245,239,230,0.2);
    display: flex; align-items: center; justify-content: center;
    color: var(--cream); text-decoration: none;
    transition: all .3s;
  }
  .socials a:hover { background: var(--red-bright); border-color: var(--red-bright); transform: translateY(-3px); }
  .socials svg { width: 18px; height: 18px; }

  .footer-col h5 {
    font-size: 11px; font-weight: 600; letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 24px;
  }
  .footer-col ul { list-style: none; }
  .footer-col li { margin-bottom: 12px; }
  .footer-col a {
    color: rgba(245,239,230,0.7);
    text-decoration: none;
    font-size: 14px;
    transition: color .2s, padding-left .2s;
  }
  .footer-col a:hover { color: var(--cream); padding-left: 6px; }

  .footer-contact-line {
    font-size: 14px; line-height: 1.6;
    color: rgba(245,239,230,0.7);
    margin-bottom: 10px;
  }
  .footer-contact-line strong { color: var(--cream); display: block; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 4px; font-weight: 600; }

  .footer-bottom {
    max-width: 1400px; margin: 0 auto;
    padding-top: 30px;
    border-top: 1px solid rgba(245,239,230,0.1);
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 16px;
    font-size: 12px;
    color: rgba(245,239,230,0.5);
  }
  .footer-bottom .legal-links { display: flex; gap: 20px; }
  .footer-bottom a {
    color: rgba(245,239,230,0.5);
    text-decoration: none;
    transition: color .2s;
  }
  .footer-bottom a:hover { color: var(--cream); }

  /* ================= NOTES ================= */
  .annotations {
    background: var(--ink); color: var(--cream);
    padding: 100px 40px;
    border-top: 1px solid rgba(245,239,230,0.1);
  }
  .annotations h3 {
    font-family: 'Anton', sans-serif;
    font-size: 44px; text-transform: uppercase;
    margin-bottom: 40px;
    max-width: 1400px; margin-left: auto; margin-right: auto;
  }
  .annotations h3 .it { color: var(--red-bright); }
  .anno-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .anno {
    padding: 28px 24px;
    border: 1px solid rgba(245,239,230,0.15);
    transition: border-color .3s, background .3s;
  }
  .anno:hover { border-color: var(--red-bright); background: rgba(193,39,45,0.05); }
  .anno .n { font-family: 'Anton', sans-serif; color: var(--red-bright); font-size: 22px; margin-bottom: 12px; }
  .anno p { font-size: 14px; line-height: 1.6; opacity: .85; }
  .anno strong { color: var(--cream); }


  /* ================= PAGE HERO (inner pages) ================= */
  .page-hero {
    min-height: 70vh;
    position: relative;
    overflow: hidden;
    background: var(--ink);
    display: flex; align-items: flex-end;
    padding: 140px 40px 80px;
    color: var(--cream);
  }
  .page-hero-bg {
    position: absolute; inset: 0;
    background-image: url('fotos/heros/club.jpg');
    background-size: cover; background-position: center 35%;
    filter: contrast(1.05);
  }
  .page-hero-bg::after {
    content: ''; position: absolute; inset: 0;
    background:
      linear-gradient(180deg, rgba(10,10,10,0.5) 0%, rgba(10,10,10,0.55) 40%, rgba(10,10,10,0.95) 100%),
      linear-gradient(90deg, rgba(193,39,45,0.3) 0%, transparent 60%);
  }
  .page-hero-inner {
    position: relative; z-index: 2;
    max-width: 1400px; margin: 0 auto; width: 100%;
  }
  .page-hero h1 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 8vw, 140px);
    line-height: 0.9;
    text-transform: uppercase;
    margin-bottom: 28px;
  }
  .page-hero h1 .it { color: var(--red-bright); }
  .page-hero .lead {
    font-size: 18px; line-height: 1.6;
    max-width: 620px;
    color: rgba(245,239,230,0.82);
  }

  /* ================= TIMELINE ================= */
  .timeline { background: var(--cream); color: var(--ink); padding: 130px 40px 110px; }
  .timeline-header { max-width: 1100px; margin: 0 auto 70px; }
  .timeline-header .section-tag { color: var(--red); }
  .timeline-header .section-tag::before { background: var(--red); }
  .timeline-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5.5vw, 88px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .timeline-header h2 .it { color: var(--red); }
  .timeline-track { max-width: 1100px; margin: 0 auto; position: relative; }
  .timeline-track::before {
    content: ''; position: absolute;
    top: 30px; bottom: 30px;
    left: 100px;
    width: 2px;
    background: linear-gradient(180deg, transparent, var(--red) 6%, var(--red) 94%, transparent);
  }
  .milestone {
    position: relative;
    padding: 30px 380px 50px 160px;
    margin-bottom: 30px;
    min-height: 260px;
  }
  .milestone::before {
    content: ''; position: absolute;
    left: 92px; top: 42px;
    width: 18px; height: 18px;
    background: var(--red);
    border-radius: 50%;
    box-shadow: 0 0 0 6px var(--cream), 0 0 0 7px var(--red);
    z-index: 2;
  }
  .milestone .year {
    position: absolute; left: 0; top: 28px;
    font-family: 'Anton', sans-serif;
    font-size: 42px; line-height: 1;
    color: var(--red);
  }
  .milestone h3 {
    font-family: 'Anton', sans-serif;
    font-size: 30px; line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 12px;
  }
  .milestone p {
    font-size: 15px; line-height: 1.65;
    color: var(--ink-soft);
    max-width: 640px;
  }
  .milestone-photo {
    position: absolute;
    right: 0; top: 30px;
    width: 340px;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,0.18);
  }
  .milestone-photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1s cubic-bezier(.2,.8,.2,1);
    filter: contrast(1.02) saturate(1.05);
  }
  .milestone:hover .milestone-photo img { transform: scale(1.05); }
  .milestone-photo::after {
    content: attr(data-year);
    position: absolute;
    bottom: 12px; left: 12px;
    background: var(--ink);
    color: var(--cream);
    padding: 6px 12px;
    font-family: 'Anton', sans-serif;
    font-size: 14px; letter-spacing: 0.12em;
    z-index: 2;
  }

  /* ================= PHILOSOPHY ================= */
  .philosophy { background: var(--ink); color: var(--cream); padding: 130px 40px; position: relative; overflow: hidden; }
  .philosophy::before {
    content: ''; position: absolute;
    top: -30%; left: -10%;
    width: 50%; height: 160%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.12) 0%, transparent 60%);
    pointer-events: none;
  }
  .philosophy-header {
    position: relative; z-index: 2;
    max-width: 1400px; margin: 0 auto 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .philosophy-header .section-tag { color: var(--red-bright); }
  .philosophy-header .section-tag::before { background: var(--red-bright); }
  .philosophy-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(44px, 5.5vw, 88px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .philosophy-header h2 .it { color: var(--red-bright); }
  .philosophy-header p { font-size: 15px; line-height: 1.6; color: rgba(245,239,230,0.75); max-width: 380px; }
  .philosophy-grid {
    position: relative; z-index: 2;
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .phi-item {
    padding: 44px 32px 38px;
    background: var(--ink-soft);
    border: 1px solid rgba(245,239,230,0.08);
    transition: border-color .35s, transform .35s;
  }
  .phi-item:hover { border-color: var(--red-bright); transform: translateY(-6px); }
  .phi-num {
    font-family: 'Anton', sans-serif;
    color: var(--red-bright);
    font-size: 14px; letter-spacing: 0.25em;
    margin-bottom: 28px;
  }
  .phi-item h3 {
    font-family: 'Anton', sans-serif;
    font-size: 34px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .phi-item p { font-size: 15px; line-height: 1.6; color: rgba(245,239,230,0.78); }

  /* ================= STAFF ================= */
  .staff { background: var(--cream); color: var(--ink); padding: 130px 40px; }
  .staff-header {
    max-width: 1400px; margin: 0 auto 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .staff-header .section-tag { color: var(--red); }
  .staff-header .section-tag::before { background: var(--red); }
  .staff-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(44px, 5.5vw, 88px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .staff-header h2 .it { color: var(--red); }
  .staff-header p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); max-width: 380px; }
  .staff-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid rgba(10,10,10,0.12);
  }
  .staff-item {
    padding: 44px 28px 38px;
    border-right: 1px solid rgba(10,10,10,0.12);
    border-bottom: 1px solid rgba(10,10,10,0.12);
    background: var(--cream);
    transition: background .35s, color .35s;
    position: relative;
  }
  .staff-item:last-child { border-right: none; }
  .staff-item:hover { background: var(--ink); color: var(--cream); }
  .staff-item:hover .staff-num { color: var(--red-bright); }
  .staff-item:hover p { color: rgba(245,239,230,0.75); }
  .staff-num {
    font-family: 'Anton', sans-serif;
    font-size: 14px; letter-spacing: 0.25em;
    color: var(--red);
    margin-bottom: 28px;
    transition: color .35s;
  }
  .staff-item h3 {
    font-family: 'Anton', sans-serif;
    font-size: 26px; line-height: 1.05;
    text-transform: uppercase;
    margin-bottom: 12px;
  }
  .staff-item p { font-size: 14px; line-height: 1.55; color: var(--ink-soft); transition: color .35s; }

  /* ================= FACILITIES ================= */
  .facilities { background: var(--ink); color: var(--cream); padding: 130px 40px; }
  .facilities-inner {
    max-width: 1400px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1.1fr;
    gap: 60px; align-items: center;
  }
  .facilities-text .section-tag { color: var(--red-bright); }
  .facilities-text .section-tag::before { background: var(--red-bright); }
  .facilities-text h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 24px;
  }
  .facilities-text h2 .it { color: var(--red-bright); }
  .facilities-text p {
    font-size: 16px; line-height: 1.6;
    color: rgba(245,239,230,0.78);
    margin-bottom: 28px;
    max-width: 460px;
  }
  .facilities-text .club-cta {
    background: var(--red-bright); color: var(--cream);
    margin-top: 0;
  }
  .facilities-text .club-cta:hover { background: var(--cream); color: var(--ink); transform: translateY(-2px); }
  .facilities-map {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    border: 1px solid rgba(245,239,230,0.15);
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  }
  .facilities-map iframe { width: 100%; height: 100%; border: none; }
  .sede-media {
    position: relative;
    aspect-ratio: 3/2;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 12px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  }
  .sede-photo {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(245,239,230,0.15);
  }
  .sede-photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1s cubic-bezier(.2,.8,.2,1);
  }
  .sede-photo:hover img { transform: scale(1.04); }
  .sede-photo .lbl {
    position: absolute;
    bottom: 10px; left: 10px;
    background: var(--ink);
    color: var(--cream);
    padding: 5px 10px;
    font-family: 'Anton', sans-serif;
    font-size: 11px; letter-spacing: 0.18em;
    text-transform: uppercase;
    z-index: 2;
  }
  .facilities-inner + .facilities-inner { margin-top: 80px; }
  .facilities-inner.reverse .facilities-text { order: 2; }
  .facilities-inner.reverse .facilities-map { order: 1; }
  .hours-box {
    background: rgba(245,239,230,0.05);
    border: 1px solid rgba(245,239,230,0.12);
    padding: 22px 24px;
    margin: 0 0 28px;
    max-width: 460px;
  }
  .hours-box .hour {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 16px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(245,239,230,0.1);
    font-size: 14px;
  }
  .hours-box .hour:first-child { padding-top: 0; }
  .hours-box .hour:last-child { padding-bottom: 0; border-bottom: none; }
  .hours-box .hour strong {
    font-weight: 600;
    color: var(--cream);
    font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  }
  .hours-box .hour span {
    font-family: 'Anton', sans-serif;
    font-size: 18px;
    color: var(--red-bright);
    letter-spacing: 0.02em;
  }


  /* ================= MAIN SPONSOR (RAGA) ================= */
  .main-sponsor {
    background: var(--ink);
    color: var(--cream);
    padding: 70px 40px;
    border-top: 1px solid rgba(245,239,230,0.08);
    position: relative;
    overflow: hidden;
  }
  .main-sponsor::before {
    content: ''; position: absolute;
    top: -30%; right: -10%;
    width: 50%; height: 160%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.12) 0%, transparent 60%);
    pointer-events: none;
  }
  .ms-inner {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 50px;
    align-items: center;
    position: relative; z-index: 2;
  }
  .ms-logo-wrap {
    width: 140px; height: 140px;
    display: flex; align-items: center; justify-content: center;
    padding: 10px;
    transition: transform .3s;
  }
  .ms-logo-wrap:hover { transform: scale(1.04); }
  .ms-logo-wrap img {
    max-width: 100%; max-height: 100%;
    display: block;
  }
  .ms-content { }
  .ms-tag {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 14px;
  }
  .ms-tag::before {
    content: '★'; color: var(--red-bright);
  }
  .ms-name {
    font-family: 'Anton', sans-serif;
    font-size: clamp(32px, 4vw, 56px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .ms-name .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red-bright);
    text-transform: lowercase;
  }
  .ms-desc {
    font-size: 14px; line-height: 1.55;
    color: rgba(245,239,230,0.75);
    max-width: 540px;
  }
  .ms-cta {
    display: inline-flex; align-items: center; gap: 14px;
    padding: 18px 28px;
    background: var(--red-bright); color: var(--cream);
    font-size: 12px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
    text-decoration: none;
    transition: all .25s;
    white-space: nowrap;
  }
  .ms-cta:hover { background: var(--cream); color: var(--ink); transform: translateY(-2px); }


  /* ============ STEPS ============ */
  .insc-steps {
    background: var(--cream);
    color: var(--ink);
    padding: 110px 40px 40px;
  }
  .insc-steps-header {
    max-width: 1400px; margin: 0 auto 50px;
    text-align: center;
  }
  .insc-steps-header .section-tag { color: var(--red); justify-content: center; display: inline-flex; }
  .insc-steps-header .section-tag::before { background: var(--red); }
  .insc-steps-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5.5vw, 88px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .insc-steps-header h2 .it { color: var(--red); }
  .insc-steps-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
  .step-item { text-align: center; padding: 24px; }
  .step-num {
    width: 64px; height: 64px;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: var(--ink); color: var(--red-bright);
    font-family: 'Anton', sans-serif;
    font-size: 30px; line-height: 64px;
  }
  .step-item h3 {
    font-family: 'Anton', sans-serif;
    font-size: 22px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 10px;
  }
  .step-item p { font-size: 14px; line-height: 1.6; color: var(--ink-soft); }

  /* ============ PRICING TABLE ============ */
  .pricing {
    background: var(--ink);
    color: var(--cream);
    padding: 130px 40px;
    position: relative; overflow: hidden;
  }
  .pricing::before {
    content: ''; position: absolute;
    top: -30%; right: -10%;
    width: 60%; height: 160%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.15) 0%, transparent 60%);
    pointer-events: none;
  }
  .pricing-header {
    max-width: 1400px; margin: 0 auto 60px;
    position: relative; z-index: 2;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .pricing-header .section-tag { color: var(--red-bright); }
  .pricing-header .section-tag::before { background: var(--red-bright); }
  .pricing-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(44px, 5.5vw, 92px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .pricing-header h2 .it { color: var(--red-bright); }
  .pricing-header p { font-size: 15px; line-height: 1.6; color: rgba(245,239,230,0.75); max-width: 380px; }

  .pricing-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    position: relative; z-index: 2;
  }
  .price-card {
    background: var(--ink-soft);
    border: 1px solid rgba(245,239,230,0.1);
    padding: 38px 32px;
    display: flex; flex-direction: column;
    transition: border-color .35s, transform .35s;
    position: relative;
  }
  .price-card.featured {
    border-color: var(--red-bright);
    background: linear-gradient(180deg, rgba(193,39,45,0.08) 0%, var(--ink-soft) 70%);
  }
  .price-card:hover { transform: translateY(-6px); border-color: var(--red-bright); }
  .price-card .pc-label {
    font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 16px;
  }
  .price-card h3 {
    font-family: 'Anton', sans-serif;
    font-size: 30px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .price-card .pc-cats {
    font-family: 'Fraunces', serif; font-style: italic;
    font-size: 15px; line-height: 1.3;
    color: rgba(245,239,230,0.65);
    margin-bottom: 26px;
  }
  .price-line {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 14px 0;
    border-bottom: 1px solid rgba(245,239,230,0.1);
    font-size: 13px;
    color: rgba(245,239,230,0.78);
  }
  .price-line:last-of-type { border-bottom: none; }
  .price-line .num {
    font-family: 'Anton', sans-serif;
    font-size: 22px;
    color: var(--cream);
    letter-spacing: 0.02em;
  }
  .price-card .pc-total {
    margin-top: 20px;
    padding: 14px 0 0;
    border-top: 1px dashed rgba(245,239,230,0.2);
    display: flex; justify-content: space-between; align-items: baseline;
  }
  .price-card .pc-total .lbl {
    font-size: 10px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase;
    color: var(--red-bright);
  }
  .price-card .pc-total .total-num {
    font-family: 'Anton', sans-serif;
    font-size: 32px;
    color: var(--cream);
  }
  .pricing-note {
    max-width: 1400px; margin: 30px auto 0;
    padding: 22px 26px;
    background: rgba(245,239,230,0.06);
    border-left: 3px solid var(--red-bright);
    color: rgba(245,239,230,0.85);
    font-size: 14px; line-height: 1.6;
    position: relative; z-index: 2;
  }
  .pricing-note strong { color: var(--cream); }

  /* ============ CATEGORÍAS ============ */
  .insc-cats {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px 100px;
  }
  .insc-cats-header {
    max-width: 1400px; margin: 0 auto 50px;
    display: grid; grid-template-columns: 1fr 1.5fr;
    gap: 60px; align-items: end;
  }
  .insc-cats-header .section-tag { color: var(--red); }
  .insc-cats-header .section-tag::before { background: var(--red); }
  .insc-cats-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .insc-cats-header h2 .it { color: var(--red); }
  .insc-cats-header p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); max-width: 720px; }
  .cats-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }
  .cat-card {
    background: var(--cream);
    border: 1px solid rgba(10,10,10,0.12);
    padding: 30px 26px 26px;
    text-align: left;
    display: flex; flex-direction: column;
    transition: background .3s, border-color .3s, transform .3s;
    position: relative;
    overflow: hidden;
  }
  .cat-card:hover { transform: translateY(-4px); border-color: var(--ink); }
  .cat-status {
    position: absolute; top: 18px; right: 18px;
    display: inline-flex; align-items: center; gap: 8px;
    padding: 5px 11px;
    font-size: 10px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    border: 1px solid;
  }
  .cat-status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; }
  .cat-status.open { background: rgba(56, 224, 123, 0.12); color: #2a9b56; border-color: rgba(56, 224, 123, 0.4); }
  .cat-status.open::before { background: #2a9b56; animation: blink 1.4s ease-in-out infinite; }
  .cat-status.limited { background: rgba(232, 114, 26, 0.12); color: #c25f15; border-color: rgba(232, 114, 26, 0.4); }
  .cat-status.limited::before { background: #c25f15; animation: blink 1.4s ease-in-out infinite; }
  .cat-status.closed { background: rgba(10,10,10,0.06); color: rgba(10,10,10,0.5); border-color: rgba(10,10,10,0.15); }
  .cat-status.closed::before { background: rgba(10,10,10,0.4); }
  .cat-status.soon {
    background: rgba(250, 200, 50, 0.18);
    color: #c08e0d;
    border-color: rgba(250, 200, 50, 0.5);
  }
  .cat-status.soon::before { background: #f5c542; animation: blink 1.4s ease-in-out infinite; }

  .cat-card .cat-name {
    font-family: 'Anton', sans-serif;
    font-size: 26px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 6px;
    margin-top: 14px;
  }
  .cat-card .cat-age {
    font-size: 14px;
    color: var(--red);
    margin-bottom: 22px;
    font-weight: 500;
    letter-spacing: 0.02em;
  }
  .cat-card.full .cat-age { color: rgba(10,10,10,0.45); }
  .cat-card .cat-meta {
    font-size: 12px; line-height: 1.5;
    color: var(--ink-soft);
    margin-bottom: 22px;
    padding-top: 14px;
    border-top: 1px dashed rgba(10,10,10,0.1);
  }
  .cat-card .cat-cta {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 12px 18px;
    background: var(--ink); color: var(--cream);
    font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
    text-decoration: none;
    transition: background .25s, transform .25s;
    margin-top: auto;
    align-self: flex-start;
  }
  .cat-card .cat-cta:hover { background: var(--red); transform: translateY(-2px); }
  .cat-card.full .cat-cta {
    background: rgba(10,10,10,0.08); color: rgba(10,10,10,0.45);
    cursor: not-allowed; pointer-events: none;
  }
  .cat-card.full { opacity: 0.65; }

  /* ============ FORM SECTION ============ */
  .insc-form {
    background: var(--ink);
    color: var(--cream);
    padding: 130px 40px;
  }
  .insc-form-inner {
    max-width: 1100px; margin: 0 auto;
  }
  .insc-form-header {
    text-align: center;
    margin-bottom: 50px;
  }
  .insc-form-header .section-tag {
    color: var(--red-bright);
    justify-content: center; display: inline-flex;
  }
  .insc-form-header .section-tag::before { background: var(--red-bright); }
  .insc-form-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(44px, 5.5vw, 88px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 18px;
  }
  .insc-form-header h2 .it { color: var(--red-bright); }
  .insc-form-header p {
    font-size: 16px; line-height: 1.6;
    color: rgba(245,239,230,0.78);
    max-width: 580px; margin: 0 auto;
  }

  .form-card {
    background: var(--ink-soft);
    border: 1px solid rgba(245,239,230,0.1);
    padding: 50px 48px;
  }
  .gforms-wrap {
    max-width: 760px;
    margin: 0 auto;
    background: var(--cream);
    padding: 0;
    box-shadow: 0 20px 60px rgba(0,0,0,0.35);
  }
  .gforms-wrap iframe {
    display: block;
    width: 100%;
    border: none;
    min-height: 1700px;
  }
  .form-alt-row {
    max-width: 760px;
    margin: 22px auto 0;
    text-align: center;
    font-size: 14px;
    color: rgba(245,239,230,0.7);
  }
  .form-alt-row a {
    color: var(--red-bright);
    text-decoration: none;
    font-weight: 600;
  }
  .form-alt-row a:hover { text-decoration: underline; }
  .form-block {
    margin-bottom: 36px;
    padding-bottom: 32px;
    border-bottom: 1px solid rgba(245,239,230,0.1);
  }
  .form-block:last-of-type { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
  .form-block-title {
    font-family: 'Anton', sans-serif;
    font-size: 22px; line-height: 1;
    text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 22px;
    display: flex; align-items: center; gap: 14px;
  }
  .form-block-title .num {
    width: 32px; height: 32px;
    background: var(--red-bright); color: var(--cream);
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 14px; font-weight: 700;
  }
  .form-block-title .txt {
    color: var(--cream);
  }
  .form-r {
    display: grid; gap: 16px;
    margin-bottom: 16px;
  }
  .form-r.c2 { grid-template-columns: 1fr 1fr; }
  .form-r.c3 { grid-template-columns: 1fr 1fr 1fr; }
  .insc-form .field { display: flex; flex-direction: column; }
  .insc-form label {
    font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
    color: rgba(245,239,230,0.7);
    margin-bottom: 8px;
  }
  .insc-form input, .insc-form select, .insc-form textarea {
    background: transparent;
    border: none;
    border-bottom: 1.5px solid rgba(245,239,230,0.25);
    color: var(--cream);
    font-family: 'Sora', sans-serif;
    font-size: 16px;
    padding: 10px 0;
    outline: none;
    transition: border-color .25s;
    border-radius: 0;
  }
  .insc-form input:focus, .insc-form select:focus, .insc-form textarea:focus {
    border-bottom-color: var(--red-bright);
  }
  .insc-form select { appearance: none; cursor: pointer; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'><path d='M1 1l5 5 5-5' stroke='%23F5EFE6' fill='none' stroke-width='1.5'/></svg>"); background-repeat: no-repeat; background-position: right 6px center; padding-right: 30px; }
  .insc-form option { background: var(--ink); color: var(--cream); }
  .insc-form textarea { resize: vertical; min-height: 80px; }
  .insc-form .check-row {
    display: flex; gap: 12px; align-items: flex-start;
    font-size: 13px; line-height: 1.5;
    color: rgba(245,239,230,0.8);
    margin-top: 8px;
  }
  .insc-form .check-row input[type=checkbox] {
    margin-top: 4px;
    accent-color: var(--red-bright);
    flex-shrink: 0;
  }
  .insc-form .check-row a { color: var(--red-bright); }
  .form-submit-row {
    margin-top: 36px;
    display: flex; gap: 18px; align-items: center; flex-wrap: wrap;
    justify-content: space-between;
  }
  .insc-submit {
    display: inline-flex; align-items: center; gap: 14px;
    padding: 20px 36px;
    background: var(--red-bright); color: var(--cream);
    font-family: 'Sora', sans-serif;
    font-size: 14px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
    border: none;
    cursor: pointer;
    transition: all .25s;
  }
  .insc-submit:hover { background: var(--cream); color: var(--ink); transform: translateY(-2px); }
  .form-alt {
    font-size: 13px; color: rgba(245,239,230,0.6);
  }
  .form-alt a { color: var(--red-bright); text-decoration: none; }
  .form-alt a:hover { text-decoration: underline; }

  /* ============ FAQ ============ */
  .insc-faq {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px;
  }
  .faq-header {
    max-width: 900px; margin: 0 auto 50px;
    text-align: center;
  }
  .faq-header .section-tag { color: var(--red); display: inline-flex; }
  .faq-header .section-tag::before { background: var(--red); }
  .faq-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .faq-header h2 .it { color: var(--red); }
  .faq-list { max-width: 900px; margin: 0 auto; }
  .faq-item {
    border-top: 1px solid rgba(10,10,10,0.15);
    padding: 22px 0;
  }
  .faq-item:last-child { border-bottom: 1px solid rgba(10,10,10,0.15); }
  .faq-q {
    cursor: pointer;
    list-style: none;
    display: flex; align-items: flex-start; justify-content: space-between; gap: 24px;
    font-family: 'Anton', sans-serif;
    font-size: 22px; line-height: 1.2;
    text-transform: uppercase;
  }
  .faq-q::-webkit-details-marker { display: none; }
  .faq-q::after {
    content: '+';
    font-family: 'Anton', sans-serif;
    font-size: 28px; line-height: 1;
    color: var(--red);
    transition: transform .25s;
    flex-shrink: 0;
  }
  .faq-item[open] .faq-q::after { content: '–'; }
  .faq-item p {
    margin-top: 18px;
    font-size: 15px; line-height: 1.65;
    color: var(--ink-soft);
    max-width: 760px;
  }
  .faq-bullets {
    margin: 12px 0 0;
    padding-left: 22px;
    font-size: 15px; line-height: 1.7;
    color: var(--ink-soft);
    max-width: 760px;
  }
  .faq-bullets li { margin-bottom: 4px; }


  /* ============ INSCRIPCIONES ABIERTAS (HUB) ============ */
  .insc-hub {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px;
    position: relative; overflow: hidden;
  }
  .insc-hub::before {
    content: ''; position: absolute;
    top: -30%; left: -10%;
    width: 50%; height: 160%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.12) 0%, transparent 60%);
    pointer-events: none;
  }
  .insc-hub-header {
    max-width: 1400px; margin: 0 auto 50px;
    position: relative; z-index: 2;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .insc-hub-header .section-tag { color: var(--red-bright); }
  .insc-hub-header .section-tag::before { background: var(--red-bright); }
  .insc-hub-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(44px, 5.5vw, 92px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .insc-hub-header h2 .it { color: var(--red-bright); }
  .insc-hub-header p { font-size: 15px; line-height: 1.6; color: rgba(15,15,15,0.72); max-width: 420px; }
  .insc-hub-grid {
    max-width: 1400px; margin: 0 auto;
    position: relative; z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }
  .insc-card {
    background: var(--ink-soft);
    border: 1px solid rgba(245,239,230,0.1);
    padding: 36px 32px 32px;
    display: flex; flex-direction: column;
    text-decoration: none;
    color: var(--cream);
    transition: border-color .35s, transform .35s;
    position: relative;
    overflow: hidden;
  }
  .insc-card:hover { border-color: var(--red-bright); transform: translateY(-6px); }
  .insc-card::after {
    content: ''; position: absolute;
    bottom: 0; left: 0;
    width: 0; height: 3px;
    background: var(--red-bright);
    transition: width .4s ease;
  }
  .insc-card:hover::after { width: 100%; }
  .insc-card-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 18px;
  }
  .insc-card-num {
    font-family: 'Anton', sans-serif;
    font-size: 13px; letter-spacing: 0.25em;
    color: rgba(245,239,230,0.55);
  }
  .insc-card-status {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(37, 211, 102, 0.15);
    color: #38e07b;
    padding: 5px 11px;
    font-size: 10px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    border: 1px solid rgba(37, 211, 102, 0.3);
  }
  .insc-card-status::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: #38e07b;
    animation: blink 1.4s ease-in-out infinite;
  }
  .insc-card-status.closing {
    background: rgba(193, 39, 45, 0.15);
    color: var(--red-bright);
    border-color: rgba(193, 39, 45, 0.3);
  }
  .insc-card-status.closing::before { background: var(--red-bright); }
  .insc-card-status.soon {
    background: rgba(250, 200, 50, 0.15);
    color: #f5c542;
    border-color: rgba(250, 200, 50, 0.4);
  }
  .insc-card-status.soon::before { background: #f5c542; animation: blink 1.4s ease-in-out infinite; }
  .insc-card h3 {
    font-family: 'Anton', sans-serif;
    font-size: 32px; line-height: 1;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .insc-card h3 .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red-bright); text-transform: lowercase;
  }
  .insc-card .who {
    font-size: 14px; line-height: 1.5;
    color: rgba(245,239,230,0.75);
    margin-bottom: 22px;
    flex-grow: 1;
  }
  .insc-card-meta {
    display: flex; gap: 18px; flex-wrap: wrap;
    padding: 14px 0 18px;
    border-top: 1px solid rgba(245,239,230,0.1);
    border-bottom: 1px solid rgba(245,239,230,0.1);
    margin-bottom: 20px;
    font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  }
  .insc-card-meta .key {
    color: rgba(245,239,230,0.55);
    margin-right: 6px;
  }
  .insc-card-meta .val {
    color: var(--cream);
    font-family: 'Anton', sans-serif;
    font-size: 13px;
    letter-spacing: 0.04em;
  }
  .insc-card-cta {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--red-bright);
    transition: gap .3s;
  }
  .insc-card:hover .insc-card-cta { gap: 20px; }
  .insc-card-cta .arr {
    display: inline-block; width: 26px; height: 1px; background: currentColor;
    position: relative;
  }
  .insc-card-cta .arr::after {
    content: ''; position: absolute; right: 0; top: -3px;
    width: 7px; height: 7px;
    border-top: 1px solid currentColor; border-right: 1px solid currentColor;
    transform: rotate(45deg);
  }

  .insc-hub-note {
    max-width: 1400px; margin: 30px auto 0;
    padding: 22px 26px;
    background: rgba(15,15,15,0.05);
    border-left: 3px solid var(--red-bright);
    color: rgba(15,15,15,0.78);
    font-size: 14px; line-height: 1.6;
    position: relative; z-index: 2;
  }
  .insc-hub-note strong { color: var(--ink); }
  .insc-hub-note a { color: var(--red-bright); text-decoration: none; font-weight: 600; }


  /* Nav dropdown */
  nav.top li.has-sub { position: relative; }
  nav.top li.has-sub > a { display: inline-flex; align-items: center; gap: 6px; }
  nav.top li.has-sub > a::after {
    content: '▾'; font-size: 9px; opacity: .7;
  }
  nav.top .submenu {
    position: absolute;
    top: 100%; left: -16px;
    margin: 0; padding: 14px 0;
    background-color: #0A0A0A;
    mix-blend-mode: normal;
    isolation: isolate;
    list-style: none;
    min-width: 240px;
    display: flex;
    flex-direction: column;
    gap: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity .25s, transform .25s, visibility .25s;
    box-shadow: 0 22px 50px rgba(0,0,0,0.7);
    z-index: 60;
  }
  nav.top .submenu::before {
    content: ''; position: absolute; inset: 0;
    background-color: #0A0A0A;
    z-index: -1;
  }
  nav.top li.has-sub:hover .submenu,
  nav.top li.has-sub:focus-within .submenu {
    opacity: 1; visibility: visible; transform: translateY(0);
  }
  nav.top .submenu li { list-style: none; }
  nav.top .submenu a {
    display: block;
    padding: 8px 22px;
    font-size: 11px;
    letter-spacing: 0.15em;
    color: rgba(245,239,230,0.75);
    transition: color .2s, padding-left .25s;
  }
  nav.top .submenu a:hover { color: var(--red-bright); padding-left: 28px; }


  .step-link {
    color: var(--red);
    text-decoration: none;
    font-weight: 600;
    transition: padding-left .2s;
  }
  .step-link:hover { padding-left: 4px; }

  /* ============ EQUIPACIÓN ============ */
  .equip {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px;
  }
  .equip-inner {
    max-width: 1400px; margin: 0 auto;
  }
  .equip-header {
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
    margin-bottom: 50px;
  }
  .equip-header .section-tag { color: var(--red); }
  .equip-header .section-tag::before { background: var(--red); }
  .equip-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .equip-header h2 .it { color: var(--red); }
  .equip-header p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); max-width: 420px; }

  .equip-banner {
    background: var(--ink);
    color: var(--cream);
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 0;
    overflow: hidden;
    border: 1px solid var(--ink);
  }
  .equip-left {
    padding: 50px 44px;
    display: flex; flex-direction: column; justify-content: center;
  }
  .equip-tag {
    font-size: 11px; font-weight: 600; letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 18px;
  }
  .equip-left h3 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(34px, 4vw, 60px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 20px;
  }
  .equip-left h3 .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red-bright); text-transform: lowercase;
  }
  .equip-left p {
    font-size: 16px; line-height: 1.6;
    color: rgba(245,239,230,0.78);
    margin-bottom: 24px;
    max-width: 460px;
  }
  .equip-code {
    display: inline-flex; align-items: center; gap: 14px;
    background: rgba(245,239,230,0.08);
    border: 1px dashed rgba(245,239,230,0.4);
    padding: 14px 20px;
    margin-bottom: 28px;
    align-self: flex-start;
  }
  .equip-code .pct {
    font-family: 'Anton', sans-serif;
    font-size: 22px;
    color: var(--red-bright);
  }
  .equip-code .lbl {
    font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
    color: rgba(245,239,230,0.65);
  }
  .equip-code .code {
    font-family: 'Anton', sans-serif;
    font-size: 18px;
    background: var(--cream);
    color: var(--ink);
    padding: 6px 12px;
    letter-spacing: 0.1em;
  }
  .equip-cta {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 18px 28px;
    background: var(--red-bright); color: var(--cream);
    font-size: 13px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
    text-decoration: none;
    transition: all .25s;
    align-self: flex-start;
  }
  .equip-cta:hover { background: var(--cream); color: var(--ink); transform: translateY(-2px); }
  .equip-actions {
    display: flex; gap: 12px; flex-wrap: wrap;
    align-self: flex-start;
  }
  .equip-cta-secondary {
    background: transparent;
    color: var(--cream);
    border: 1px solid rgba(245,239,230,0.4);
  }
  .equip-cta-secondary:hover { background: var(--cream); color: var(--ink); border-color: var(--cream); }

  .equip-steps {
    background: var(--ink-soft);
    padding: 50px 44px;
    display: flex; flex-direction: column; justify-content: center;
    color: var(--cream);
  }
  .equip-steps h4 {
    font-family: 'Anton', sans-serif;
    font-size: 18px; line-height: 1;
    text-transform: uppercase;
    color: var(--red-bright);
    margin-bottom: 22px;
    letter-spacing: 0.04em;
  }
  .equip-steps ol {
    list-style: none; padding: 0; margin: 0;
    counter-reset: equip;
  }
  .equip-steps ol li {
    counter-increment: equip;
    position: relative;
    padding: 14px 0 14px 48px;
    border-bottom: 1px solid rgba(245,239,230,0.1);
    font-size: 14px; line-height: 1.55;
    color: rgba(245,239,230,0.85);
  }
  .equip-steps ol li:last-child { border-bottom: none; }
  .equip-steps ol li::before {
    content: counter(equip);
    position: absolute; left: 0; top: 14px;
    width: 32px; height: 32px;
    background: var(--red-bright);
    color: var(--cream);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Anton', sans-serif;
    font-size: 14px;
  }
  .equip-steps ol li strong { color: var(--cream); display: block; margin-bottom: 4px; }
  .equip-steps ol li a { color: var(--red-bright); text-decoration: none; font-weight: 600; }
  .equip-steps ol li a:hover { text-decoration: underline; }
  .equip-steps-hint {
    margin-top: 22px;
    font-size: 13px;
    color: rgba(245,239,230,0.65);
  }
  .equip-steps-hint a { color: var(--red-bright); text-decoration: none; font-weight: 600; }
  .equip-steps-hint a:hover { text-decoration: underline; }

  /* Ventaja para socios: 10% en webs del grupo */
  .equip-perk {
    margin-top: 30px;
    background: var(--ink-soft);
    color: var(--cream);
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 0;
    overflow: hidden;
    border: 1px solid var(--ink);
  }
  .equip-perk-left {
    padding: 50px 44px;
    display: flex; flex-direction: column; justify-content: center;
  }
  .equip-perk-left h3 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(28px, 3vw, 44px);
    line-height: 1;
    text-transform: uppercase;
    margin-bottom: 18px;
  }
  .equip-perk-left h3 .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red-bright); text-transform: lowercase;
  }
  .equip-perk-left p {
    font-size: 15px; line-height: 1.6;
    color: rgba(245,239,230,0.78);
    margin-bottom: 20px;
    max-width: 520px;
  }
  .equip-sites {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap; gap: 8px 14px;
  }
  .equip-sites li a {
    display: inline-block;
    padding: 8px 14px;
    background: rgba(245,239,230,0.06);
    border: 1px solid rgba(245,239,230,0.18);
    color: var(--cream);
    font-size: 13px;
    text-decoration: none;
    letter-spacing: 0.02em;
    transition: all .25s;
  }
  .equip-sites li a:hover {
    background: var(--red-bright); border-color: var(--red-bright); color: var(--cream);
  }
  .equip-code-box {
    background: var(--red-bright); color: var(--cream);
    padding: 50px 40px;
    display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
    gap: 8px;
  }
  .equip-code-box .pct {
    font-family: 'Anton', sans-serif;
    font-size: 44px;
    line-height: 1;
  }
  .equip-code-box .lbl {
    font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
    color: rgba(245,239,230,0.85);
    margin-top: 6px;
  }
  .equip-code-box .code {
    font-family: 'Anton', sans-serif;
    font-size: 26px;
    background: var(--cream);
    color: var(--ink);
    padding: 10px 16px;
    letter-spacing: 0.08em;
    margin-top: 6px;
  }
  .equip-code-box .hint {
    font-size: 12px;
    line-height: 1.5;
    color: rgba(245,239,230,0.85);
    margin-top: 14px;
  }

  /* Mostrar plazas solo cuando se llega vía anchor #nuevos-alumnos */
  #nuevos-alumnos { display: none; }
  #nuevos-alumnos:target { display: block; animation: fadeIn .4s ease; }
  #nuevos-alumnos .insc-steps { padding-top: 60px; }
  @keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

  /* ================ RESPONSIVE ================ */
  @media (max-width: 1000px) {
    nav.top { padding: 16px 20px; mix-blend-mode: normal; background: rgba(10,10,10,0.92); }
    .hamburger { display: block; }

    nav.top li.has-sub > a::after { display: none; }
    nav.top .submenu::before { display: none; }
    nav.top li.has-sub > a {
      display: block !important;
      font-size: 22px !important;
      letter-spacing: 0.12em !important;
      color: var(--cream) !important;
      gap: 0 !important;
      padding: 6px 0 !important;
      min-height: 30px !important;
      visibility: visible !important;
      opacity: 1 !important;
      text-align: center !important;
      width: auto !important;
    }
    nav.top .submenu {
      position: static;
      opacity: 1; visibility: visible; transform: none;
      background: transparent;
      box-shadow: none;
      padding: 8px 0 0;
      min-width: auto;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 4px;
    }
    nav.top .submenu a {
      font-size: 13px;
      padding: 4px 0;
      letter-spacing: 0.1em;
      opacity: .7;
    }

    nav.top ul {
      position: fixed; inset: 0;
      flex-direction: column;
      justify-content: center; align-items: center;
      gap: 28px;
      background-color: #0A0A0A;
      mix-blend-mode: normal;
      isolation: isolate;
      font-size: 22px; letter-spacing: 0.12em;
      transform: translateX(100%);
      transition: transform .4s cubic-bezier(.2,.8,.2,1);
      z-index: 55;
      padding: 80px 24px 40px;
    }
    nav.top ul::before {
      content: ''; position: absolute; inset: 0;
      background-color: #0A0A0A;
      z-index: -1;
    }
    nav.top ul a { color: var(--cream); display: block; padding: 6px 0; }
    nav.top ul a:hover { color: var(--red-bright); }
    #nav-toggle:checked ~ ul { transform: translateX(0); }
    body:has(#nav-toggle:checked) { overflow: hidden; }

    .hero-bg { background-position: 50% 30% !important; }
    .hero-inner { grid-template-columns: 1fr; padding: 110px 20px 100px; gap: 30px; }
    .hero h1 { font-size: clamp(48px, 13vw, 80px); }
    .hero-side { height: 380px; }
    .float-card.f1 { width: 130px; height: 170px; top: 120px; right: 0; left: auto; }
    .float-card.f2 { width: 120px; height: 160px; top: 30px; left: 130px; right: auto; bottom: auto; }
    .float-card.f3 { display: block; width: 110px; height: 145px; top: 220px; left: 130px; right: auto; }
    .badge { width: 90px; height: 90px; top: 0; right: 0; }
    .badge .b1, .badge .b3 { font-size: 8px; }
    .badge .b2 { font-size: 24px; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
    .stat-num { font-size: 56px; }
    .services { padding: 80px 20px; }
    .services-header { grid-template-columns: 1fr; gap: 28px; }
    .services-grid { gap: 14px; }
    .card-1, .card-2, .card-3, .card-4 { grid-column: span 12; min-height: 380px; }
    .gm-track img { width: 240px; height: 160px; }
    .anno-grid { grid-template-columns: 1fr; }
    .annotations { padding: 60px 20px; }
    .club { padding: 80px 20px; }
    .club-inner { grid-template-columns: 1fr; gap: 40px; }
    .club-mono { font-size: 160px; top: 0; }
    .club-photo-wrap { height: 380px; }
    .club-photo-tag { padding: 20px 24px; bottom: -16px; left: -12px; }
    .club-photo-tag .yr { font-size: 40px; }
    .pillars { padding: 70px 20px; }
    .pillars-header { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .pillars-grid { grid-template-columns: 1fr 1fr; }
    .pillar { border-right: 1px solid rgba(245,239,230,0.15); border-bottom: 1px solid rgba(245,239,230,0.15); padding: 32px 20px; }
    .pillar:nth-child(2n) { border-right: none; }
    .pillar:nth-last-child(-n+2) { border-bottom: none; }
    .sponsors { padding: 80px 20px; }
    .sponsors-header { grid-template-columns: 1fr; gap: 24px; }
    .sponsors-featured { grid-template-columns: 1fr; }
    .sponsors-grid { grid-template-columns: repeat(2, 1fr); }
    .sponsors-cta { padding: 28px 22px; }
    .news { padding: 80px 20px; }
    .news-header { grid-template-columns: 1fr; gap: 24px; }
    .news-grid { grid-template-columns: 1fr; }
    .final-cta { padding: 70px 20px; min-height: auto; }
    .final-cta-inner { grid-template-columns: 1fr; gap: 36px; }
    footer { padding: 70px 20px 24px; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: 50px; }
    .footer-brand { grid-column: span 2; }
    .footer-bottom { flex-direction: column; align-items: flex-start; gap: 14px; }

    .page-hero { padding: 110px 20px 60px; min-height: 60vh; }
    .timeline { padding: 70px 20px; }
    .timeline-track::before { left: 32px; }
    .milestone { padding: 20px 0 30px 72px; min-height: auto; }
    .milestone::before { left: 23px; top: 30px; }
    .milestone .year { font-size: 28px; top: 22px; }
    .milestone h3 { font-size: 22px; }
    .milestone-photo { position: relative; top: auto; right: auto; width: 100%; margin-top: 20px; }
    .milestone-photo::after { font-size: 12px; padding: 5px 10px; }
    .philosophy { padding: 70px 20px; }
    .philosophy-header { grid-template-columns: 1fr; gap: 20px; }
    .philosophy-grid { grid-template-columns: 1fr; gap: 14px; }
    .staff { padding: 70px 20px; }
    .staff-header { grid-template-columns: 1fr; gap: 20px; }
    .staff-grid { grid-template-columns: 1fr 1fr; }
    .staff-item:nth-child(2n) { border-right: none; }
    .facilities { padding: 70px 20px; }
    .facilities-inner { grid-template-columns: 1fr; gap: 30px; }

    .insc-steps { padding: 60px 20px 30px; }
    .insc-steps-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
    .pricing { padding: 70px 20px; }
    .pricing-header { grid-template-columns: 1fr; gap: 22px; }
    .pricing-grid { grid-template-columns: 1fr; gap: 14px; }
    .insc-cats { padding: 70px 20px; }
    .insc-cats-header { grid-template-columns: 1fr; gap: 22px; }
    .cats-grid { grid-template-columns: 1fr; }
    .insc-form { padding: 70px 20px; }
    .form-card { padding: 28px 22px; }
    .form-r.c2, .form-r.c3 { grid-template-columns: 1fr; }
    .insc-faq { padding: 70px 20px; }
    .faq-q { font-size: 17px; }

    .insc-hub { padding: 70px 20px; }
    .insc-hub-header { grid-template-columns: 1fr; gap: 22px; }
    .insc-hub-grid { grid-template-columns: 1fr; gap: 14px; }

    .equip { padding: 70px 20px; }
    .equip-header { grid-template-columns: 1fr; gap: 22px; }
    .equip-banner { grid-template-columns: 1fr; }
    .equip-perk { grid-template-columns: 1fr; }
    .equip-perk-left { padding: 36px 24px; }
    .equip-code-box { padding: 36px 24px; }
    .equip-left, .equip-steps { padding: 32px 24px; }


  }

  /* ============ CTA RENOVACIÓN ============ */
  .verano-cta {
    background: var(--ink);
    color: var(--cream);
    padding: 110px 40px;
    text-align: center;
    position: relative; overflow: hidden;
  }
  .verano-cta::before {
    content: ''; position: absolute;
    top: -30%; left: 50%; transform: translateX(-50%);
    width: 70%; height: 160%;
    background: radial-gradient(ellipse, rgba(193,39,45,0.18) 0%, transparent 65%);
    pointer-events: none;
  }
  .verano-cta-inner {
    max-width: 760px; margin: 0 auto;
    position: relative; z-index: 2;
  }
  .verano-cta-inner .section-tag { color: var(--red-bright); justify-content: center; }
  .verano-cta-inner .section-tag::before { background: var(--red-bright); }
  .verano-cta-inner h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(48px, 6vw, 92px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 22px;
  }
  .verano-cta-inner h2 .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red-bright); text-transform: lowercase;
  }
  .verano-cta-inner p {
    font-size: 16px; line-height: 1.6;
    color: rgba(245,239,230,0.78);
    margin-bottom: 32px;
  }

  /* ============ FORMULARIO RENOVACIÓN ============ */
  .verano-form {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px 110px;
  }
  .verano-form-header {
    max-width: 1100px; margin: 0 auto 50px;
    text-align: center;
  }
  .verano-form-header .section-tag { color: var(--red); justify-content: center; }
  .verano-form-header .section-tag::before { background: var(--red); }
  .verano-form-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
    margin-bottom: 18px;
  }
  .verano-form-header h2 .it {
    font-family: 'Fraunces', serif; font-style: italic; font-weight: 400;
    color: var(--red); text-transform: lowercase;
  }
  .verano-form-header p {
    font-size: 16px; line-height: 1.6;
    color: var(--ink-soft);
    max-width: 560px; margin: 0 auto;
  }
  .verano-form-inner {
    max-width: 720px; margin: 0 auto;
    background: #fff;
    padding: 20px;
    box-shadow: 0 24px 60px rgba(10,10,10,0.12);
    border: 1px solid rgba(10,10,10,0.06);
  }
  .verano-form iframe { display: block; width: 100%; border: 0; }
  .verano-form-fallback {
    text-align: center;
    font-size: 14px;
    color: var(--ink-soft);
    margin: 16px 0 0;
  }
  .verano-form-fallback a { color: var(--red); font-weight: 600; text-decoration: none; }
  .verano-form-fallback a:hover { text-decoration: underline; }

  @media (max-width: 900px) {
    .verano-cta { padding: 80px 20px; }
    .verano-form { padding: 70px 12px 60px; }
    .verano-form-inner { padding: 12px; }
  }

  /* ============ LO QUE INCLUYE ============ */
  .insc-includes {
    background: var(--cream);
    color: var(--ink);
    padding: 130px 40px;
  }
  .includes-header {
    max-width: 1400px; margin: 0 auto 60px;
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: end;
  }
  .includes-header .section-tag { color: var(--red); }
  .includes-header .section-tag::before { background: var(--red); }
  .includes-header h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.95;
    text-transform: uppercase;
  }
  .includes-header h2 .it { color: var(--red); }
  .includes-header p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); max-width: 420px; }

  .includes-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid rgba(10,10,10,0.12);
    border-left: 1px solid rgba(10,10,10,0.12);
  }
  .inc-item {
    padding: 36px 28px;
    border-right: 1px solid rgba(10,10,10,0.12);
    border-bottom: 1px solid rgba(10,10,10,0.12);
    display: flex; flex-direction: column;
  }
  .inc-num {
    font-family: 'Anton', sans-serif;
    font-size: 13px; letter-spacing: 0.25em;
    color: var(--red);
    margin-bottom: 22px;
  }
  .inc-item h3 {
    font-family: 'Anton', sans-serif;
    font-size: 20px; line-height: 1.1;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .inc-item p { font-size: 13px; line-height: 1.55; color: var(--ink-soft); }

  /* ============ VIDEO FEATURED ============ */
  .video-feat {
    background: var(--ink);
    padding: 100px 40px;
  }
  .video-feat-inner {
    max-width: 1100px; margin: 0 auto;
    text-align: center;
  }
  .video-feat .section-tag {
    color: var(--red-bright);
    display: inline-flex; justify-content: center;
  }
  .video-feat .section-tag::before { background: var(--red-bright); }
  .video-feat h2 {
    font-family: 'Anton', sans-serif;
    font-size: clamp(36px, 4.5vw, 64px);
    line-height: 0.95;
    text-transform: uppercase;
    color: var(--cream);
    margin-bottom: 40px;
  }
  .video-feat h2 .it { color: var(--red-bright); }
  .video-feat-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }
  .video-feat-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,0.6);
  }
  .video-feat video {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    background: var(--ink);
  }

  /* ============ MOBILE ============ */
  @media (max-width: 900px) {
    .insc-includes { padding: 70px 20px; }
    .includes-header { grid-template-columns: 1fr; gap: 22px; }
    .includes-grid { grid-template-columns: 1fr 1fr; }
    .video-feat { padding: 60px 20px; }
    .video-feat-grid { grid-template-columns: 1fr; gap: 16px; }
  }
