
/* ================================
   Root Variables (Light Theme)
================================= */
:root {
  /* Brand Colors */
  --gold-light: #f5d06f;
  --gold-mid: #e1af56;
  --gold-dark: #c37c2a;

  --blue-dark: #031e27;
  --blue-mid: #0b455f;
  --blue-main: #2b597e;
  --blue-light: #4772aa;
  --navbar-bg: rgba(255, 255, 255, 0.6);
  --navbar-blur: 10px;
  /* NEOM Hero Colors */
  --neom-primary: #1e3a8a;     /* Deep blue */
  --neom-accent: #d4af37;      /* Gold */
  --neom-secondary: #06b6d4;   /* Cyan */
  --neom-text: #fff;           /* White */
  --neom-subtext: #ddd;        /* Light gray */
  --neom-transition: all 0.3s ease;

  /* Theme Colors */
  --background-color: #ffffff;
  --text-color: #111111;
  --primary-color: var(--blue-main);
  --accent-color: var(--gold-mid);

  /* UI Elements */
  --card-bg: #f9f9f9;
  --border-color: #e0e0e0;
  --input-bg: #ffffff;
  --input-border: #cccccc;

  /* Footer */
  --footer-bg: var(--blue-dark);
  --footer-text: #ffffff;

  /* Typography */
  --font-main: 'Montserrat', sans-serif;

  /* Animation */
  --transition: 0.3s ease;
}

/* ================================
   Root Variables (Dark Theme)
================================= */
[data-theme="dark"] {
  --background-color: #031e27;
  --text-color: #ffffff;
  --primary-color: var(--gold-mid);
  --accent-color: var(--blue-light);

  --card-bg: #0f2a3c;
  --border-color: #25485d;
  --input-bg: #0f2a3c;
  --input-border: #335e76;

  --footer-bg: #010e16;
  --footer-text: #ffffff;
}
[data-theme="dark"] .section-about,
[data-theme="dark"] .section-programs,
[data-theme="dark"] .section-excursion,
[data-theme="dark"] .section-lrt {
  background-color: #0f2a3c;
}
[data-theme="light"] .section-lrt{
  background-color: #f8f8f8
}
[data-theme="dark"] .section-why,
[data-theme="dark"] .section-technology,
[data-theme="dark"] .section-graduation {
  background-color: #031e27;
}
[data-theme="dark"] .neom-hero-btn.button {
  --text-stroke-color: rgba(255, 255, 255, 0.8);
}
[data-theme="dark"] {
  --navbar-bg: rgba(3, 30, 39, 0.55);
}
[data-theme="dark"] .inquiry-btn {
  --text-stroke-color: rgba(255,255,255,0.85);
}


/* THEME-AWARE NAV BAR */


.navbar {
  background: var(--navbar-bg) !important;
  backdrop-filter: blur(var(--navbar-blur));
  -webkit-backdrop-filter: blur(var(--navbar-blur));
  border-bottom: 1px solid var(--border-color);
  transition: background-color .25s ease, box-shadow .25s ease, padding .25s ease;
}

/* Fix color var */
.navbar a { color: var(--text-color); }

/* Shrink-on-scroll look */
.navbar.scrolled {
  background: var(--card-bg) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
}

.navbar-toggler{
  background-color: #5bbeef7a!important;
}
/* Link styling + animated underline */
.navbar .nav-link {
  position: relative;
  font-weight: 600;
  letter-spacing: .2px;
  padding: .75rem 0.9rem;
  color: var(--text-color);
  transition: color .2s ease;
}
.navbar .nav-link:hover { color: var(--accent-color); }

.navbar .nav-link.active{
    color: #0088CC;
}

.navbar .nav-link::after {
  content: "";
  position: absolute;
  left: 0.9rem;
  right: 0.9rem;
  bottom: .35rem;
  height: 2px;
  background: var(--accent-color);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
  border-radius: 2px;
}
.navbar .nav-link:hover::after,
.navbar .nav-link.active::after {
  transform: scaleX(1);

}

/* Mobile menu: soft fade & stagger */
@media (max-width: 991.98px) {
  .navbar-collapse.collapse.show .nav-link {
    animation: navFade .3s ease forwards;
    opacity: 0;
  }
  .navbar-collapse.collapse.show .nav-item:nth-child(1) .nav-link { animation-delay: .05s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(2) .nav-link { animation-delay: .1s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(3) .nav-link { animation-delay: .15s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(4) .nav-link { animation-delay: .2s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(5) .nav-link { animation-delay: .25s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(6) .nav-link { animation-delay: .3s; }
  .navbar-collapse.collapse.show .nav-item:nth-child(7) .nav-link { animation-delay: .35s; }
  @keyframes navFade {
    to { opacity: 1; transform: none; }
    from { opacity: 0; transform: translateY(6px); }
  }
}


/* Inquiry Now Button - Same Style as Hero CTA */
.inquiry-btn {
  --border-right: 4px;
  --text-stroke-color: rgba(255,255,255,0.6);
  --animation-color: var(--neom-accent);
  --fs-size: 1rem;
  font-weight: bold;
  letter-spacing: 2px;
  text-decoration: none;
  font-size: var(--fs-size);
  font-family: var(--font-main);
  position: relative;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1px var(--text-stroke-color);
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  display: inline-block;
  line-height: 1.2;
}

.inquiry-btn .hover-text {
  position: absolute;
  box-sizing: border-box;
  color: var(--animation-color);
  width: 0%;
  inset: 0;
  border-right: var(--border-right) solid var(--animation-color);
  overflow: hidden;
  transition: 0.5s;
  -webkit-text-stroke: 1px var(--animation-color);
}

.inquiry-btn:hover .hover-text {
  width: 100%;
  filter: drop-shadow(0 0 15px var(--animation-color));
}



/* Scroll progress bar */
#scrollProgress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--neom-accent), var(--neom-secondary));
  z-index: 99999;
  transition: width .1s linear;
}

/* ================================
   Global Reset & Base Styling
================================= */
body {
  font-family: var(--font-main);
  background-color: var(--background-color);
  color: var(--text-color);
  scroll-behavior: smooth;
  transition: background-color var(--transition), color var(--transition);
}
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  color: var(--primary-color);
}

p {
  color: var(--text-color);
  line-height: 1.7;
}

a {
  color: var(--accent-color);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--primary-color);
}

/* ================================
   Section Layouts
================================= */
.section-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--primary-color);
}

.section-subtitle {
  font-size: 1.125rem;
  color: var(--text-color);
}


/* ================================
   Hero Section
================================= */
.neom-hero-section {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  font-family: 'Poppins', sans-serif;
  /* Background fallback gradient if no GIF provided */
  background: linear-gradient(145deg, var(--neom-primary), var(--neom-secondary));
  isolation: isolate; /* ensures overlays stack cleanly */
}
.neom-hero-section {
  background-size: cover;      /* fills area, cropping if needed */
  background-position: center; /* centers the GIF */
  background-repeat: no-repeat;/* prevents tiling */
}

/* === GIF Background Layer === */
.neom-hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}
/* Overlay for readability */
.neom-hero-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 80% at 50% 50%, rgba(0,0,0,0.15), rgba(0,0,0,0.45));
  z-index: 0;
}

/* Wave Overlay */
.neom-hero-wave-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 120px;
  background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.25));
  animation: neom-hero-wave 10s linear infinite;
  z-index: 2;
}

@keyframes neom-hero-wave {
  0% { transform: translateX(0); }
  50% { transform: translateX(-25%); }
  100% { transform: translateX(0); }
}

.neom-hero-container {
  position: relative;
  z-index: 2;
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
}

/* Glassmorphic Card */
.neom-hero-card {
  background: rgba(17, 25, 40, 0.35);
  border-radius: 16px;
  padding: 40px;
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.neom-hero-title {
  font-size: 3rem;
  font-weight: 700;
  color: var(--neom-text);
  margin-bottom: 20px;
}

.neom-hero-title span {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  animation: neom-hero-letter-fade 1s ease-out forwards;
}

@keyframes neom-hero-letter-fade {
  to { opacity: 1; transform: translateY(0); }
}

.neom-hero-subtitle {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--neom-subtext);
  margin-bottom: 30px;
  min-height: 1.5rem;
}

.neom-hero-btn {
  display: inline-block;
  padding: 14px 28px;
  font-size: 1.2rem;
  font-weight: 600;
  background: var(--neom-primary);
  color: var(--neom-text);
  border: 2px solid var(--neom-accent);
  border-radius: 8px;
  text-decoration: none;
  transition: var(--neom-transition);
}

.neom-hero-btn:hover {
  background: var(--neom-accent);
  color: var(--neom-primary);
  transform: scale(1.05);
}

/* Scroll Indicator */
.neom-hero-scroll {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.5rem;
  color: var(--neom-text);
  animation: neom-hero-bounce 2s infinite;
  cursor: pointer;
  z-index: 2;
}

@keyframes neom-hero-bounce {
  0%, 20%, 50%, 80%, 100% { transform: translate(-50%, 0); }
  40% { transform: translate(-50%, -10px); }
  60% { transform: translate(-50%, -5px); }
}

/* === Hide content if you want GIF only === */
.neom-hero-section.no-content .neom-hero-container,
.neom-hero-section.no-content .neom-hero-wave-overlay {
  display: none;
}
.neom-hero-section.no-content .neom-hero-scroll {
  opacity: 0.9;
}

/* Responsive */
@media (max-width: 768px) {
  .neom-hero-title {
    font-size: 1.5rem;
  }
  .neom-hero-subtitle {
    font-size: 0.8rem;
  }
  .neom-hero-btn {
    padding: 12px 24px;
    font-size: 0.5rem;
  }
  .neom-hero-card {
    padding: 20px;
  }
  .neom-hero-wave-overlay {
    height: 80px;
  }
}



/* ================================
   Shared Section Style
================================= */
section {
  padding: 80px 0;
}

.section-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--primary-color);
  margin-bottom: 20px;
  text-align: center;
}

.section-subtitle {
  font-size: 1.1rem;
  color: var(--text-color);
  text-align: center;
  margin-bottom: 40px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

/* ================================
   Section Background Alternation
================================= */
.section-about {
  background-color: #f9fafb;
}

.section-why {
  background-color: #ffffff;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
}

.section-programs {
  background-color: #f3f4f6;
}

.section-technology {
  background-color: #ffffff;
}

.section-excursion {
  background-color: #f9fafb;
  border-top: 1px solid #e5e7eb;
}

.section-graduation {
  background-color: #ffffff;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 -1px 8px rgba(0, 0, 0, 0.04);
}

/* ================================
   Why Us Cards
================================= */
.section-why .why-card {
  border: 1px solid var(--border-color);
  border-radius: 20px;
  background-color: var(--card-bg);
  transition: transform var(--transition), background-color var(--transition);
}

.section-why .why-card:hover {
  transform: translateY(-5px);
}

.section-why .icon {
  color: var(--accent-color);
}

/* ================================
   Programs (Grid + Description Cards)
================================= */
/* spacing var */
.section-programs { --g: clamp(1rem, 2vw, 1.5rem); }

/* mobile/tablet = auto grid */
.section-programs .programs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--g);
}

/* desktop = 4 per row, centered last line */
@media (min-width: 992px) {
  .section-programs .programs-grid {
    display: flex;            /* switch to flex */
    flex-wrap: wrap;
    gap: var(--g);
    justify-content: center;  /* centers incomplete row */
  }
  .section-programs .program-card {
    flex: 0 1 calc((100% - (3 * var(--g))) / 4); /* 4 per row */
    min-width: 260px;  /* keep cards from getting too skinny */
    max-width: 320px;  /* avoid huge cards on ultrawide */
  }
}

/* Card */
.section-programs .program-card {
  position: relative;
  background: var(--card-bg);
  border-radius: 18px;
  padding: 1.25rem 1.25rem 1.25rem 1.25rem;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
  outline: 1px solid color-mix(in oklab, var(--accent-color) 18%, transparent);
  transition: transform .2s ease, box-shadow .2s ease, outline-color .2s ease;
  /* subtle left accent bar using gradient so it scales nicely */
  --accent-w: 6px;
  background-image: linear-gradient(
    to right,
    color-mix(in oklab, var(--accent-color) 80%, transparent) var(--accent-w),
    transparent var(--accent-w)
  );
  background-size: 100% 100%;
  background-repeat: no-repeat;
}

.section-programs .program-card:hover,
.section-programs .program-card:focus-within {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
  outline-color: color-mix(in oklab, var(--accent-color) 40%, transparent);
}

/* Icon circle (optional) */
.section-programs .program-icon {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  font-size: 1.25rem;
  background: color-mix(in oklab, var(--accent-color) 18%, transparent);
  color: var(--primary-color);
  margin-bottom: .6rem;
}

/* Title + subtitle/desc */
.section-programs .program-title {
  color: var(--primary-color);
  font-weight: 700;
  font-size: clamp(1.05rem, 2.2vw, 1.2rem);
  line-height: 1.2;
  margin: .25rem 0 .5rem;
}

.section-programs .program-desc {
  color: var(--text-color, #555);
  font-size: .98rem;
  line-height: 1.55;
  margin: 0;
}

/* Tag row (optional) */
.section-programs .program-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: .9rem;
}

.section-programs .program-tag {
  font-size: .78rem;
  padding: .25rem .55rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--accent-color) 14%, transparent);
  color: var(--primary-color);
}

/* CTA (optional) */
.section-programs .program-cta {
  margin-top: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--primary-color);
  border-bottom: 2px solid color-mix(in oklab, var(--primary-color) 40%, transparent);
}
.section-programs .program-cta:hover { opacity: .9; }

/* AOS nicety on small screens */
@media (max-width: 576px) {
  [data-aos] { transition-duration: 600ms !important; }
}

/* ================================
   Technology Cards
================================= */
.section-technology .tech-card {
  border: 1px dashed var(--border-color);
  background-color: var(--card-bg);
  border-radius: 20px;
}

.section-technology .tech-title {
  color: var(--primary-color);
}

/* ================================
   Excursion & Graduation
================================= */
.section-excursion .excursion-image,
.section-graduation .graduation-image {
  border-radius: 20px!important;
  max-width: 100%;
  height: auto;
}


/* ================================
   Footer
================================= */
.footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  font-size: 0.875rem;
  transition: background-color var(--transition), color var(--transition);
}

.footer-socials a {
  font-size: 1.2rem;
  transition: color var(--transition);
}

.footer-socials a:hover {
  color: var(--accent-color);
}


/* ================================
   theme toggle
================================= */

.theme-switch {
  --toggle-size: 10px;
  /* the size is adjusted using font-size,
     this is not transform scale,
     so you can choose any size */
  --container-width: 5.625em;
  --container-height: 2.5em;
  --container-radius: 6.25em;
  /* radius 0 - minecraft mode :) */
  --container-light-bg: #3D7EAE;
  --container-night-bg: #1D1F2C;
  --circle-container-diameter: 3.375em;
  --sun-moon-diameter: 2.125em;
  --sun-bg: #ECCA2F;
  --moon-bg: #C4C9D1;
  --spot-color: #959DB1;
  --circle-container-offset: calc((var(--circle-container-diameter) - var(--container-height)) / 2 * -1);
  --stars-color: #fff;
  --clouds-color: #F3FDFF;
  --back-clouds-color: #AACADF;
  --transition: .5s cubic-bezier(0, -0.02, 0.4, 1.25);
  --circle-transition: .3s cubic-bezier(0, -0.02, 0.35, 1.17);
}

.theme-switch, .theme-switch *, .theme-switch *::before, .theme-switch *::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-size: var(--toggle-size);
}

.theme-switch__container {
  width: var(--container-width);
  height: var(--container-height);
  background-color: var(--container-light-bg);
  border-radius: var(--container-radius);
  overflow: hidden;
  cursor: pointer;
  -webkit-box-shadow: 0em -0.062em 0.062em rgba(0, 0, 0, 0.25), 0em 0.062em 0.125em rgba(255, 255, 255, 0.94);
  box-shadow: 0em -0.062em 0.062em rgba(0, 0, 0, 0.25), 0em 0.062em 0.125em rgba(255, 255, 255, 0.94);
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
  position: relative;
}

.theme-switch__container::before {
  content: "";
  position: absolute;
  z-index: 1;
  inset: 0;
  -webkit-box-shadow: 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset, 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset;
  box-shadow: 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset, 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset;
  border-radius: var(--container-radius)
}

.theme-switch__checkbox {
  display: none;
}

.theme-switch__circle-container {
  width: var(--circle-container-diameter);
  height: var(--circle-container-diameter);
  background-color: rgba(255, 255, 255, 0.1);
  position: absolute;
  left: var(--circle-container-offset);
  top: var(--circle-container-offset);
  border-radius: var(--container-radius);
  -webkit-box-shadow: inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), 0 0 0 0.625em rgba(255, 255, 255, 0.1), 0 0 0 1.25em rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), 0 0 0 0.625em rgba(255, 255, 255, 0.1), 0 0 0 1.25em rgba(255, 255, 255, 0.1);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: var(--circle-transition);
  -o-transition: var(--circle-transition);
  transition: var(--circle-transition);
  pointer-events: none;
}

.theme-switch__sun-moon-container {
  pointer-events: auto;
  position: relative;
  z-index: 2;
  width: var(--sun-moon-diameter);
  height: var(--sun-moon-diameter);
  margin: auto;
  border-radius: var(--container-radius);
  background-color: var(--sun-bg);
  -webkit-box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #a1872a inset;
  box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #a1872a inset;
  -webkit-filter: drop-shadow(0.062em 0.125em 0.125em rgba(0, 0, 0, 0.25)) drop-shadow(0em 0.062em 0.125em rgba(0, 0, 0, 0.25));
  filter: drop-shadow(0.062em 0.125em 0.125em rgba(0, 0, 0, 0.25)) drop-shadow(0em 0.062em 0.125em rgba(0, 0, 0, 0.25));
  overflow: hidden;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
}

.theme-switch__moon {
  -webkit-transform: translateX(100%);
  -ms-transform: translateX(100%);
  transform: translateX(100%);
  width: 100%;
  height: 100%;
  background-color: var(--moon-bg);
  border-radius: inherit;
  -webkit-box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
  position: relative;
}

.theme-switch__spot {
  position: absolute;
  top: 0.75em;
  left: 0.312em;
  width: 0.75em;
  height: 0.75em;
  border-radius: var(--container-radius);
  background-color: var(--spot-color);
  -webkit-box-shadow: 0em 0.0312em 0.062em rgba(0, 0, 0, 0.25) inset;
  box-shadow: 0em 0.0312em 0.062em rgba(0, 0, 0, 0.25) inset;
}

.theme-switch__spot:nth-of-type(2) {
  width: 0.375em;
  height: 0.375em;
  top: 0.937em;
  left: 1.375em;
}

.theme-switch__spot:nth-last-of-type(3) {
  width: 0.25em;
  height: 0.25em;
  top: 0.312em;
  left: 0.812em;
}

.theme-switch__clouds {
  width: 1.25em;
  height: 1.25em;
  background-color: var(--clouds-color);
  border-radius: var(--container-radius);
  position: absolute;
  bottom: -0.625em;
  left: 0.312em;
  -webkit-box-shadow: 0.937em 0.312em var(--clouds-color), -0.312em -0.312em var(--back-clouds-color), 1.437em 0.375em var(--clouds-color), 0.5em -0.125em var(--back-clouds-color), 2.187em 0 var(--clouds-color), 1.25em -0.062em var(--back-clouds-color), 2.937em 0.312em var(--clouds-color), 2em -0.312em var(--back-clouds-color), 3.625em -0.062em var(--clouds-color), 2.625em 0em var(--back-clouds-color), 4.5em -0.312em var(--clouds-color), 3.375em -0.437em var(--back-clouds-color), 4.625em -1.75em 0 0.437em var(--clouds-color), 4em -0.625em var(--back-clouds-color), 4.125em -2.125em 0 0.437em var(--back-clouds-color);
  box-shadow: 0.937em 0.312em var(--clouds-color), -0.312em -0.312em var(--back-clouds-color), 1.437em 0.375em var(--clouds-color), 0.5em -0.125em var(--back-clouds-color), 2.187em 0 var(--clouds-color), 1.25em -0.062em var(--back-clouds-color), 2.937em 0.312em var(--clouds-color), 2em -0.312em var(--back-clouds-color), 3.625em -0.062em var(--clouds-color), 2.625em 0em var(--back-clouds-color), 4.5em -0.312em var(--clouds-color), 3.375em -0.437em var(--back-clouds-color), 4.625em -1.75em 0 0.437em var(--clouds-color), 4em -0.625em var(--back-clouds-color), 4.125em -2.125em 0 0.437em var(--back-clouds-color);
  -webkit-transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
  -o-transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
  transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
}

.theme-switch__stars-container {
  position: absolute;
  color: var(--stars-color);
  top: -100%;
  left: 0.312em;
  width: 2.75em;
  height: auto;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
}

.theme-switch__checkbox:checked + .theme-switch__container {
  background-color: var(--container-night-bg);
}

.theme-switch__checkbox:checked + .theme-switch__container .theme-switch__circle-container {
  left: calc(100% - var(--circle-container-offset) - var(--circle-container-diameter));
}

.theme-switch__checkbox:checked + .theme-switch__container .theme-switch__circle-container:hover {
  left: calc(100% - var(--circle-container-offset) - var(--circle-container-diameter) - 0.187em)
}

.theme-switch__circle-container:hover {
  left: calc(var(--circle-container-offset) + 0.187em);
}

.theme-switch__checkbox:checked + .theme-switch__container .theme-switch__moon {
  -webkit-transform: translate(0);
  -ms-transform: translate(0);
  transform: translate(0);
}

.theme-switch__checkbox:checked + .theme-switch__container .theme-switch__clouds {
  bottom: -4.062em;
}

.theme-switch__checkbox:checked + .theme-switch__container .theme-switch__stars-container {
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

/* ===============================
   Toggle Placement and Visibility
================================== */

/* Desktop Toggle – Top Right Fixed */
.theme-switch-wrapper {
  z-index: 9999;
  margin-top: 7px;
}

/* On mobile: hide fixed toggle */
@media (max-width: 991.98px) {
  .theme-switch-wrapper {
    display: none !important;
  }
}

/* Inside navbar menu for mobile */
.navbar-nav .theme-switch {
  margin-left: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Optional: make it a bit smaller in mobile nav */
@media (max-width: 575.98px) {
  .navbar-nav .theme-switch {
    --toggle-size: 22px; /* make smaller */
    --container-width: 4.5em;
    --container-height: 2em;
    --circle-container-diameter: 2.8em;
    --sun-moon-diameter: 1.6em;
  }
}

/* ===============================
   Social media
================================== */
    /* Container for all tooltips */
    .social-media-container {
      display: flex;
      gap: 20px;
      justify-content: center;
      align-items: center;
      padding: 20px;
      background: var(--back-clouds-color);
      min-height: 20vh;
    }

     /* Base styles for all tooltips */
    .tooltip-container {
      position: relative;
      cursor: pointer;
      transition: all 0.2s;
      font-size: 17px;
      border-radius: 10px;
    }

    .tooltip-container .tooltip {
      position: absolute;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      padding: 10px;
      opacity: 0;
      pointer-events: none;
      transition: all 0.3s;
      border-radius: 15px;
      box-shadow: inset 5px 5px 5px rgba(0, 0, 0, 0.2),
        inset -5px -5px 15px rgba(255, 255, 255, 0.1),
        5px 5px 15px rgba(0, 0, 0, 0.3), -5px -5px 15px rgba(255, 255, 255, 0.1);
      z-index: 10;
    }

    .tooltip-container:hover .tooltip {
      top: -150px;
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
    }

    .tooltip-container .icon {
      text-decoration: none;
      color: #fff;
      display: block;
      position: relative;
    }

    .tooltip-container .icon .layer {
      width: 60px;
      height: 60px;
      border-radius: 15px;
      transition: transform 0.3s, box-shadow 0.3s ease;
    }

    .tooltip-container .icon:hover .layer {
      transform: rotate(-35deg) skew(20deg);
    }

    .tooltip-container .layer span {
      position: absolute;
      top: 0;
      left: 0;
      height: 100%;
      width: 100%;
      border-radius: 15px;
      transition: all 0.3s;
    }

    .tooltip-container .icon .text {
      position: absolute;
      left: 50%;
      bottom: -5px;
      opacity: 0;
      font-weight: 500;
      transform: translateX(-50%);
      transition: bottom 0.3s ease, opacity 0.3s ease;
    }

    .tooltip-container .icon:hover .text {
      bottom: -35px;
      opacity: 1;
    }

    .tooltip-container .icon:hover .layer span:nth-child(1) {
      opacity: 0.2;
    }

    .tooltip-container .icon:hover .layer span:nth-child(2) {
      opacity: 0.4;
      transform: translate(5px, -5px);
    }

    .tooltip-container .icon:hover .layer span:nth-child(3) {
      opacity: 0.6;
      transform: translate(10px, -10px);
    }

    .tooltip-container .icon:hover .layer span:nth-child(4) {
      opacity: 0.8;
      transform: translate(15px, -15px);
    }

    .tooltip-container .icon:hover .layer span:nth-child(5) {
      opacity: 1;
      transform: translate(20px, -20px);
    }

    .tooltip-container .user {
      display: flex;
      gap: 10px;
    }

    .tooltip-container .img {
      width: 50px;
      height: 50px;
      font-size: 25px;
      font-weight: 700;
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: #fff;
    }

    .tooltip-container .details {
      display: flex;
      flex-direction: column;
      gap: 0;
      color: #fff;
    }

    .tooltip-container .about {
      color: #ccc;
      padding-top: 5px;
    }

    .tooltip-container .svgIcon {
      transition: transform 0.3s ease;
    }

    .tooltip-container .icon:hover .svgIcon {
      transform: scale(1.1);
    }
/* Responsive */
  @media (max-width: 768px) {
    .social-media-container {
      gap: 15px;
      padding: 15px;
    }

    .tooltip-container .tooltip {
      width: 250px;
      top: -140px;
    }

    .tooltip-container .icon .layer {
      width: 50px;
      height: 50px;
    }

    .tooltip-container .svgIcon {
      height: 1.2em;
    }

    .tooltip-container .img {
      width: 40px;
      height: 40px;
      font-size: 20px;
    }

    .tooltip-container .name {
      font-size: 15px;
    }

    .tooltip-container .username,
    .tooltip-container .about {
      font-size: 13px;
    }
  }
    /* Facebook Specific Styles */
    .tooltip-container.fb .tooltip {
      background: #3b5998;
      border: 1px solid #29487d;
    }

    .tooltip-container.fb .icon .layer {
      border: 2px solid #1877f2;
      box-shadow: 0 0 15px rgba(24, 119, 242, 0.7), 0 0 20px rgba(24, 119, 242, 0.5);
    }

    .tooltip-container.fb .icon:hover .layer {
      box-shadow: 0 0 30px rgba(24, 119, 242, 1), 0 0 40px rgba(24, 119, 242, 0.7);
    }

    .tooltip-container.fb .layer span,
    .tooltip-container.fb .text {
      color: #1877f2;
      border-color: #1877f2;
    }

    .tooltip-container.fb .icon:hover .layer span {
      box-shadow: -1px 1px 3px #1877f2;
    }

    .tooltip-container.fb .fbSVG {
      font-size: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(
        45deg,
        #1877f2 0%,
        #3b5998 25%,
        #1877f2 50%,
        #3b5998 75%,
        #1877f2 100%
      );
      border-radius: 15px;
    }

    .tooltip-container.fb .img {
      border: 1px solid #1877f2;
    }

    .tooltip-container.fb .name {
      font-size: 17px;
      font-weight: 700;
      color: #1877f2;
    }

    /* WhatsApp Specific Styles */
    .tooltip-container.whatsapp .tooltip {
      background: #25D366;
      border: 1px solid #128C7E;
    }

    .tooltip-container.whatsapp .icon .layer {
      border: 2px solid #25D366;
      box-shadow: 0 0 15px rgba(37, 211, 102, 0.7), 0 0 20px rgba(37, 211, 102, 0.5);
    }

    .tooltip-container.whatsapp .icon:hover .layer {
      box-shadow: 0 0 30px rgba(37, 211, 102, 1), 0 0 40px rgba(37, 211, 102, 0.7);
    }

    .tooltip-container.whatsapp .layer span,
    .tooltip-container.whatsapp .text {
      color: #25D366;
      border-color: #25D366;
    }

    .tooltip-container.whatsapp .icon:hover .layer span {
      box-shadow: -1px 1px 3px #25D366;
    }

    .tooltip-container.whatsapp .whatsappSVG {
      font-size: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(
        45deg,
        #25D366 0%,
        #128C7E 25%,
        #25D366 50%,
        #128C7E 75%,
        #25D366 100%
      );
      border-radius: 15px;
    }

    .tooltip-container.whatsapp .img {
      border: 1px solid #25D366;
    }

    .tooltip-container.whatsapp .name {
      font-size: 17px;
      font-weight: 700;
      color: #25D366;
    }

    /* Instagram Specific Styles */
    .tooltip-container.instagram .tooltip {
      background: #E4405F;
      border: 1px solid #C13584;
    }

    .tooltip-container.instagram .icon .layer {
      border: 2px solid #E4405F;
      box-shadow: 0 0 15px rgba(228, 64, 95, 0.7), 0 0 20px rgba(228, 64, 95, 0.5);
    }

    .tooltip-container.instagram .icon:hover .layer {
      box-shadow: 0 0 30px rgba(228, 64, 95, 1), 0 0 40px rgba(228, 64, 95, 0.7);
    }

    .tooltip-container.instagram .layer span,
    .tooltip-container.instagram .text {
      color: #E4405F;
      border-color: #E4405F;
    }

    .tooltip-container.instagram .icon:hover .layer span {
      box-shadow: -1px 1px 3px #E4405F;
    }

    .tooltip-container.instagram .instagramSVG {
      font-size: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(
        45deg,
        #f09433 0%,
        #e6683c 25%,
        #dc2743 50%,
        #cc2366 75%,
        #bc1888 100%
      );
      border-radius: 15px;
    }

    .tooltip-container.instagram .img {
      border: 1px solid #E4405F;
    }

    .tooltip-container.instagram .name {
      font-size: 17px;
      font-weight: 700;
      color: #E4405F;
    }

    /* Twitter Specific Styles */
    .tooltip-container.twitter .tooltip {
      background: #1DA1F2;
      border: 1px solid #1A91DA;
    }

    .tooltip-container.twitter .icon .layer {
      border: 2px solid #1DA1F2;
      box-shadow: 0 0 15px rgba(29, 161, 242, 0.7), 0 0 20px rgba(29, 161, 242, 0.5);
    }

    .tooltip-container.twitter .icon:hover .layer {
      box-shadow: 0 0 30px rgba(29, 161, 242, 1), 0 0 40px rgba(29, 161, 242, 0.7);
    }

    .tooltip-container.twitter .layer span,
    .tooltip-container.twitter .text {
      color: #1DA1F2;
      border-color: #1DA1F2;
    }

    .tooltip-container.twitter .icon:hover .layer span {
      box-shadow: -1px 1px 3px #1DA1F2;
    }

    .tooltip-container.twitter .twitterSVG {
      font-size: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(
        45deg,
        #1DA1F2 0%,
        #1A91DA 25%,
        #1DA1F2 50%,
        #1A91DA 75%,
        #1DA1F2 100%
      );
      border-radius: 15px;
    }

    .tooltip-container.twitter .img {
      border: 1px solid #1DA1F2;
    }

    .tooltip-container.twitter .name {
      font-size: 17px;
      font-weight: 700;
      color: #1DA1F2;
    }
  /* TikTok Specific Styles */
  .tooltip-container.tiktok .tooltip {
    background: #000000;
    border: 1px solid #333333;
  }

  .tooltip-container.tiktok .icon .layer {
    border: 2px solid #000000;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.7), 0 0 20px rgba(0, 0, 0, 0.5);
  }

  .tooltip-container.tiktok .icon:hover .layer,
  .tooltip-container.tiktok .icon:focus .layer {
    box-shadow: 0 0 30px rgba(0, 0, 0, 1), 0 0 40px rgba(0, 0, 0, 0.7);
  }

  .tooltip-container.tiktok .layer span,
  .tooltip-container.tiktok .text {
    color: #000000;
    border-color: #000000;
  }

  .tooltip-container.tiktok .icon:hover .layer span,
  .tooltip-container.tiktok .icon:focus .layer span {
    box-shadow: -1px 1px 3px #000000;
  }

  .tooltip-container.tiktok .tiktokSVG {
    font-size: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
      45deg,
      #000000 0%,
      #333333 25%,
      #000000 50%,
      #333333 75%,
      #000000 100%
    );
    border-radius: 15px;
  }

  .tooltip-container.tiktok .img {
    border: 1px solid #000000;
  }

  .tooltip-container.tiktok .name {
    font-size: 17px;
    font-weight: 700;
    color: #000000;
  }
  /* Telegram Specific Styles */
  .tooltip-container.telegram .tooltip {
    background: #0088CC;
    border: 1px solid #006699;
  }

  .tooltip-container.telegram .icon .layer {
    border: 2px solid #0088CC;
    box-shadow: 0 0 15px rgba(0, 136, 204, 0.7), 0 0 20px rgba(0, 136, 204, 0.5);
  }

  .tooltip-container.telegram .icon:hover .layer,
  .tooltip-container.telegram .icon:focus .layer {
    box-shadow: 0 0 30px rgba(0, 136, 204, 1), 0 0 40px rgba(0, 136, 204, 0.7);
  }

  .tooltip-container.telegram .layer span,
  .tooltip-container.telegram .text {
    color: #0088CC;
    border-color: #0088CC;
  }

  .tooltip-container.telegram .icon:hover .layer span,
  .tooltip-container.telegram .icon:focus .layer span {
    box-shadow: -1px 1px 3px #0088CC;
  }

  .tooltip-container.telegram .telegramSVG {
    font-size: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
      45deg,
      #0088CC 0%,
      #006699 25%,
      #0088CC 50%,
      #006699 75%,
      #0088CC 100%
    );
    border-radius: 15px;
  }

  .tooltip-container.telegram .img {
    border: 1px solid #0088CC;
  }

  .tooltip-container.telegram .name {
    font-size: 17px;
    font-weight: 700;
    color: #0088CC;
  }
.tooltip-container.wechat .tooltip {
    background: #00c70a;
    border: 1px solid #009107;
  }

  .tooltip-container.wechat .icon .layer {
    border: 2px solid #00c70a;
    box-shadow: 0 0 15px rgba(0, 199, 10, 0.7), 0 0 20px rgba(0, 199, 10, 0.5);
  }

  .tooltip-container.wechat .icon:hover .layer,
  .tooltip-container.wechat .icon:focus .layer {
    box-shadow: 0 0 30px rgba(0, 199, 10, 1), 0 0 40px rgba(0, 199, 10, 0.7);
  }

  .tooltip-container.wechat .layer span,
  .tooltip-container.wechat .text {
    color: #00c70a;
    border-color: #00c70a;
  }

  .tooltip-container.wechat .icon:hover .layer span,
  .tooltip-container.wechat .icon:focus .layer span {
    box-shadow: -1px 1px 3px #00c70a;
  }

  .tooltip-container.wechat .wechatSVG {
    font-size: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
      45deg,
      #00c70a 0%,
      #009107 25%,
      #00c70a 50%,
      #009107 75%,
      #00c70a 100%
    );
    border-radius: 15px;
  }

  .tooltip-container.wechat .img {
    border: 1px solid #009107;
  }

  .tooltip-container.wechat .name {
    font-size: 17px;
    font-weight: 700;
    color: #00c70a;
  }
    .footer .copyright .copyright-content p{
	color:#F3FDFF;
    font-family: 'Times New Roman', Times, serif;
    font-size: small;
}
.copyright{
    display: flex;
    justify-content: center;
}


/* ===============================
   Loader
================================== */

.loader-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.9); /* Light overlay */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}
 
.loader {
  --background: linear-gradient(135deg, #23C4F8, #275EFE);
  --shadow: rgba(39, 94, 254, 0.28);
  --text: #6C7486;
  --page: rgba(255, 255, 255, 0.36);
  --page-fold: rgba(255, 255, 255, 0.52);
  --duration: 3s;
  width: 200px;
  height: 140px;
  position: relative;
}

.loader:before, .loader:after {
  --r: -6deg;
  content: "";
  position: absolute;
  bottom: 8px;
  width: 120px;
  top: 80%;
  box-shadow: 0 16px 12px var(--shadow);
  transform: rotate(var(--r));
}

.loader:before {
  left: 4px;
}

.loader:after {
  --r: 6deg;
  right: 4px;
}

.loader div {
  width: 100%;
  height: 100%;
  border-radius: 13px;
  position: relative;
  z-index: 1;
  perspective: 600px;
  box-shadow: 0 4px 6px var(--shadow);
  background-image: var(--background);
}

.loader div ul {
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
}

.loader div ul li {
  --r: 180deg;
  --o: 0;
  --c: var(--page);
  position: absolute;
  top: 10px;
  left: 10px;
  transform-origin: 100% 50%;
  color: var(--c);
  opacity: var(--o);
  transform: rotateY(var(--r));
  -webkit-animation: var(--duration) ease infinite;
  animation: var(--duration) ease infinite;
}

.loader div ul li:nth-child(2) {
  --c: var(--page-fold);
  -webkit-animation-name: page-2;
  animation-name: page-2;
}

.loader div ul li:nth-child(3) {
  --c: var(--page-fold);
  -webkit-animation-name: page-3;
  animation-name: page-3;
}

.loader div ul li:nth-child(4) {
  --c: var(--page-fold);
  -webkit-animation-name: page-4;
  animation-name: page-4;
}

.loader div ul li:nth-child(5) {
  --c: var(--page-fold);
  -webkit-animation-name: page-5;
  animation-name: page-5;
}

.loader div ul li svg {
  width: 90px;
  height: 120px;
  display: block;
}

.loader div ul li:first-child {
  --r: 0deg;
  --o: 1;
}

.loader div ul li:last-child {
  --o: 1;
}

.loader span {
  display: block;
  left: 0;
  right: 0;
  top: 100%;
  margin-top: 20px;
  text-align: center;
  color: var(--text);
}

@keyframes page-2 {
  0% {
    transform: rotateY(180deg);
    opacity: 0;
  }

  20% {
    opacity: 1;
  }

  35%, 100% {
    opacity: 0;
  }

  50%, 100% {
    transform: rotateY(0deg);
  }
}

@keyframes page-3 {
  15% {
    transform: rotateY(180deg);
    opacity: 0;
  }

  35% {
    opacity: 1;
  }

  50%, 100% {
    opacity: 0;
  }

  65%, 100% {
    transform: rotateY(0deg);
  }
}

@keyframes page-4 {
  30% {
    transform: rotateY(180deg);
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  65%, 100% {
    opacity: 0;
  }

  80%, 100% {
    transform: rotateY(0deg);
  }
}

@keyframes page-5 {
  45% {
    transform: rotateY(180deg);
    opacity: 0;
  }

  65% {
    opacity: 1;
  }

  80%, 100% {
    opacity: 0;
  }

  95%, 100% {
    transform: rotateY(0deg);
  }
}


/* Force landscape ratio feel */
@media (max-width: 768px) {
  .neom-hero-section {
    aspect-ratio: 16 / 9;          /* lock to landscape proportion */
    height: auto;                  /* let aspect-ratio define height */
    max-width: 100vh;             /* still fill viewport height */
    background-size: cover;        /* keep GIF stretched to fill */
    background-position: center center;
    
    margin-top: 75px; /* adjust to your navbar height */
  }
}

/* ===============================
   Back to Top Button
================================== */

.button-top {
  position: fixed;
  right: 20px;
  bottom: 30px;
  z-index: 999;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: var(--primary-color);
  border: none;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0px 0px 0px 4px rgba(180, 160, 255, 0.253);
  cursor: pointer;
  transition: all 0.3s ease;
  overflow: hidden;
  color: var(--text-color);
}

.svgIcon-top {
  width: 12px;
  transition: 0.3s ease;
}

.svgIcon-top path {
  fill: currentColor;
}

.button-top:hover {
  width: 140px;
  border-radius: 50px;
  background-color: var(--accent-color);
}

.button-top:hover .svgIcon-top {
  transform: translateY(-200%);
}

.button-top::before {
  position: absolute;
  bottom: -20px;
  content: "Back to Top";
  color: var(--text-color);
  font-size: 0;
}

.button-top:hover::before {
  font-size: 13px;
  bottom: unset;
  transition: 0.3s ease;
}


/* Contact Section */
.contact-section {
  background: var(--background-color);
  padding: 80px 20px;
  font-family: var(--font-main);
  color: var(--text-color);
}

.container-contact {
  max-width: 1200px;
  margin: auto;
  display: flex;
  flex-direction: column;
  gap: 60px;
}

.contact-header {
  text-align: center;
}

.section-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--primary-color);
  margin-bottom: 10px;
}

.section-subtitle {
  font-size: 1.2rem;
  min-height: 1.2rem;
}

/* Grid */
.contact-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

/* Info Box */
.contact-info {
  flex: 1;
  min-width: 280px;
  background: var(--card-bg);
  border-radius: 12px;
  padding: 30px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
  border: 2px solid var(--accent-color);
}

.info-title {
  font-size: 1.5rem;
  margin-bottom: 20px;
  color: var(--primary-color);
  font-weight: 600;
}

.info-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.info-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1rem;
}

.info-list i {
  color: var(--accent-color);
  font-size: 1.2rem;
}

.info-list a {
  color: var(--text-color);
  text-decoration: none;
}

.info-list a:hover {
  color: var(--accent-color);
}

/* Contact Form */
.contact-form-container {
  flex: 2;
  min-width: 300px;
  background: var(--card-bg);
  padding: 30px;
  border-radius: 12px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
  border: 2px solid var(--accent-color);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.input-group {
  position: relative;
}

.input,
.input-textarea {
  width: 100%;
  padding: 14px;
  font-size: 1rem;
  background: var(--input-bg);
  border: 1.5px solid var(--border-color);
  border-radius: 20px;
  border-top-right-radius: 20px!important;
  border-bottom-right-radius: 20px!important;
  font-family: var(--font-main);
  color: var(--text-color);
  transition: border var(--transition);
}

.input-textarea {
  resize: vertical;
  height: 130px;
}

.input:focus,
.input-textarea:focus {
  border-color: var(--accent-color);
  outline: none;
}

.user-label {
  position: absolute;
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  font-size: 1rem;
  color: #777;
  pointer-events: none;
  background: var(--input-bg);
  padding: 0 4px;
  transition: all var(--transition);
}

.input:focus + .user-label,
.input:valid + .user-label,
.input-textarea:focus + .user-label,
.input-textarea:valid + .user-label {
  top: -8px;
  left: 10px;
  font-size: 0.8rem;
  color: var(--accent-color);
}

/* Button */
.form-button {
  padding: 14px 24px;
  background: var(--primary-color);
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--transition);
}

.form-button:hover {
  background: var(--accent-color);
  color: var(--text-color);
}

.form-success {
  display: none;
  text-align: center;
  background: #10b981;
  color: #fff;
  padding: 12px;
  border-radius: 8px;
  font-size: 0.95rem;
}

.form-success.active {
  display: block;
}

/* Map */
.contact-map {
  border-radius: 20px;
  overflow: hidden;
  border: 1.5px solid var(--accent-color);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.08);
}

.contact-map iframe {
  width: 100%;
  height: 300px;
  border: none;
}

.map-controls {
  display: flex;
  justify-content: flex-end;
  padding: 10px;
  gap: 10px;
  background: var(--card-bg);
}

.map-toggle,
.map-link {
  padding: 8px 14px;
  font-size: 0.9rem;
  background: var(--primary-color);
  color: #fff;
  border: none;
  border-radius: 6px;
  text-decoration: none;
  transition: background var(--transition);
}

.map-toggle:hover,
.map-link:hover {
  background: var(--accent-color);
  color: var(--text-color);
}

/* Responsive */
@media (max-width: 991px) {
  .contact-grid {
    flex-direction: column;
  }

  .form-button {
    width: 100%;
  }

  .section-title {
    font-size: 2rem;
  }
}

/* NEOM Hero Animated Button */
.neom-hero-btn.button {
  margin: 0;
  height: auto;
  background: transparent;
  padding: 0;
  border: none;
  cursor: pointer;

  --border-right: 6px;
  --text-stroke-color: rgba(255, 255, 255, 0.6);
  --animation-color: var(--neom-accent); /* Gold color from theme */
  --fs-size: 1.4rem;
  letter-spacing: 3px;
  text-decoration: none;
  font-family: var(--font-main);
  position: relative;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1px var(--text-stroke-color);
}

.neom-hero-btn .hover-text {
  position: absolute;
  box-sizing: border-box;
  color: var(--animation-color);
  width: 0%;
  inset: 0;
  border-right: var(--border-right) solid var(--animation-color);
  overflow: hidden;
  transition: 0.5s;
  -webkit-text-stroke: 1px var(--animation-color);
}

.neom-hero-btn.button:hover .hover-text {
  width: 100%;
  filter: drop-shadow(0 0 23px var(--animation-color));
}


/* Are digee */

/* ================================
   NEOM Etymology Section
================================= */
.section-etymology {
  padding: 80px 0;
  background-color: var(--background-color);
}
.section-etymology .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 22px;
}
.section-etymology .section-head {
  text-align: center;
  margin-bottom: 36px;
}
.section-etymology .section-title {
  color: var(--primary-color);
}
.section-etymology .section-subtitle {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

/* Grid */
.etymology-grid {
  --g: clamp(1rem, 2.5vw, 1.5rem);
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: var(--g);
}
@media (max-width: 1024px) {
  .etymology-grid { grid-template-columns: repeat(2, minmax(220px, 1fr)); }
}
@media (max-width: 576px) {
  .etymology-grid { grid-template-columns: 1fr; }
}

/* Cards */
.etymology-card {
  position: relative;
  display: grid;
  grid-template-columns: 88px 1fr;
  align-items: start;
  gap: 18px;
  padding: 22px;
  border-radius: 18px;
  background: var(--card-bg);
  outline: 1px solid color-mix(in oklab, var(--accent-color) 18%, transparent);
  box-shadow: 0 6px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, outline-color .2s ease, background-color .2s ease;
}
.etymology-card:hover,
.etymology-card:focus-within {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
  outline-color: color-mix(in oklab, var(--accent-color) 40%, transparent);
}

/* Left letter block */
.etymology-letter {
  width: 88px;
  height: 88px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-size: 2.2rem;
  font-weight: 800;
  letter-spacing: .5px;
  color: var(--primary-color);
  background:
    linear-gradient(135deg,
      color-mix(in oklab, var(--accent-color) 18%, transparent),
      color-mix(in oklab, var(--accent-color) 10%, transparent));
  border: 1px solid color-mix(in oklab, var(--accent-color) 30%, transparent);
}

/* Right content */
.etymology-body {
  display: grid;
  gap: 6px;
}
.etymology-term {
  margin: 0;
  font-size: clamp(1.05rem, 2.2vw, 1.25rem);
  color: var(--primary-color);
  font-weight: 800;
  line-height: 1.2;
}
.etymology-lang {
  margin-left: .5ch;
  font-size: .85rem;
  font-weight: 700;
  color: color-mix(in oklab, var(--primary-color) 80%, #6b7280);
  background: color-mix(in oklab, var(--accent-color) 12%, transparent);
  padding: .18rem .5rem;
  border-radius: 999px;
  vertical-align: middle;
}
.etymology-romanization {
  margin: 0;
  font-size: .98rem;
  color: var(--text-color);
  opacity: .9;
  font-style: italic;
}
.etymology-meaning {
  margin: 0;
  font-weight: 700;
  color: var(--primary-color);
}
.etymology-note {
  margin: 2px 0 0 0;
  color: var(--text-color);
  opacity: .9;
}

/* CTA */
.etymology-cta {
  margin-top: 28px;
  display: flex;
  justify-content: center;
}
.etymology-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.4rem;
  font-weight: 700;
  border-radius: 10px;
  text-decoration: none;
  border: 2px solid var(--accent-color);
  color: var(--text-color);
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--accent-color) 20%, transparent),
    color-mix(in oklab, var(--accent-color) 8%, transparent)
  );
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.etymology-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
  background: color-mix(in oklab, var(--accent-color) 24%, transparent);
}

/* Dark theme subtle tweaks */
[data-theme="dark"] .etymology-letter {
  color: var(--primary-color);
  background:
    linear-gradient(135deg,
      color-mix(in oklab, var(--accent-color) 22%, transparent),
      color-mix(in oklab, var(--accent-color) 12%, transparent));
}
