/* ============================================================
   Spring in Japan — Premium Redesign
   ============================================================ */

/* Elementor lazy-load fix handled via e-no-lazyload class injection */

/* Hero section */
.pjt-spring-hero {
  position: relative;
  overflow: hidden;
}
.pjt-spring-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(12,45,85,0.3) 0%, rgba(12,45,85,0.6) 100%);
  pointer-events: none;
}

.pjt-spring-hero-title .elementor-heading-title {
  font-family: "Domine", Georgia, serif !important;
  font-size: clamp(44px, 6vw, 64px) !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em !important;
  color: #fff !important;
  text-shadow: 0 2px 40px rgba(0,0,0,0.3);
}

.pjt-spring-hero-subtitle .elementor-heading-title {
  font-family: "Archivo", sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: #f3e1b2 !important;
}

.pjt-spring-hero-desc {
  max-width: 720px;
}
.pjt-spring-hero-desc .elementor-widget-container {
  font-family: "PT Sans", sans-serif !important;
  font-size: 18px !important;
  line-height: 1.8 !important;
  color: rgba(255,255,255,0.9) !important;
}

/* Primary button */
.pjt-spring-btn-primary .elementor-button {
  background: #d9aa43 !important;
  color: #0c2d55 !important;
  height: 52px !important;
  padding: 0 32px !important;
  border-radius: 999px !important;
  font-family: "Archivo", sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  line-height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid transparent !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.pjt-spring-btn-primary .elementor-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(217, 170, 67, 0.3);
}

/* Secondary button */
.pjt-spring-btn-secondary .elementor-button {
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  height: 52px !important;
  padding: 0 32px !important;
  border-radius: 999px !important;
  font-family: "Archivo", sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  line-height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(255,255,255,0.5) !important;
  transition: transform 0.2s ease, background 0.2s ease !important;
}
.pjt-spring-btn-secondary .elementor-button:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.2) !important;
}

/* Section titles */
.pjt-spring-section-title .elementor-heading-title {
  font-family: "Domine", Georgia, serif !important;
  font-size: clamp(32px, 4vw, 40px) !important;
  font-weight: 600 !important;
  color: #0c2d55 !important;
}

/* Timeline section */
.pjt-spring-timeline {
  background: #f8f5f2 !important;
}

.elementor-element.pjt-spring-timeline-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  width: 100% !important;
  flex-direction: unset !important;
  flex-wrap: unset !important;
}

.elementor-element.pjt-spring-timeline-grid > .e-con,
.elementor-element.pjt-spring-timeline-grid > [class*="elementor-element"] {
  flex: none !important;
  width: 100% !important;
  max-width: none !important;
}

@media (max-width: 1024px) {
  .elementor-element.pjt-spring-timeline-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 768px) {
  .elementor-element.pjt-spring-timeline-grid {
    grid-template-columns: 1fr !important;
  }
}

.pjt-spring-timeline-card {
  position: relative;
  transition: transform 0.3s ease;
}
.pjt-spring-timeline-card:hover {
  transform: translateY(-4px);
}

.pjt-spring-timeline-card.pjt-spring-highlight::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  border: 2px solid #d9aa43;
  pointer-events: none;
}

.pjt-spring-timeline-date .elementor-heading-title {
  font-family: "Archivo", sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}

.pjt-spring-timeline-loc .elementor-heading-title {
  font-family: "Domine", Georgia, serif !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  color: #0c2d55 !important;
  margin-top: 10px;
}

/* Destinations - override e-flex */
.elementor-element.pjt-spring-dest-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  width: 100% !important;
  flex-direction: unset !important;
  flex-wrap: unset !important;
}

.elementor-element.pjt-spring-dest-grid > .e-con,
.elementor-element.pjt-spring-dest-grid > [class*="elementor-element"] {
  flex: none !important;
  width: 100% !important;
  max-width: none !important;
}

@media (max-width: 1024px) {
  .elementor-element.pjt-spring-dest-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 768px) {
  .elementor-element.pjt-spring-dest-grid {
    grid-template-columns: 1fr !important;
  }
}

.pjt-spring-dest-card {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  transition: transform 0.3s ease;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.pjt-spring-dest-card:hover {
  transform: scale(1.02);
}

/* Ensure inner gradient container fills the card */
.pjt-spring-dest-card > .e-con {
  width: 100% !important;
  max-width: 100% !important;
  flex: 1 1 auto !important;
}

/* Why private car section */
.pjt-spring-why {
  background: #0c2d55 !important;
}

/* Tips section */
.pjt-spring-tips {
  background: #f8f5f2 !important;
}

/* CTA buttons */
.pjt-spring-cta .elementor-button {
  line-height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .pjt-spring-hero-buttons {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .pjt-spring-hero-title .elementor-heading-title {
    font-size: 36px !important;
  }
  
  .pjt-spring-timeline-grid,
  .pjt-spring-dest-grid {
    grid-template-columns: 1fr;
  }
}
