/* ============================================================
   Trips / Range Page — trips.css
   ============================================================ */

/* Fixed frosted-glass header for trips page */
.hd-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: rgba(10, 10, 14, 0.45);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 200;
}
.hd-header.scrolled {
  background: rgba(10, 10, 14, 0.88);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
}
.hd-header .hd-logo,
.hd-header .hd-nav__link,
.hd-header .hd-nav__link span,

.hd-header .gx-btn--dark {
  color: #fff;
}

/* ============================================================
   1. HERO
   ============================================================ */
.trp-hero {
  position: relative;
  min-height: 100vh;
  background: var(--gx-darker);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-top: 5rem;
}
.trp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(6,8,16,0.88) 0%,
    rgba(6,8,16,0.72) 50%,
    rgba(6,8,16,0.85) 100%
  );
  z-index: 1;
}
.trp-hero > * { position: relative; z-index: 2; }

/* Background large distance number */
.trp-hero__bg-num {
  position: absolute;
  bottom: -3rem;
  right: -2rem;
  font-family: var(--gx-font-heading);
  font-size: clamp(16rem, 28vw, 34rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.06em;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.035);
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
}

/* Lime glow */
.trp-hero__glow {
  position: absolute;
  bottom: -12rem;
  left: -8rem;
  width: 48rem;
  height: 48rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,236,102,0.08) 0%, transparent 65%);
  pointer-events: none;
}

.trp-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gx-sp-80);
  align-items: center;
  padding-block: var(--gx-sp-120);
}

/* Content */
.trp-hero__content {
  animation: trp-enter 900ms 80ms var(--gx-ease) both;
}

@keyframes trp-enter {
  from { opacity: 0; transform: translateY(2.5rem); }
  to   { opacity: 1; transform: translateY(0); }
}

.trp-hero__label {
  color: var(--gx-lime) !important;
  margin-bottom: var(--gx-sp-24);
}

.trp-hero__title {
  font-family: var(--gx-font-heading);
  font-size: clamp(3rem, 5.5vw, 6rem);
  font-weight: 700;
  color: var(--gx-white);
  line-height: 0.93;
  margin-bottom: var(--gx-sp-32);
}

.trp-hero__desc {
  font-size: 1.0625rem;
  color: var(--gx-gray);
  line-height: 1.7;
  max-width: 28rem;
  margin-bottom: var(--gx-sp-48);
}

.trp-hero__actions {
  display: flex;
  gap: var(--gx-sp-16);
  flex-wrap: wrap;
}
.trp-hero .gx-btn--outline .gx-btn__circle {
  background: #fff;
  color: var(--gx-dark);
}
.trp-hero .gx-btn--outline:hover .gx-btn__circle {
  background: var(--gx-dark);
  color: #fff;
}
.trp-hero .gx-btn--primary:hover .gx-btn__circle {
  background: #fff;
  color: var(--gx-dark);
}

/* Right — route visualization */
.trp-hero__route {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  animation: trp-enter 900ms 300ms var(--gx-ease) both;
  padding-left: var(--gx-sp-64);
  border-left: 1px solid rgba(255,255,255,0.07);
}

.trp-hero__stop {
  display: flex;
  align-items: center;
  gap: var(--gx-sp-16);
  position: relative;
}

.trp-hero__stop-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.2);
  background: var(--gx-darker);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  transition: border-color var(--gx-t);
}

.trp-hero__stop--origin .trp-hero__stop-dot {
  border-color: var(--gx-lime);
  background: var(--gx-lime);
  box-shadow: 0 0 0 4px rgba(201,236,102,0.2);
}

.trp-hero__stop--dest .trp-hero__stop-dot {
  border-color: var(--gx-lime);
}

.trp-hero__stop-info {}

.trp-hero__stop-city {
  display: block;
  font-family: var(--gx-font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gx-white);
  letter-spacing: -0.02em;
}

.trp-hero__stop-meta {
  display: block;
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray-mid);
  margin-top: 0.2rem;
}

/* Animated dashed connector between stops */
.trp-hero__connector {
  display: flex;
  align-items: center;
  gap: var(--gx-sp-16);
  padding-block: var(--gx-sp-12);
}

.trp-hero__connector-line {
  width: 2px;
  background: repeating-linear-gradient(
    to bottom,
    rgba(201,236,102,0.5) 0px,
    rgba(201,236,102,0.5) 6px,
    transparent 6px,
    transparent 12px
  );
  height: 3.5rem;
  margin-left: 6px; /* half of dot width - half of line width */
  animation: trp-dash-flow 3s linear infinite;
}

@keyframes trp-dash-flow {
  from { background-position: 0 0; }
  to   { background-position: 0 24px; }
}

.trp-hero__connector-tag {
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-lime);
  background: rgba(201,236,102,0.08);
  border: 1px solid rgba(201,236,102,0.2);
  padding: 0.2rem 0.6rem;
  border-radius: var(--gx-r-full);
}

/* Total distance badge */
.trp-hero__total {
  display: flex;
  align-items: baseline;
  gap: var(--gx-sp-8);
  margin-top: var(--gx-sp-32);
  padding-top: var(--gx-sp-32);
  border-top: 1px solid rgba(255,255,255,0.07);
  width: 100%;
}

.trp-hero__total-num {
  font-family: var(--gx-font-heading);
  font-size: 4rem;
  font-weight: 800;
  color: var(--gx-lime);
  line-height: 1;
  letter-spacing: -0.05em;
}

.trp-hero__total-unit {
  font-family: var(--gx-font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gx-gray);
  letter-spacing: -0.02em;
}

.trp-hero__total-label {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray-mid);
  margin-left: auto;
  align-self: center;
}

/* Scroll indicator */
.trp-hero__scroll {
  position: absolute;
  bottom: var(--gx-sp-48);
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  color: var(--gx-gray);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gx-sp-8);
  z-index: 1;
}

.trp-hero__scroll::after {
  content: '';
  width: 1px;
  height: 2.5rem;
  background: linear-gradient(to bottom, var(--gx-lime), transparent);
  animation: trp-scroll 2.5s ease-in-out infinite;
}

@keyframes trp-scroll {
  0%, 100% { opacity: 0.2; transform: scaleY(0.7); }
  50%       { opacity: 1;   transform: scaleY(1); }
}

/* ============================================================
   2. MODEL RANGE CARDS
   ============================================================ */
.trp-models {
  background: var(--gx-off-white);
  padding-block: var(--gx-sp-150);
}

.trp-models__head {
  margin-bottom: var(--gx-sp-64);
}

.trp-models__head .gx-label { color: var(--gx-gray-mid) !important; margin-bottom: var(--gx-sp-16); }

.trp-models__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gx-sp-24);
}

.trp-model-card {
  background: var(--gx-white);
  border-radius: var(--gx-r-2xl);
  padding: var(--gx-sp-48) var(--gx-sp-40);
  border: 1px solid var(--gx-gray-light);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform 350ms var(--gx-ease), box-shadow 350ms var(--gx-ease);
}

.trp-model-card--featured {
  border-color: rgba(201,236,102,0.4);
  background: linear-gradient(180deg, rgba(201,236,102,0.03) 0%, var(--gx-white) 40%);
}

.trp-model-card--featured::before {
  content: 'Best Range';
  position: absolute;
  top: var(--gx-sp-20);
  right: var(--gx-sp-20);
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-dark);
  background: var(--gx-lime);
  padding: 0.25rem 0.625rem;
  border-radius: var(--gx-r-full);
}

.trp-model-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--gx-sh-lg);
}

/* SVG Arc Gauge */
.trp-arc {
  position: relative;
  width: 10rem;
  height: 10rem;
  margin-bottom: var(--gx-sp-24);
}

.trp-arc svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}

.trp-arc__track {
  fill: none;
  stroke: var(--gx-gray-light);
  stroke-width: 7;
  stroke-dasharray: 235.62 78.54;
  stroke-linecap: round;
}

.trp-arc__fill {
  fill: none;
  stroke: var(--gx-lime);
  stroke-width: 7;
  stroke-dasharray: 235.62 78.54;
  stroke-dashoffset: 235.62; /* fully empty by default */
  stroke-linecap: round;
  transition: stroke-dashoffset 1.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.trp-arc.is-animated .trp-arc__fill {
  stroke-dashoffset: var(--arc-end, 0);
}

.trp-arc__center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: 1rem; /* optical center for 270° arc */
}

.trp-arc__km {
  font-family: var(--gx-font-heading);
  font-size: 2rem;
  font-weight: 800;
  color: var(--gx-g500);
  line-height: 1;
  letter-spacing: -0.04em;
}

.trp-arc__unit {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray-mid);
  margin-top: 0.25rem;
}

.trp-model-card__name {
  font-family: var(--gx-font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gx-g500);
  letter-spacing: -0.02em;
  margin-bottom: var(--gx-sp-8);
}

.trp-model-card__type {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray-mid);
  margin-bottom: var(--gx-sp-24);
}

.trp-model-card__specs {
  width: 100%;
  border-top: 1px solid var(--gx-gray-light);
  padding-top: var(--gx-sp-20);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gx-sp-16);
  text-align: left;
}

.trp-model-card__spec-label {
  display: block;
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gx-gray-mid);
  margin-bottom: 0.25rem;
}

.trp-model-card__spec-val {
  display: block;
  font-family: var(--gx-font-heading);
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--gx-g400);
  letter-spacing: -0.01em;
}

/* ============================================================
   3. POPULAR ROUTES
   ============================================================ */
.trp-routes {
  background: var(--gx-dark);
  padding-block: var(--gx-sp-150);
}

.trp-routes__head { margin-bottom: var(--gx-sp-64); }
.trp-routes__head .gx-label { color: var(--gx-lime) !important; margin-bottom: var(--gx-sp-16); }
.trp-routes__head .gx-h2 { color: var(--gx-white) !important; }

.trp-route-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.trp-route-item {
  display: grid;
  grid-template-columns: 14rem 1fr 14rem;
  align-items: center;
  gap: var(--gx-sp-32);
  padding-block: var(--gx-sp-24);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background var(--gx-t);
}

.trp-route-item:first-child {
  border-top: 1px solid rgba(255,255,255,0.06);
}

.trp-route-item:hover {
  background: rgba(255,255,255,0.02);
}

.trp-route-cities {
  display: flex;
  align-items: center;
  gap: var(--gx-sp-12);
}

.trp-route-city {
  font-family: var(--gx-font-heading);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--gx-white);
  letter-spacing: -0.01em;
}

.trp-route-arrow {
  color: var(--gx-lime);
  flex-shrink: 0;
}

/* Visual bar */
.trp-route-bar-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--gx-sp-8);
}

.trp-route-bar-track {
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,0.07);
  border-radius: 2px;
  overflow: hidden;
}

.trp-route-bar-fill {
  height: 100%;
  border-radius: 2px;
  background: var(--gx-lime);
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.trp-route-item.is-animated .trp-route-bar-fill {
  transform: scaleX(1);
}

.trp-route-bar-labels {
  display: flex;
  justify-content: space-between;
}

.trp-route-bar-dist {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  color: var(--gx-gray);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Model badges */
.trp-route-models {
  display: flex;
  gap: var(--gx-sp-8);
  justify-content: flex-end;
  flex-wrap: wrap;
}

.trp-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.25rem 0.625rem;
  border-radius: var(--gx-r-full);
  border: 1px solid;
}

.trp-badge--ok {
  color: var(--gx-lime);
  border-color: rgba(201,236,102,0.3);
  background: rgba(201,236,102,0.07);
}

.trp-badge--stop {
  color: var(--gx-gray);
  border-color: rgba(255,255,255,0.1);
  background: transparent;
}

/* ============================================================
   4. RANGE CALCULATOR
   ============================================================ */
.trp-calc {
  background: var(--gx-darker);
  padding-block: var(--gx-sp-150);
  position: relative;
  overflow: hidden;
}

.trp-calc::before {
  content: '';
  position: absolute;
  top: -15rem;
  right: -15rem;
  width: 50rem;
  height: 50rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,236,102,0.06) 0%, transparent 65%);
  pointer-events: none;
}

.trp-calc__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--gx-sp-96);
  align-items: start;
}

.trp-calc__head .gx-label { color: var(--gx-lime) !important; margin-bottom: var(--gx-sp-20); }
.trp-calc__head .gx-h2 { color: var(--gx-white) !important; margin-bottom: var(--gx-sp-16); }

.trp-calc__sub {
  font-size: 0.9375rem;
  color: var(--gx-gray);
  line-height: 1.65;
  margin-bottom: var(--gx-sp-48);
}

/* Slider */
.trp-calc__slider-label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--gx-sp-12);
}

.trp-calc__slider-text {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray);
}

.trp-calc__dist-display {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
}

.trp-calc__dist-num {
  font-family: var(--gx-font-heading);
  font-size: 3rem;
  font-weight: 800;
  color: var(--gx-lime);
  line-height: 1;
  letter-spacing: -0.05em;
}

.trp-calc__dist-unit {
  font-family: var(--gx-font-mono);
  font-size: 0.875rem;
  color: var(--gx-gray);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.trp-calc__slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  outline: none;
  position: relative;
  cursor: pointer;
  margin-bottom: var(--gx-sp-8);
}

.trp-calc__slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--gx-lime);
  cursor: pointer;
  border: 3px solid var(--gx-darker);
  box-shadow: 0 0 0 2px var(--gx-lime);
  transition: transform 150ms;
}

.trp-calc__slider::-moz-range-thumb {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--gx-lime);
  cursor: pointer;
  border: 3px solid var(--gx-darker);
  box-shadow: 0 0 0 2px var(--gx-lime);
}

.trp-calc__slider::-webkit-slider-thumb:hover {
  transform: scale(1.15);
}

.trp-calc__slider-range {
  display: flex;
  justify-content: space-between;
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  color: var(--gx-gray-mid);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--gx-sp-48);
}

/* Model status cards */
.trp-calc__models {
  display: flex;
  flex-direction: column;
  gap: var(--gx-sp-16);
}

.trp-calc__model {
  display: flex;
  align-items: center;
  gap: var(--gx-sp-20);
  padding: var(--gx-sp-20) var(--gx-sp-24);
  border-radius: var(--gx-r-xl);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  transition: border-color 300ms, background 300ms, opacity 300ms;
}

.trp-calc__model.is-covered {
  border-color: rgba(201,236,102,0.3);
  background: rgba(201,236,102,0.05);
}

.trp-calc__model.is-out {
  opacity: 0.4;
}

.trp-calc__model-indicator {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: var(--gx-font-mono);
  font-size: 0.7rem;
  color: var(--gx-gray);
  transition: border-color 300ms, background 300ms, color 300ms;
}

.trp-calc__model.is-covered .trp-calc__model-indicator {
  border-color: var(--gx-lime);
  background: var(--gx-lime);
  color: var(--gx-dark);
}

.trp-calc__model-info {
  flex: 1;
}

.trp-calc__model-name {
  display: block;
  font-family: var(--gx-font-heading);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--gx-white);
  letter-spacing: -0.01em;
}

.trp-calc__model-range {
  display: block;
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  color: var(--gx-gray-mid);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 0.2rem;
}

.trp-calc__model-status {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gx-gray-mid);
  white-space: nowrap;
  transition: color 300ms;
}

.trp-calc__model.is-covered .trp-calc__model-status {
  color: var(--gx-lime);
}

/* ============================================================
   5. RANGE FACTORS
   ============================================================ */
.trp-factors {
  background: var(--gx-beige);
  padding-block: var(--gx-sp-150);
}

.trp-factors__head { margin-bottom: var(--gx-sp-64); }
.trp-factors__head .gx-label { color: var(--gx-gray-mid) !important; margin-bottom: var(--gx-sp-16); }

.trp-factors__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gx-sp-20);
}

.trp-factor-card {
  background: var(--gx-white);
  border-radius: var(--gx-r-xl);
  padding: var(--gx-sp-40);
  border: 1px solid transparent;
  transition: transform 350ms var(--gx-ease), box-shadow 350ms var(--gx-ease), border-color 350ms;
  position: relative;
  overflow: hidden;
}

.trp-factor-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--gx-sh);
  border-color: rgba(201,236,102,0.4);
}

.trp-factor-card__icon {
  width: 3rem;
  height: 3rem;
  border-radius: var(--gx-r-md);
  background: rgba(15, 18, 30, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gx-g500);
  margin-bottom: var(--gx-sp-24);
  transition: background var(--gx-t), color var(--gx-t);
}

.trp-factor-card:hover .trp-factor-card__icon {
  background: rgba(15, 18, 30, 0.14);
}

.trp-factor-card__name {
  font-family: var(--gx-font-heading);
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--gx-g500);
  letter-spacing: -0.01em;
  margin-bottom: var(--gx-sp-8);
}

.trp-factor-card__impact {
  display: inline-flex;
  align-items: center;
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gx-gray-mid);
  border: 1px solid var(--gx-gray-light);
  padding: 0.2rem 0.6rem;
  border-radius: var(--gx-r-full);
  margin-bottom: var(--gx-sp-16);
}

.trp-factor-card__text {
  font-size: 0.875rem;
  color: var(--gx-g100);
  line-height: 1.65;
}

/* ============================================================
   6. TRAVEL PACKAGES
   ============================================================ */
.trp-packages {
  background: var(--gx-off-white);
  padding-block: var(--gx-sp-150);
}

.trp-packages__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gx-sp-64);
  align-items: end;
  margin-bottom: var(--gx-sp-64);
}

.trp-packages__head .gx-label {
  color: var(--gx-gray-mid) !important;
  margin-bottom: var(--gx-sp-16);
}

.trp-packages__head .gx-h2 {
  line-height: 1.1;
}

.trp-packages__sub {
  font-size: 0.9375rem;
  color: var(--gx-g100);
  line-height: 1.65;
  margin-bottom: var(--gx-sp-24);
}

/* 3-column card grid */
.trp-pkg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gx-sp-20);
}

/* Card */
.trp-pkg-card {
  background: var(--gx-white);
  border-radius: var(--gx-r-2xl);
  border: 1px solid var(--gx-gray-light);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 380ms var(--gx-ease), box-shadow 380ms var(--gx-ease);
}

.trp-pkg-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--gx-sh-lg);
}

.trp-pkg-card--featured {
  border-color: rgba(201,236,102,0.5);
  box-shadow: 0 0 0 1px rgba(201,236,102,0.2);
}

/* Image area
   ─────────────────────────────────────────────────
   Template buyers: replace background with
   background-image: url(images/your-photo.jpg);
   background-size: cover; background-position: center;
   ───────────────────────────────────────────────── */
.trp-pkg-img {
  position: relative;
  height: 15rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--gx-sp-16);
  background-size: cover;
  background-position: center;
}

/* Gradient overlays per destination */
.trp-pkg-img[data-dest="paris"] {
  background: linear-gradient(155deg, #c9a96e 0%, #4a6fa5 60%, #1e3a5f 100%);
}
.trp-pkg-img[data-dest="norway"] {
  background: linear-gradient(155deg, #0d2b40 0%, #1a5c4a 50%, #2d8c6e 100%);
}
.trp-pkg-img[data-dest="swiss"] {
  background: linear-gradient(155deg, #6b8fae 0%, #a8c8b8 50%, #e8ede8 100%);
}
.trp-pkg-img[data-dest="spain"] {
  background: linear-gradient(155deg, #d4734a 0%, #e8a84c 40%, #2a8a96 100%);
}
.trp-pkg-img[data-dest="scotland"] {
  background: linear-gradient(155deg, #2d3d5c 0%, #4a6b4a 50%, #7a9060 100%);
}
.trp-pkg-img[data-dest="italy"] {
  background: linear-gradient(155deg, #1a6494 0%, #3a9ab8 40%, #e8c96e 100%);
}

/* Dark scrim so badges stay legible */
.trp-pkg-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.1) 50%, transparent 100%);
}

/* Big country name as texture */
.trp-pkg-img__country {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -52%);
  font-family: var(--gx-font-heading);
  font-size: 3.5rem;
  font-weight: 800;
  color: rgba(255,255,255,0.08);
  white-space: nowrap;
  letter-spacing: -0.03em;
  pointer-events: none;
  user-select: none;
}

/* Badges row */
.trp-pkg-img__badges {
  position: relative;
  z-index: 1;
  display: flex;
  gap: var(--gx-sp-8);
  flex-wrap: wrap;
}

.trp-pkg-img__badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.85);
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 0.3rem 0.65rem;
  border-radius: var(--gx-r-full);
  border: 1px solid rgba(255,255,255,0.12);
}

.trp-pkg-img__badge--lime {
  color: var(--gx-dark);
  background: var(--gx-lime);
  border-color: transparent;
}

/* Card body */
.trp-pkg-body {
  flex: 1;
  padding: var(--gx-sp-20) var(--gx-sp-24) var(--gx-sp-24);
  display: flex;
  flex-direction: column;
  gap: var(--gx-sp-16);
}

.trp-pkg-location {
  font-family: var(--gx-font-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gx-gray-mid);
  margin-bottom: var(--gx-sp-8);
}

.trp-pkg-title {
  font-family: var(--gx-font-heading);
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--gx-g500);
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin-bottom: var(--gx-sp-12);
}

/* Includes list */
.trp-pkg-includes {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.trp-pkg-includes li {
  display: flex;
  align-items: center;
  gap: var(--gx-sp-8);
  font-size: 0.8125rem;
  color: var(--gx-g200);
  line-height: 1.4;
}

.trp-pkg-includes li svg {
  flex-shrink: 0;
  color: var(--gx-lime-dark);
}

/* Card footer: price + CTA */
.trp-pkg-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gx-sp-16);
  padding-top: var(--gx-sp-16);
  border-top: 1px solid var(--gx-gray-light);
  margin-top: auto;
}

.trp-pkg-price {
  display: flex;
  align-items: baseline;
  gap: 0.3rem;
}

.trp-pkg-price__from {
  font-family: var(--gx-font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gx-gray-mid);
}

.trp-pkg-price__num {
  font-family: var(--gx-font-heading);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--gx-g500);
  letter-spacing: -0.04em;
  line-height: 1;
}

.trp-pkg-price__per {
  font-size: 0.75rem;
  color: var(--gx-gray-mid);
}

/* ============================================================
   7. RESPONSIVE
   ============================================================ */
@media (max-width: 1200px) {
  .trp-factors__grid { grid-template-columns: repeat(2, 1fr); }
  .trp-calc__inner { gap: var(--gx-sp-64); }
  .trp-pkg-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1024px) {
  .trp-hero__inner { grid-template-columns: 1fr; gap: var(--gx-sp-56); padding-block: var(--gx-sp-96); }
  .trp-hero__route { padding-left: 0; border-left: none; padding-top: var(--gx-sp-40); border-top: 1px solid rgba(255,255,255,0.07); }
  .trp-models__grid { grid-template-columns: repeat(2, 1fr); }
  .trp-calc__inner { grid-template-columns: 1fr; gap: var(--gx-sp-56); }
  .trp-route-item { grid-template-columns: 12rem 1fr 12rem; gap: var(--gx-sp-24); }
  .trp-packages__head { grid-template-columns: 1fr; gap: var(--gx-sp-32); }
}

@media (max-width: 768px) {
  .trp-hero__title { font-size: clamp(2.75rem, 9vw, 4rem); }
  .trp-hero__actions { flex-direction: column; align-items: flex-start; }
  .trp-models__grid { grid-template-columns: 1fr; }
  .trp-factors__grid { grid-template-columns: 1fr 1fr; }
  .trp-route-item { grid-template-columns: 1fr; gap: var(--gx-sp-12); padding-block: var(--gx-sp-20); }
  .trp-route-models { justify-content: flex-start; }
  .trp-pkg-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .trp-factors__grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .trp-hero__content,
  .trp-hero__route,
  .trp-hero__scroll::after,
  .trp-hero__connector-line,
  .trp-arc__fill,
  .trp-route-bar-fill { animation: none; transition: none; }

  .trp-arc__fill { stroke-dashoffset: var(--arc-end, 0); }
  .trp-route-bar-fill { transform: scaleX(1); }
}
