/* ========================================
   SaudiWing Aviation - Main Stylesheet
   Colors: Navy (#0a0e1a) + Gold (#d4a853)
   ======================================== */

/* --- Reset & Base --- */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: "Inter", sans-serif;
  overflow-x: hidden;
  background: #0a0e1a;
  color: #e2e8f0;
}

/* Arabic font override */
[lang="ar"] body,
[dir="rtl"] body {
  font-family: "Noto Kufi Arabic", "Inter", sans-serif;
}

/* --- Custom Cursor (desktop only) --- */
.cursor-dot {
  width: 8px;
  height: 8px;
  background: #d4a853;
  border-radius: 50%;
  position: fixed;
  pointer-events: none;
  z-index: 9999;
  transition: transform 0.12s ease;
}

.cursor-ring {
  width: 40px;
  height: 40px;
  border: 1.5px solid rgba(212, 168, 83, 0.4);
  border-radius: 50%;
  position: fixed;
  pointer-events: none;
  z-index: 9998;
  transition:
    width 0.3s,
    height 0.3s,
    transform 0.06s ease;
}

.cursor-ring.hovering {
  width: 60px;
  height: 60px;
  border-color: rgba(212, 168, 83, 0.7);
}

@media (max-width: 768px) {
  .cursor-dot,
  .cursor-ring {
    display: none;
  }
}

/* --- Loader --- */
#loader {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: #0a0e1a;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transition:
    opacity 0.8s cubic-bezier(0.77, 0, 0.175, 1),
    visibility 0.8s;
}

#loader.done {
  opacity: 0;
  visibility: hidden;
}

.loader-line {
  width: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, #d4a853, transparent);
  transition: width 1.8s cubic-bezier(0.77, 0, 0.175, 1);
}

.loader-line.go {
  width: 200px;
}

.loader-counter {
  color: #d4a853;
  font-size: 72px;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.04em;
  font-family: "Inter", sans-serif;
}

/* --- Scroll Progress --- */
#scrollProgress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  background: linear-gradient(90deg, #d4a853, #b8862a);
  z-index: 10001;
  width: 0;
}

[dir="rtl"] #scrollProgress {
  left: auto;
  right: 0;
}

/* --- Scroll Reveal Animations --- */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-30px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

[dir="rtl"] .reveal-left {
  transform: translateX(30px);
}

.reveal-left.active {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(30px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

[dir="rtl"] .reveal-right {
  transform: translateX(-30px);
}

.reveal-right.active {
  opacity: 1;
  transform: translateX(0);
}

/* --- Stagger Children --- */
.stagger > * {
  opacity: 0;
  transform: translateY(25px);
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.stagger.active > *:nth-child(1) {
  transition-delay: 0.05s;
}
.stagger.active > *:nth-child(2) {
  transition-delay: 0.12s;
}
.stagger.active > *:nth-child(3) {
  transition-delay: 0.19s;
}
.stagger.active > *:nth-child(4) {
  transition-delay: 0.26s;
}
.stagger.active > *:nth-child(5) {
  transition-delay: 0.33s;
}
.stagger.active > *:nth-child(6) {
  transition-delay: 0.4s;
}

.stagger.active > * {
  opacity: 1;
  transform: translateY(0);
}

/* --- Hero Text Reveal --- */
.line-reveal {
  overflow: hidden;
}

.line-reveal span {
  display: inline-block;
  transform: translateY(115%);
  transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.line-reveal.active span {
  transform: translateY(0);
}

/* --- Marquee --- */
.marquee-track {
  display: flex;
  animation: marquee 28s linear infinite;
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

[dir="rtl"] .marquee-track {
  animation-name: marquee-rtl;
}

@keyframes marquee-rtl {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(50%);
  }
}

/* --- Float Animation --- */
@keyframes float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

/* --- Tilt Card --- */
.tilt-card {
  transition:
    transform 0.5s cubic-bezier(0.33, 1, 0.68, 1),
    box-shadow 0.5s ease;
  transform-style: preserve-3d;
}

.tilt-card:hover {
  box-shadow: 0 25px 50px -15px rgba(212, 168, 83, 0.1);
}

/* --- Magnetic Button --- */
.magnetic-btn {
  transition: transform 0.3s cubic-bezier(0.33, 1, 0.68, 1);
}

/* --- Section Backgrounds --- */
.section-dark {
  background: #0a0e1a;
}

.section-light {
  background: #0f1628;
}

.section-lighter {
  background: #141d35;
}

/* --- Divider --- */
.divider {
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(212, 168, 83, 0.15) 50%,
    transparent
  );
}

/* --- Gold Glow --- */
.gold-glow {
  box-shadow: 0 0 30px rgba(212, 168, 83, 0.12);
}

/* --- Input Underline Effect --- */
.input-line {
  position: relative;
}

.input-line::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: #d4a853;
  transition: width 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

[dir="rtl"] .input-line::after {
  left: auto;
  right: 0;
}

.input-line:focus-within::after {
  width: 100%;
}

/* --- Count Up Numbers --- */
.count-up {
  font-variant-numeric: tabular-nums;
  font-family: "Inter", sans-serif;
}

/* --- Slider --- */
.slider-container {
  position: relative;
  overflow: hidden;
}

.slider-track {
  display: flex;
  transition: transform 0.5s cubic-bezier(0.33, 1, 0.68, 1);
}

.slider-slide {
  flex: 0 0 100%;
  min-width: 0;
}

@media (min-width: 768px) {
  .slider-slide {
    flex: 0 0 33.333%;
  }
}

.slider-btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(212, 168, 83, 0.3);
  background: rgba(10, 14, 26, 0.8);
  color: #d4a853;
  cursor: pointer;
  transition: all 0.3s ease;
}

.slider-btn:hover {
  background: rgba(212, 168, 83, 0.1);
  border-color: #d4a853;
}

.slider-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 32px;
}

.slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(212, 168, 83, 0.2);
  cursor: pointer;
  transition: all 0.3s ease;
}

.slider-dot.active {
  background: #d4a853;
  width: 24px;
  border-radius: 4px;
}

/* --- Noise Overlay --- */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9990;
  opacity: 0.02;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* --- Responsive Utilities --- */
@media (max-width: 640px) {
  .hero-title {
    font-size: 2.25rem;
    line-height: 1.1;
  }
}

@media (min-width: 641px) and (max-width: 1023px) {
  .hero-title {
    font-size: 3.5rem;
  }
}

@media (min-width: 1024px) {
  .hero-title {
    font-size: 5rem;
  }
}
