/* ── Family films detail ── */
    .family-detail {
      background: var(--dark);
      padding: 7rem 2rem;
    }
 
    .family-detail-inner {
      max-width: 960px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 5rem;
      align-items: start;
    }
 
    .family-detail-text .section-label {
      font-family: var(--font-body);
      font-size: 0.78rem;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }
 
    .family-detail-text h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3.2rem);
      color: var(--light);
      text-transform: uppercase;
      letter-spacing: 0.03em;
      margin-bottom: 1.25rem;
      line-height: 1;
    }
 
    .family-detail-text p {
      font-family: var(--font-body);
      font-size: 0.97rem;
      color: rgba(230,232,229,0.7);
      line-height: 1.75;
      font-weight: 300;
      margin-bottom: 1rem;
    }
 
    .family-pull {
      font-family: var(--font-serif);
      font-style: italic;
      font-size: 1.1rem;
      color: var(--light);
      padding-left: 1.25rem;
      border-left: 3px solid var(--gold);
      margin: 1.5rem 0 2rem;
      line-height: 1.65;
    }
 
    /* Process steps */
    .process-steps {
      display: flex;
      flex-direction: column;
      gap: 1.5rem;
    }
 
    .process-step {
      display: flex;
      gap: 1.25rem;
      align-items: flex-start;
    }
 
    .process-step-num {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      border: 2px solid var(--gold);
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: var(--font-display);
      font-size: 1.1rem;
      color: var(--gold);
      flex-shrink: 0;
    }
 
    .process-step-body strong {
      font-family: var(--font-display);
      font-size: 1.2rem;
      letter-spacing: 0.05em;
      color: var(--light);
      display: block;
      margin-bottom: 0.3rem;
    }
 
    .process-step-body p {
      font-family: var(--font-body);
      font-size: 0.9rem;
      color: rgba(230,232,229,0.6);
      line-height: 1.6;
      font-weight: 300;
      margin: 0;
    }
 
    /* ── Pricing ── */
    .pricing-section {
      background: var(--light);
      padding: 6rem 2rem;
    }
 
    .pricing-section-intro {
      text-align: center;
      margin-bottom: 3.5rem;
    }
 
    .pricing-section-intro .section-label {
      font-family: var(--font-body);
      font-size: 0.78rem;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }
 
    .pricing-section-intro h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3.5rem);
      color: var(--dark);
      text-transform: uppercase;
      letter-spacing: 0.03em;
    }
 
    .pricing-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.5rem;
      max-width: 900px;
      margin: 0 auto 3rem;
    }
 
    .price-card {
      background: #fff;
      border: 1px solid rgba(41,54,58,0.1);
      border-radius: 10px;
      padding: 2rem 1.75rem;
      display: flex;
      flex-direction: column;
      text-decoration: none;
      transition: transform 0.3s, box-shadow 0.3s;
    }
 
    .price-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 16px 40px rgba(0,0,0,0.1);
    }
 
    .price-card.featured {
      background: var(--dark);
      border-color: var(--gold);
      border-width: 2px;
    }
 
    .price-card-tier {
      font-family: var(--font-display);
      font-size: 1.5rem;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 0.5rem;
    }
 
    .price-card:not(.featured) .price-card-tier { color: var(--dark); }
    .price-card.featured .price-card-tier { color: var(--light); }
 
    .price-card-price {
      font-family: var(--font-display);
      font-size: 2.2rem;
      color: var(--gold);
      letter-spacing: 0.03em;
      margin-bottom: 1.25rem;
      line-height: 1;
    }
 
    .price-card-features {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.6rem;
      margin-bottom: 1.25rem;
      flex-grow: 1;
    }
 
    .price-card-features li {
      display: flex;
      align-items: flex-start;
      gap: 0.6rem;
      font-size: 0.88rem;
      line-height: 1.45;
    }
 
    .price-card:not(.featured) .price-card-features li { color: #555; }
    .price-card.featured .price-card-features li { color: rgba(230,232,229,0.75); }
 
    .price-card-features li i {
      color: var(--gold);
      font-size: 0.6rem;
      margin-top: 4px;
      flex-shrink: 0;
    }
 
    .price-card-note {
      font-family: var(--font-body);
      font-size: 0.78rem;
      font-style: italic;
      margin-top: auto;
    }
 
    .price-card:not(.featured) .price-card-note { color: #888; }
    .price-card.featured .price-card-note { color: rgba(212,175,55,0.6); }
 
    /* ── Add-ons ── */
    .addons-section {
      background: var(--dark);
      padding: 6rem 2rem;
    }
 
    .addons-intro {
      text-align: center;
      margin-bottom: 3.5rem;
    }
 
    .addons-intro .section-label {
      font-family: var(--font-body);
      font-size: 0.78rem;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }
 
    .addons-intro h2 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 4vw, 3.5rem);
      color: var(--light);
      text-transform: uppercase;
      letter-spacing: 0.03em;
      margin-bottom: 0.5rem;
    }
 
    .addons-intro p {
      font-family: var(--font-body);
      font-size: 0.97rem;
      color: rgba(230,232,229,0.55);
      font-weight: 300;
    }
 
    .addons-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 1rem;
      max-width: 960px;
      margin: 0 auto 4rem;
    }
 
    .addon-card {
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(212,175,55,0.15);
      border-radius: 8px;
      padding: 1.5rem;
      text-align: center;
      transition: background 0.25s, border-color 0.25s;
    }
 
    .addon-card:hover {
      background: rgba(212,175,55,0.07);
      border-color: rgba(212,175,55,0.4);
    }
 
    .addon-icon {
      font-size: 1.5rem;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }
 
    .addon-name {
      font-family: var(--font-display);
      font-size: 1.1rem;
      letter-spacing: 0.05em;
      color: var(--light);
      text-transform: uppercase;
      margin-bottom: 0.5rem;
      line-height: 1.2;
    }
 
    .addon-price {
      font-family: var(--font-display);
      font-size: 1.5rem;
      color: var(--gold);
      letter-spacing: 0.05em;
    }
 
    /* Fine print */
    .fine-print-block {
      max-width: 760px;
      margin: 0 auto;
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(212,175,55,0.12);
      border-radius: 8px;
      padding: 2rem 2.5rem;
    }
 
    .fine-print-block h3 {
      font-family: var(--font-display);
      font-size: 1.4rem;
      color: var(--light);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 1.25rem;
    }
 
    .fine-print-block ul {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
 
    .fine-print-block li {
      font-family: var(--font-body);
      font-size: 0.88rem;
      color: rgba(230,232,229,0.55);
      line-height: 1.6;
      font-weight: 300;
      padding-left: 1rem;
      border-left: 2px solid rgba(212,175,55,0.2);
    }
 
    .fine-print-block li strong {
      color: rgba(230,232,229,0.85);
      font-weight: 500;
    }
 
    /* ── Travel note ── */
    .travel-note {
      background: rgba(212,175,55,0.06);
      border: 1px solid rgba(212,175,55,0.2);
      border-radius: 8px;
      padding: 1.25rem 1.75rem;
      max-width: 760px;
      margin: 2rem auto 0;
      display: flex;
      gap: 1rem;
      align-items: flex-start;
    }
 
    .travel-note i {
      color: var(--gold);
      font-size: 1rem;
      margin-top: 2px;
      flex-shrink: 0;
    }
 
    .travel-note p {
      font-family: var(--font-body);
      font-size: 0.88rem;
      color: rgba(230,232,229,0.65);
      line-height: 1.6;
      font-weight: 300;
      margin: 0;
    }

     /* ── Final CTA ── */
    .os-cta {
      background: var(--gold);
      padding: 7rem 2rem;
      text-align: center;
    }
 
    .os-cta h2 {
      font-family: var(--font-display);
      font-size: clamp(2.5rem, 6vw, 5rem);
      color: var(--dark);
      letter-spacing: 0.02em;
      line-height: 1;
      margin-bottom: 1rem;
      text-transform: uppercase;
    }
 
    .os-cta p {
      font-size: 1.1rem;
      color: rgba(41,54,58,0.8);
      margin-bottom: 2.5rem;
    }
 
    .btn-cta-dark {
      display: inline-block;
      background: var(--dark);
      color: var(--white);
      font-family: var(--font-display);
      font-size: 1.3rem;
      letter-spacing: 0.1em;
      padding: 1.1rem 3rem;
      border-radius: 4px;
      text-decoration: none;
      transition: background 0.25s, transform 0.2s, box-shadow 0.25s;
    }
 
    .btn-cta-dark:hover {
      background: #1a2528;
      transform: translateY(-3px);
      box-shadow: 0 12px 30px rgba(0,0,0,0.2);
    }