/* ════════════════════════════════════════
       01. SAFARI HERO
       ════════════════════════════════════════ */
    .safari-hero {
      position: relative;
      min-height: 100vh;
      display: flex;
      align-items: flex-end;
      overflow: hidden;
      isolation: isolate;
      background: #060D1A;
    }

    .safari-hero__bg {
      position: absolute;
      inset: -8%;
      background: url('../images/safari-1.jpg') center/cover no-repeat;
      will-change: transform;
      animation: ken-burns 25s ease-in-out infinite;
    }

    @keyframes ken-burns {
      0%   { transform: scale(1.00) translate(0%, 0%); }
      30%  { transform: scale(1.10) translate(-0.8%, -0.5%); }
      60%  { transform: scale(1.14) translate(-0.3%, -0.8%); }
      100% { transform: scale(1.00) translate(0%, 0%); }
    }

    .safari-hero__overlays {
      position: absolute;
      inset: 0;
      z-index: 2;
      pointer-events: none;
    }

    .safari-hero__vignette {
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 70% 60% at 50% 50%, transparent 30%, rgba(6,13,26,0.65) 100%);
    }

    .safari-hero__gradient {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(6,13,26,0.35) 0%, transparent 30%, transparent 40%, rgba(6,13,26,0.75) 100%),
        linear-gradient(90deg, rgba(6,13,26,0.40) 0%, transparent 50%);
    }

    .safari-hero__dust {
      position: absolute;
      inset: 0;
      pointer-events: none;
      z-index: 3;
      overflow: hidden;
    }

    .safari-dust {
      position: absolute;
      border-radius: var(--radius-full);
      pointer-events: none;
      will-change: transform, opacity;
    }

    .safari-dust--warm {
      width: var(--s, 3px);
      height: var(--s, 3px);
      background: rgba(212,169,106,0.50);
      animation: safari-dust-drift var(--d, 12s) ease-in-out infinite var(--dl, 0s);
      left: var(--x, 50%);
      top: var(--y, 50%);
      opacity: 0;
    }

    .safari-dust--gold {
      width: var(--s, 2px);
      height: var(--s, 2px);
      background: rgba(255,179,71,0.60);
      box-shadow: 0 0 6px rgba(255,179,71,0.30);
      animation: safari-dust-drift var(--d, 9s) ease-in-out infinite var(--dl, 0s);
      left: var(--x, 50%);
      top: var(--y, 50%);
      opacity: 0;
    }

    @keyframes safari-dust-drift {
      0%   { transform: translate(0, 0) scale(0.7); opacity: 0; }
      10%  { opacity: 0.7; }
      50%  { transform: translate(var(--dx, 20px), var(--dy, -50px)) scale(1); opacity: 0.45; }
      85%  { opacity: 0.12; }
      100% { transform: translate(calc(var(--dx, 20px) * 2.2), calc(var(--dy, -50px) * 1.6)) scale(0.6); opacity: 0; }
    }

    /* Dust positions */
    .sd1{--x:4%;--y:80%;--d:14s;--dl:0s;--dx:18px;--dy:-60px;--s:3px}
    .sd2{--x:12%;--y:65%;--d:11s;--dl:-3s;--dx:-12px;--dy:-45px;--s:2.5px}
    .sd3{--x:22%;--y:85%;--d:16s;--dl:-6s;--dx:25px;--dy:-70px;--s:3.5px}
    .sd4{--x:35%;--y:70%;--d:10s;--dl:-2s;--dx:-8px;--dy:-35px;--s:2px}
    .sd5{--x:48%;--y:90%;--d:13s;--dl:-5s;--dx:15px;--dy:-55px;--s:3px}
    .sd6{--x:60%;--y:75%;--d:15s;--dl:-1s;--dx:20px;--dy:-65px;--s:2.5px}
    .sd7{--x:72%;--y:88%;--d:12s;--dl:-4s;--dx:-14px;--dy:-50px;--s:3px}
    .sd8{--x:85%;--y:72%;--d:14s;--dl:-7s;--dx:22px;--dy:-75px;--s:3.5px}
    .sd9{--x:92%;--y:82%;--d:11s;--dl:-2s;--dx:-10px;--dy:-40px;--s:2px}
    .sd10{--x:55%;--y:60%;--d:9s;--dl:-8s;--dx:30px;--dy:-80px;--s:2px}

    .safari-hero__content {
      position: relative;
      z-index: 5;
      width: 100%;
      max-width: var(--container-2xl);
      margin-inline: auto;
      padding: 0 var(--gutter-lg) var(--space-9);
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: var(--space-5);
    }

    .safari-hero__badge {
      display: inline-flex;
      align-items: center;
      gap: var(--space-2);
      padding: var(--space-1) var(--space-3);
      background: rgba(255,255,255,0.08);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      border: 1px solid rgba(255,255,255,0.15);
      border-radius: var(--radius-full);
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      color: var(--color-secondary);
      opacity: 0;
      animation: anim-fade-up 0.8s var(--ease-smooth) 0.4s both;
    }

    .safari-hero__badge-dot {
      width: 6px;
      height: 6px;
      border-radius: var(--radius-full);
      background: var(--color-accent);
      animation: pulse 2s ease-in-out infinite;
    }

    .safari-hero__title {
      font-family: var(--font-display);
      font-size: var(--text-cinematic);
      font-weight: var(--weight-black);
      color: #fff;
      letter-spacing: var(--tracking-tight);
      line-height: 1.0;
      max-width: 800px;
      opacity: 0;
      animation: hero-enter 1.2s var(--ease-smooth) 0.5s both;
    }

    .safari-hero__title-line {
      display: block;
    }

    .safari-hero__title-accent {
      background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-dawn) 50%, var(--color-accent) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .safari-hero__subtitle {
      font-size: var(--text-lg);
      color: rgba(255,255,255,0.55);
      line-height: var(--leading-relaxed);
      max-width: 520px;
      opacity: 0;
      animation: anim-fade-up 0.8s var(--ease-smooth) 0.7s both;
    }

    .safari-hero__actions {
      display: flex;
      align-items: center;
      gap: var(--space-4);
      flex-wrap: wrap;
      opacity: 0;
      animation: anim-fade-up 0.8s var(--ease-smooth) 0.9s both;
    }

    .safari-hero__stats {
      display: flex;
      gap: var(--space-6);
      margin-top: var(--space-4);
      opacity: 0;
      animation: anim-fade-up 0.8s var(--ease-smooth) 1.1s both;
    }

    .safari-hero__stat {
      text-align: left;
    }

    .safari-hero__stat-value {
      font-family: var(--font-display);
      font-size: var(--text-xl);
      font-weight: var(--weight-bold);
      color: #fff;
      line-height: 1;
      margin-block-end: 2px;
    }

    .safari-hero__stat-label {
      font-size: var(--text-xs);
      color: rgba(255,255,255,0.40);
      letter-spacing: var(--tracking-wide);
      text-transform: uppercase;
    }

    .safari-hero__scroll {
      position: absolute;
      bottom: var(--space-5);
      inset-inline-end: var(--space-7);
      z-index: 5;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: var(--space-2);
      color: rgba(255,255,255,0.40);
      animation: float 2.5s ease-in-out infinite;
    }

    .safari-hero__scroll-text {
      font-size: var(--text-xs);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      writing-mode: vertical-rl;
    }

    @media (max-width: 767px) {
      .safari-hero__content {
        align-items: center;
        text-align: center;
        padding-bottom: var(--space-7);
      }
      .safari-hero__stats { justify-content: center; }
      .safari-hero__actions { justify-content: center; }
      .safari-hero__scroll { display: none; }
    }


    /* ════════════════════════════════════════
       02. SAFARI EXPERIENCE CARDS
       ════════════════════════════════════════ */
    .safari-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: var(--space-5);
    }

    .safari-card {
      position: relative;
      border-radius: var(--radius-card);
      overflow: hidden;
      cursor: pointer;
      isolation: isolate;
      background: var(--color-surface);
      box-shadow: var(--shadow-md);
      border: 1px solid var(--color-border);
      transition:
        transform var(--transition-base),
        box-shadow var(--transition-base),
        border-color var(--transition-base);
    }

    .safari-card:hover {
      transform: translateY(-8px);
      box-shadow: var(--shadow-2xl), 0 0 50px rgba(139,94,60,0.10);
      border-color: transparent;
    }

    .safari-card__media {
      position: relative;
      overflow: hidden;
      aspect-ratio: 4 / 3;
    }

    .safari-card__media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform var(--transition-slow);
      will-change: transform;
    }

    .safari-card:hover .safari-card__media img {
      transform: scale(1.08);
    }

    .safari-card__media-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(6,13,26,0.60) 0%, rgba(6,13,26,0.10) 50%, transparent 100%);
      pointer-events: none;
    }

    .safari-card__tag {
      position: absolute;
      top: var(--space-3);
      left: var(--space-3);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 4px 12px;
      background: rgba(255,255,255,0.12);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,0.20);
      border-radius: var(--radius-full);
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-wide);
      color: #fff;
      text-transform: uppercase;
    }

    .safari-card__difficulty {
      position: absolute;
      top: var(--space-3);
      right: var(--space-3);
      display: flex;
      gap: 3px;
      padding: 4px 10px;
      background: rgba(0,0,0,0.40);
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      border-radius: var(--radius-full);
    }

    .safari-card__difficulty-dot {
      width: 6px;
      height: 6px;
      border-radius: var(--radius-full);
      background: rgba(255,255,255,0.25);
    }

    .safari-card__difficulty-dot--active {
      background: var(--color-dawn);
    }

    .safari-card__body {
      padding: var(--space-5) var(--space-5) var(--space-6);
    }

    .safari-card__location {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      color: var(--color-safari);
      margin-block-end: var(--space-2);
    }

    .safari-card__location svg {
      width: 14px;
      height: 14px;
    }

    .safari-card__title {
      font-family: var(--font-heading);
      font-size: var(--text-xl);
      font-weight: var(--weight-bold);
      color: var(--color-text-primary);
      margin-block-end: var(--space-3);
      line-height: var(--leading-snug);
      transition: color var(--transition-fast);
    }

    .safari-card:hover .safari-card__title {
      color: var(--color-accent);
    }

    .safari-card__meta {
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-3);
      margin-block-end: var(--space-4);
    }

    .safari-card__meta-item {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: var(--text-sm);
      color: var(--color-text-muted);
    }

    .safari-card__meta-item svg {
      width: 15px;
      height: 15px;
      opacity: 0.6;
    }

    .safari-card__footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-top: var(--space-4);
      border-top: 1px solid var(--color-border);
    }

    .safari-card__price {
      font-family: var(--font-display);
      font-weight: var(--weight-extrabold);
      font-size: var(--text-xl);
      color: var(--color-text-primary);
    }

    .safari-card__price span {
      font-size: var(--text-sm);
      font-weight: var(--weight-regular);
      color: var(--color-text-muted);
    }

    .safari-card__cta {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: var(--text-sm);
      font-weight: var(--weight-semibold);
      color: var(--color-accent);
      transition: gap var(--transition-fast);
    }

    .safari-card:hover .safari-card__cta {
      gap: 10px;
    }

    .safari-card__cta svg {
      width: 16px;
      height: 16px;
    }

    @media (max-width: 1023px) {
      .safari-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (max-width: 639px) {
      .safari-grid { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; }
    }


    /* ════════════════════════════════════════
       03. WILDLIFE HIGHLIGHTS
       ════════════════════════════════════════ */
    .wildlife-section {
      position: relative;
      background: var(--color-night);
      overflow: hidden;
    }

    .wildlife-section::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(ellipse 50% 40% at 20% 80%, rgba(139,94,60,0.06) 0%, transparent 70%),
        radial-gradient(ellipse 40% 35% at 80% 20%, rgba(26,77,46,0.06) 0%, transparent 70%);
      pointer-events: none;
    }

    .wildlife-list {
      display: flex;
      flex-direction: column;
      gap: var(--space-7);
    }

    .wildlife-item {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--space-7);
      align-items: center;
      position: relative;
    }

    .wildlife-item:nth-child(even) {
      direction: rtl;
    }

    .wildlife-item:nth-child(even) > * {
      direction: ltr;
    }

    .wildlife-item__media {
      position: relative;
      border-radius: var(--radius-xl);
      overflow: hidden;
      aspect-ratio: 4 / 3;
      box-shadow: var(--shadow-xl);
    }

    .wildlife-item__media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 8s ease-out;
    }

    .wildlife-item.is-visible .wildlife-item__media img {
      transform: scale(1.06);
    }

    .wildlife-item__media-float {
      position: absolute;
      width: 60px;
      height: 60px;
      border: 1.5px solid rgba(212,169,106,0.15);
      border-radius: var(--radius-lg);
      animation: float 5s ease-in-out infinite;
      pointer-events: none;
    }

    .wildlife-item__media-float--1 {
      bottom: -15px;
      right: -15px;
      transform: rotate(12deg);
      animation-delay: -1s;
    }

    .wildlife-item__media-float--2 {
      top: -10px;
      left: -10px;
      width: 40px;
      height: 40px;
      border-radius: var(--radius-full);
      border-color: rgba(244,98,42,0.12);
      animation-delay: -3s;
    }

    .wildlife-item__content {
      display: flex;
      flex-direction: column;
      gap: var(--space-4);
    }

    .wildlife-item__emoji {
      font-size: 40px;
      line-height: 1;
      filter: drop-shadow(0 4px 12px rgba(0,0,0,0.3));
    }

    .wildlife-item__title {
      font-family: var(--font-display);
      font-size: var(--text-3xl);
      font-weight: var(--weight-bold);
      color: var(--color-text-inverse);
      line-height: var(--leading-snug);
    }

    .wildlife-item__title-accent {
      color: var(--color-safari-light);
    }

    .wildlife-item__desc {
      font-size: var(--text-md);
      color: rgba(255,255,255,0.50);
      line-height: var(--leading-relaxed);
    }

    .wildlife-item__facts {
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-3);
    }

    .wildlife-fact {
      display: flex;
      align-items: center;
      gap: var(--space-2);
      padding: var(--space-2) var(--space-3);
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: var(--radius-md);
      font-size: var(--text-sm);
      color: rgba(255,255,255,0.55);
    }

    .wildlife-fact strong {
      color: var(--color-secondary);
      font-weight: var(--weight-semibold);
    }

    @media (max-width: 767px) {
      .wildlife-item,
      .wildlife-item:nth-child(even) {
        grid-template-columns: 1fr;
        direction: ltr;
        gap: var(--space-4);
      }
      .wildlife-item__title { font-size: var(--text-2xl); }
    }


    /* ════════════════════════════════════════
       04. JOURNEY TIMELINE
       ════════════════════════════════════════ */
    .journey-timeline {
      position: relative;
      max-width: 800px;
      margin-inline: auto;
    }

    .journey-timeline__line {
      position: absolute;
      left: 24px;
      top: 0;
      bottom: 0;
      width: 2px;
      background: var(--color-border);
      border-radius: 2px;
      overflow: hidden;
    }

    .journey-timeline__line-fill {
      width: 100%;
      height: 0%;
      background: linear-gradient(180deg, var(--color-safari) 0%, var(--color-accent) 50%, var(--color-dawn) 100%);
      border-radius: 2px;
      transition: height 0.1s linear;
      box-shadow: 0 0 16px rgba(139,94,60,0.30);
    }

    .journey-timeline__step {
      position: relative;
      padding-left: 72px;
      padding-bottom: var(--space-7);
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 0.7s var(--ease-smooth), transform 0.7s var(--ease-smooth);
    }

    .journey-timeline__step.is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    .journey-timeline__step:last-child {
      padding-bottom: 0;
    }

    .journey-timeline__dot {
      position: absolute;
      left: 15px;
      top: 4px;
      width: 20px;
      height: 20px;
      border-radius: var(--radius-full);
      border: 2px solid var(--color-border-strong);
      background: var(--color-surface);
      z-index: 2;
      transition: all 0.5s var(--ease-smooth);
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .journey-timeline__dot-inner {
      width: 8px;
      height: 8px;
      border-radius: var(--radius-full);
      background: transparent;
      transition: background 0.4s var(--ease-smooth), box-shadow 0.4s var(--ease-smooth);
    }

    .journey-timeline__step.is-passed .journey-timeline__dot {
      border-color: var(--color-safari);
    }

    .journey-timeline__step.is-passed .journey-timeline__dot-inner {
      background: var(--color-safari);
    }

    .journey-timeline__step.is-active .journey-timeline__dot {
      border-color: var(--color-accent);
      box-shadow: 0 0 0 5px rgba(244,98,42,0.15), 0 0 24px rgba(244,98,42,0.25);
    }

    .journey-timeline__step.is-active .journey-timeline__dot-inner {
      background: var(--color-accent);
      box-shadow: 0 0 8px var(--color-accent-glow);
    }

    .journey-timeline__time {
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      color: var(--color-safari);
      margin-block-end: var(--space-2);
    }

    .journey-timeline__title {
      font-family: var(--font-heading);
      font-size: var(--text-xl);
      font-weight: var(--weight-bold);
      color: var(--color-text-primary);
      margin-block-end: var(--space-2);
    }

    .journey-timeline__desc {
      font-size: var(--text-base);
      color: var(--color-text-secondary);
      line-height: var(--leading-relaxed);
      max-width: 480px;
    }

    .journey-timeline__image {
      margin-top: var(--space-3);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow-sm);
      max-width: 360px;
    }

    .journey-timeline__image img {
      width: 100%;
      height: auto;
      display: block;
    }

    @media (min-width: 768px) {
      .journey-timeline__line {
        left: 50%;
        transform: translateX(-50%);
      }
      .journey-timeline__step {
        padding-left: 0;
        width: 50%;
      }
      .journey-timeline__step:nth-child(odd) {
        padding-right: 64px;
        text-align: right;
      }
      .journey-timeline__step:nth-child(odd) .journey-timeline__image {
        margin-inline-end: auto;
      }
      .journey-timeline__step:nth-child(even) {
        margin-left: 50%;
        padding-left: 64px;
      }
      .journey-timeline__step:nth-child(even) .journey-timeline__image {
        margin-inline-start: auto;
      }
      .journey-timeline__dot { left: auto; }
      .journey-timeline__step:nth-child(odd) .journey-timeline__dot { right: -41px; }
      .journey-timeline__step:nth-child(even) .journey-timeline__dot { left: -41px; }
    }


    /* ════════════════════════════════════════
       05. MAP SECTION
       ════════════════════════════════════════ */
    .safari-map {
      position: relative;
      background: var(--gradient-hero);
      overflow: hidden;
    }

    .safari-map__inner {
      position: relative;
      max-width: 1000px;
      margin-inline: auto;
    }

    .safari-map__svg-wrap {
      position: relative;
      width: 100%;
      max-width: 700px;
      margin-inline: auto;
    }

    .safari-map__svg-wrap svg {
      width: 100%;
      height: auto;
      filter: drop-shadow(0 4px 30px rgba(0,0,0,0.3));
    }

    .safari-map__continent {
      fill: rgba(139,94,60,0.12);
      stroke: rgba(212,169,106,0.20);
      stroke-width: 1;
      transition: fill 0.5s var(--ease-smooth);
    }

    .safari-map__pin {
      cursor: pointer;
      transition: transform 0.3s var(--ease-bounce);
      transform-origin: center bottom;
    }

    .safari-map__pin:hover {
      transform: scale(1.3) translateY(-4px);
    }

    .safari-map__pin-pulse {
      animation: map-pin-pulse 2.5s ease-out infinite;
      transform-origin: center;
    }

    @keyframes map-pin-pulse {
      0%   { r: 8; opacity: 0.4; }
      100% { r: 20; opacity: 0; }
    }

    .safari-map__tooltip {
      position: absolute;
      padding: var(--space-3) var(--space-4);
      background: rgba(13,26,46,0.92);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: var(--radius-md);
      color: #fff;
      pointer-events: none;
      opacity: 0;
      transform: translateY(8px);
      transition: opacity 0.3s var(--ease-smooth), transform 0.3s var(--ease-smooth);
      white-space: nowrap;
      z-index: 10;
      box-shadow: var(--shadow-xl);
    }

    .safari-map__tooltip.is-visible {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }

    .safari-map__tooltip-title {
      font-family: var(--font-heading);
      font-size: var(--text-sm);
      font-weight: var(--weight-semibold);
      margin-block-end: 2px;
    }

    .safari-map__tooltip-sub {
      font-size: var(--text-xs);
      color: rgba(255,255,255,0.50);
    }

    .safari-map__legend {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: var(--space-4);
      margin-top: var(--space-6);
    }

    .safari-map__legend-item {
      display: flex;
      align-items: center;
      gap: var(--space-2);
      font-size: var(--text-sm);
      color: rgba(255,255,255,0.50);
    }

    .safari-map__legend-dot {
      width: 8px;
      height: 8px;
      border-radius: var(--radius-full);
    }


    /* ════════════════════════════════════════
       06. TESTIMONIALS
       ════════════════════════════════════════ */
    .safari-testimonials {
      position: relative;
      overflow: hidden;
    }

    .safari-testimonials__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: var(--space-5);
    }

    .safari-testimonial {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-card);
      padding: var(--space-6);
      box-shadow: var(--shadow-md);
      position: relative;
      overflow: hidden;
      transition:
        transform var(--transition-base),
        box-shadow var(--transition-base);
    }

    .safari-testimonial::before {
      content: '';
      position: absolute;
      top: 0;
      inset-inline: 0;
      height: 3px;
      background: var(--gradient-safari);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform var(--transition-base);
    }

    .safari-testimonial:hover::before {
      transform: scaleX(1);
    }

    .safari-testimonial:hover {
      transform: translateY(-4px);
      box-shadow: var(--shadow-xl);
    }

    .safari-testimonial--featured {
      grid-column: span 1;
      background: linear-gradient(135deg, rgba(139,94,60,0.06), rgba(10,37,64,0.04));
      border-color: rgba(139,94,60,0.15);
    }

    .safari-testimonial__stars {
      display: flex;
      gap: 3px;
      color: var(--color-dawn);
      margin-block-end: var(--space-4);
    }

    .safari-testimonial__stars svg {
      width: 16px;
      height: 16px;
      fill: currentColor;
    }

    .safari-testimonial__quote {
      font-size: var(--text-md);
      color: var(--color-text-secondary);
      line-height: var(--leading-relaxed);
      font-style: italic;
      margin-block-end: var(--space-5);
    }

    .safari-testimonial__author {
      display: flex;
      align-items: center;
      gap: var(--space-3);
    }

    .safari-testimonial__avatar {
      width: 48px;
      height: 48px;
      border-radius: var(--radius-full);
      object-fit: cover;
      border: 2px solid var(--color-border);
    }

    .safari-testimonial__avatar-placeholder {
      width: 48px;
      height: 48px;
      border-radius: var(--radius-full);
      background: var(--gradient-safari);
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: var(--font-display);
      font-size: var(--text-md);
      font-weight: var(--weight-bold);
      color: #fff;
    }

    .safari-testimonial__name {
      font-weight: var(--weight-semibold);
      font-size: var(--text-sm);
      color: var(--color-text-primary);
    }

    .safari-testimonial__trip {
      font-size: var(--text-xs);
      color: var(--color-text-muted);
    }

    @media (max-width: 1023px) {
      .safari-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
      .safari-testimonial--featured { grid-column: span 2; }
    }

    @media (max-width: 639px) {
      .safari-testimonials__grid { grid-template-columns: 1fr; }
      .safari-testimonial--featured { grid-column: span 1; }
    }


    /* ════════════════════════════════════════
       07. SAFARI CTA
       ════════════════════════════════════════ */
    .safari-cta {
      position: relative;
      min-height: 70vh;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      isolation: isolate;
    }

    .safari-cta__bg {
      position: absolute;
      inset: -5%;
      background: url('../images/safari-7.jpg') center/cover no-repeat;
      will-change: transform;
      animation: ken-burns-slow 30s ease-in-out infinite;
    }

    @keyframes ken-burns-slow {
      0%   { transform: scale(1.02) translate(0%, 0%); }
      50%  { transform: scale(1.10) translate(-0.5%, -0.3%); }
      100% { transform: scale(1.02) translate(0%, 0%); }
    }

    .safari-cta__overlay {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(6,13,26,0.50) 0%, rgba(6,13,26,0.80) 100%),
        radial-gradient(ellipse 50% 50% at 50% 60%, rgba(244,98,42,0.08) 0%, transparent 70%);
      z-index: 1;
    }

    .safari-cta__content {
      position: relative;
      z-index: 2;
      text-align: center;
      max-width: 640px;
      padding: var(--space-5);
    }

    .safari-cta__label {
      display: inline-flex;
      align-items: center;
      gap: var(--space-2);
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      color: var(--color-secondary);
      margin-block-end: var(--space-4);
    }

    .safari-cta__label-line {
      width: 24px;
      height: 1.5px;
      background: var(--color-secondary);
      opacity: 0.5;
    }

    .safari-cta__title {
      font-family: var(--font-display);
      font-size: var(--text-display);
      font-weight: var(--weight-black);
      color: #fff;
      letter-spacing: var(--tracking-tight);
      line-height: var(--leading-tight);
      margin-block-end: var(--space-4);
    }

    .safari-cta__desc {
      font-size: var(--text-lg);
      color: rgba(255,255,255,0.50);
      line-height: var(--leading-relaxed);
      margin-block-end: var(--space-7);
    }

    .safari-cta__btn {
      position: relative;
      display: inline-flex;
      align-items: center;
      gap: var(--space-3);
      padding: var(--space-4) var(--space-8);
      background: var(--color-accent);
      color: #fff;
      font-family: var(--font-body);
      font-size: var(--text-md);
      font-weight: var(--weight-bold);
      letter-spacing: var(--tracking-wide);
      border: none;
      border-radius: var(--radius-full);
      cursor: pointer;
      text-decoration: none;
      box-shadow:
        0 4px 24px var(--color-accent-glow),
        0 0 60px rgba(244,98,42,0.15);
      transition:
        transform var(--transition-base),
        box-shadow var(--transition-base),
        background var(--transition-fast);
      overflow: hidden;
    }

    .safari-cta__btn::before {
      content: '';
      position: absolute;
      inset: 0;
      background: rgba(255,255,255,0.15);
      transform: translateX(-100%) skewX(-15deg);
      transition: transform 0.5s var(--ease-smooth);
    }

    .safari-cta__btn:hover::before {
      transform: translateX(100%) skewX(-15deg);
    }

    .safari-cta__btn:hover {
      transform: translateY(-4px) scale(1.04);
      box-shadow:
        0 8px 40px var(--color-accent-glow),
        0 0 80px rgba(244,98,42,0.25),
        0 0 120px rgba(244,98,42,0.10);
      animation: glow-pulse 2s ease-in-out infinite;
    }

    .safari-cta__btn:active {
      transform: translateY(-2px) scale(0.98);
    }

    .safari-cta__btn svg {
      width: 20px;
      height: 20px;
      transition: transform var(--transition-base);
    }

    .safari-cta__btn:hover svg {
      transform: translateX(4px);
    }


    /* ════════════════════════════════════════
       08. SECTION HELPERS
       ════════════════════════════════════════ */
    .section-tag {
      display: inline-flex;
      align-items: center;
      gap: var(--space-2);
      padding: var(--space-1) var(--space-3);
      background: rgba(139,94,60,0.08);
      border: 1px solid rgba(139,94,60,0.15);
      border-radius: var(--radius-full);
      font-size: var(--text-xs);
      font-weight: var(--weight-semibold);
      letter-spacing: var(--tracking-widest);
      text-transform: uppercase;
      color: var(--color-safari);
      margin-block-end: var(--space-4);
    }

    [data-theme="dark"] .section-tag {
      background: rgba(196,154,108,0.08);
      border-color: rgba(196,154,108,0.15);
    }


    /* ════════════════════════════════════════
       09. REDUCED MOTION
       ════════════════════════════════════════ */
    @media (prefers-reduced-motion: reduce) {
      .safari-hero__bg,
      .safari-cta__bg {
        animation: none !important;
      }
      .safari-dust { display: none !important; }
      .journey-timeline__line-fill { transition: none !important; }
      .journey-timeline__step {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
      }
      .wildlife-item.is-visible .wildlife-item__media img {
        transform: none !important;
      }
      .safari-card:hover,
      .safari-testimonial:hover {
        transform: none !important;
      }
      .safari-card:hover .safari-card__media img {
        transform: none !important;
      }
      .safari-map__pin-pulse { animation: none !important; }
      .safari-hero__badge,
      .safari-hero__title,
      .safari-hero__subtitle,
      .safari-hero__actions,
      .safari-hero__stats {
        opacity: 1 !important;
        animation: none !important;
      }
    }