/*
 * Newgen Core Stylesheet
 * Shared layout, navigation, and preloader styling for the rebuilt pages.
 * NOTE: Keep hero background behavior centralizedâ€”reuse the shared stacks
 * (e.g., newgen-works.css) instead of re-implementing per page.
 */

:root {
  --header-height: 112px;
  --color-accent: #00d4ff;
  --color-pink: #ff69b4;

  /* Navigation timing + accent placement */
  /* Nav animation timing (delayed + slower per request) */
  --nav-bg-fade: 3000ms;      /* was 1200ms; now 2.5x longer */
  --nav-bg-delay: 1350ms;     /* was 100ms; now +1.25s start delay */
  --nav-accent-fade: 3500ms;  /* was 1400ms; now 2.5x longer */
  --nav-accent-delay: 2150ms; /* was 900ms; now +1.25s start delay */
  --nav-switch-gap: 500ms;
  --nav-accent-color: var(--color-accent);
  --nav-accent-width: 2px;
  --nav-blur: 0px;
  --nav-saturation: 100%;

  /* Hero defaults that individual pages can override */
  --hero-bg-opacity: 0;
  --hero-bg-scale: 1.1;
  --hero-bg-scale-final: 1.1;
  --hero-bg-blur: 8px;
  --hero-bg-drop-vh: 2.2;
  --hero-bg-drop-initial: 0svh;
  /* Original spotlight positioning */
  --spotlight-y: 0px;
  --hero-bg-drop-final: calc(var(--hero-bg-drop-vh) * 1svh);
  /* Absolute final drop in px (overrides above if set on body) */
  --hero-bg-drop-final-abs: var(--hero-bg-drop-final);
  --hero-bg-drop: var(--hero-bg-drop-initial);
  --hero-bg-drop-cover: max(var(--hero-bg-drop-initial), var(--hero-bg-drop-final));
  --hero-bg-bleed: max(4svh, calc(var(--hero-bg-drop-cover) + var(--hero-bg-blur) + 8px));
  --hero-bg-image: none;
  /* Hero layout knobs */
  --hero-top-trim-px: 0px;            /* subtract from top padding */
  --hero-top-extra-svh: 4svh;         /* extra space above hero beyond header */
  --hero-min-height-svh: 56;          /* min-height in svh units */
  --hero-bg-position: center center;
  --hero-bg-size: cover;
  --hero-bg-duration: 3000ms;
  --hero-bg-ease: cubic-bezier(.25,.46,.45,.94);
  --hero-text-opacity: 0;
  --hero-text-y: -30px;
  --hero-text-duration: 1200ms;
  --hero-text-ease: cubic-bezier(.25,.46,.45,.94);

  /* Engineered hero height + scroll behavior */
  --hero-height-max-svh: 56;
  --hero-height-min-svh: 44;
  --hero-height-map-factor: 1.25;
  --hero-exit-threshold: 0.3; /* fraction of viewport */

  --preloader-fade-duration: 1000ms;
  --preloader-delay-before-hero: 300ms;
}

html {
  scroll-behavior: smooth;
}

[id] {
  scroll-margin-top: calc(var(--header-height) + 12px);
}

body.stretched.dark.side-push-panel {
  background: #04050a;
  color: #dedede;
}

#nav-accent {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: var(--nav-accent-color, #00d4ff);
  z-index: 1200;
  pointer-events: none;
  /* Slide-in bar speed (2.5x longer) + 1.25s delay */
  transition: width 1.5s ease 1.25s;
}

body.nav-accent-ready #nav-accent {
  width: 100%;
}

body.engineered-mode #wrapper,
body.engineered-mode #content,
body.engineered-mode #content-wrap,
body.engineered-mode #page-title {
  background: transparent !important;
  /* background-image: none !important; */
}

body.engineered-mode #header,
body.engineered-mode #header-wrap {
  border: 0 !important;
  box-shadow: none !important;
}

body.engineered-mode #header:after,
body.engineered-mode #header-wrap:after {
  content: none !important;
  display: none !important;
}

/* Content background driven by CSS variables (single source) */
#content .content-wrap {
  background-image: var(--content-bg-image, none);
  background-repeat: var(--content-bg-repeat, no-repeat);
  background-size: var(--content-bg-size, cover);
  background-position: var(--content-bg-position, center top);
  background-color: var(--content-bg-color, transparent);
  padding-top: var(--content-pad-top, 2.5rem);
  padding-bottom: var(--content-pad-bottom, 3rem);
}

/* Primary nav: simple, accessible dropdowns for two items */
.primary-menu .menu-container .menu-item { position: relative; }
.primary-menu .menu-container .menu-item.has-submenu > .submenu {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 220px;
  padding: 10px 0;
  margin: 0;
  list-style: none;
  display: none;
  background: rgba(14,16,22,.12);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  backdrop-filter: blur(10px) saturate(120%);
  border-left: 2px solid var(--color-accent);
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
  z-index: 1201;
}
.primary-menu .menu-container .menu-item.has-submenu:hover > .submenu,
.primary-menu .menu-container .menu-item.has-submenu:focus-within > .submenu {
  display: block;
}
.primary-menu .submenu .submenu-item { display: block; }
.primary-menu .submenu .submenu-link {
  display: block;
  padding: 10px 16px;
  color: #e8f6ff;
  text-decoration: none;
  white-space: nowrap;
}
.primary-menu .submenu .submenu-link:hover,
.primary-menu .submenu .submenu-link:focus {
  background: rgba(0,212,255,.08);
  color: var(--color-accent);
}

/* Add more breathing room at nav edges (logo and dropdown side) */
#header #header-wrap .container {
  padding-left: 64px;
  padding-right: 64px;
}

.preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(8px);
  transition: opacity var(--preloader-fade-duration) ease,
              visibility var(--preloader-fade-duration) ease;
}

.preloader.loaded {
  opacity: 0;
  visibility: hidden;
}

.preloader-content {
  text-align: center;
  color: var(--color-accent);
}

.preloader-spinner,
.loader {
  --loader-c1: var(--color-accent);
  --loader-c2: var(--color-accent);
  --loader-c3: var(--color-accent);
  width: 140px;
  aspect-ratio: 1;
  position: relative;
  margin: 0 auto 24px;
  border-radius: 50%;
}

.preloader-spinner::before,
.loader::before,
.preloader-spinner::after,
.loader::after {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 50%;
  border: 3px solid rgba(0, 212, 255, 0.35);
  border-top-color: var(--color-accent);
  animation: spin 1s linear infinite;
}

.preloader-text {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.preloader-progress {
  margin-top: 15px;
  font-size: 12px;
  opacity: 0.8;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

#header #header-wrap {
  position: relative;
}

#header.border-full-header #header-wrap {
  border-bottom: 0 !important;
}

#header #header-wrap::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: var(--nav-accent-width);
  background: var(--nav-accent-color);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition:
    opacity var(--nav-accent-fade) cubic-bezier(.25,.46,.45,.94) var(--nav-accent-delay),
    transform var(--nav-accent-fade) cubic-bezier(.25,.46,.45,.94) var(--nav-accent-delay);
  pointer-events: none;
}

#header #header-wrap::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: var(--nav-accent-width);
  background: var(--nav-accent-color);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition: opacity var(--nav-accent-fade) ease var(--nav-accent-delay),
              transform var(--nav-accent-fade) ease var(--nav-accent-delay);
  pointer-events: none;
  z-index: 1;
}

body.nav-line-top #header #header-wrap::before {
  opacity: 1;
  transform: scaleX(1);
  transition-timing-function: cubic-bezier(.17,.67,.39,.95);
}

body.nav-line-bottom #header #header-wrap::before {
  opacity: 0;
  transform: scaleX(0);
  transition-timing-function: cubic-bezier(.6,.05,.55,.95);
}

#header #header-wrap .nav-glass {
  position: absolute;
  inset: 0;
  background: rgba(3, 3, 5, 0.35);
  backdrop-filter: blur(10px) saturate(120%);
  opacity: 0;
  transition: opacity var(--nav-bg-fade) ease var(--nav-bg-delay);
  pointer-events: none;
  z-index: -1;
}

#header #header-wrap > .container,
#header #header-wrap .header-row {
  position: relative;
  z-index: 2;
}

#header #header-wrap::before {
  z-index: 1;
}

body.sticky-header #header #header-wrap .nav-glass {
  opacity: 1;
}

body.sticky-header #header #header-wrap {
  background: rgba(14, 16, 22, 0.12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px) saturate(120%);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22);
}

.engineered-hero {
  position: relative;
  z-index: 0;
  min-height: calc(var(--hero-min-height-svh, 56) * 1svh);
  display: flex;
  align-items: center;
  padding: calc(var(--header-height, 112px) + var(--hero-top-extra-svh, 4svh) - var(--hero-top-trim-px, 0px)) 0 6svh;
  overflow: visible;
}

.engineered-hero .hero-bg {
  position: fixed;
  left: 0;
  width: 100vw;
  top: calc(-1 * var(--hero-bg-bleed));
  height: calc(100svh + var(--hero-bg-bleed));
  background-image: var(--hero-bg-image);
  background-repeat: no-repeat;
  background-position: var(--hero-bg-position);
  background-size: var(--hero-bg-size);
  opacity: var(--hero-bg-opacity);
  transform: translateY(var(--spotlight-y, var(--hero-bg-drop))) scale(var(--hero-bg-scale));
  filter: blur(var(--hero-bg-blur));
  transition:
    opacity var(--hero-bg-duration) var(--hero-bg-ease),
    transform var(--hero-bg-duration) var(--hero-bg-ease),
    filter var(--hero-bg-duration) var(--hero-bg-ease);
  z-index: -1;
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 800px;
  border: 2px solid var(--color-accent);
  backdrop-filter: blur(12px) saturate(120%);
  background: rgba(0, 0, 0, 0.15);
  padding: 2rem;
  border-radius: 10px;
}

.hero-small-text,
.hero-main-title,
.hero-subtitle {
  opacity: var(--hero-text-opacity);
  transform: translateY(var(--hero-text-y));
  transition: all var(--hero-text-duration) var(--hero-text-ease);
}

.hero-small-text {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--color-pink);
}

.hero-main-title {
  font-size: clamp(2.5rem, 6vw, 4rem);
  line-height: 1.1;
  color: #ffffff;
  margin: 0.6rem 0 1.2rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.hero-main-title .accent {
  color: var(--color-accent) !important;
}

.body-copy {
  color: #bfc6d8;
  line-height: 1.7;
}

.hero-subtitle {
  font-size: 1.2rem;
  color: #ffffff;
  max-width: 600px;
}

.body-copy {
  color: #bfc6d8;
  line-height: 1.7;
}

.list-feature {
  list-style: none;
  padding-left: 1.6rem;
  color: #dce2f0;
}

.list-feature li {
  position: relative;
  margin-bottom: 0.6rem;
}

.list-feature li::before {
  content: '';
  position: absolute;
  left: -1.6rem;
  top: 0.55rem;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 0 4px rgba(0, 212, 255, 0.15);
}

.callout-highlight {
  position: relative;
  padding: 1.8rem 2.2rem;
  margin: 2rem 0;
  background: rgba(5, 9, 18, 0.82);
  border-left: 4px solid var(--color-accent);
  border-radius: 12px;
  color: #f2f5ff;
  box-shadow: 0 18px 40px -28px rgba(0, 0, 0, 0.85);
}

.callout-highlight p {
  margin-bottom: 0.6rem;
  color: inherit;
}

.callout-highlight .callout-title {
  font-size: 0.9rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  margin-bottom: 0.8rem;
  color: rgba(255, 255, 255, 0.6);
}

.callout-highlight .callout-quote {
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: 1rem;
}

.btn-variant,
.btn-variant:link,
.btn-variant:visited,
.ng-btn,
.ng-btn:link,
.ng-btn:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.7rem 1.6rem;
  border-radius: 999px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
}

.btn-variant:hover,
.ng-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -18px rgba(0, 0, 0, 0.8);
}

.btn-variant:focus-visible,
.ng-btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.btn-neo,
.btn-neo:link,
.btn-neo:visited,
.ng-btn--neo,
.ng-btn--neo:link,
.ng-btn--neo:visited {
  background: var(--color-accent) !important;
  color: #04121a !important;
}

.btn-variant.btn-neo,
.btn-variant.btn-neo:hover,
.btn-variant.btn-neo:focus-visible,
.ng-btn.ng-btn--neo,
.ng-btn.ng-btn--neo:hover,
.ng-btn.ng-btn--neo:focus-visible {
  border: none;
}

.btn-neo:hover,
.ng-btn--neo:hover {
  background: #33ddff;
}

.btn-night,
.btn-night:link,
.btn-night:visited,
.ng-btn--night,
.ng-btn--night:link,
.ng-btn--night:visited {
  background: rgba(5, 12, 20, 0.88) !important;
  color: #ff69b4 !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-night:hover,
.ng-btn--night:hover {
  background: rgba(5, 12, 20, 1);
  color: #ffc0dd;
}

.btn-outline-accent,
.btn-outline-accent:link,
.btn-outline-accent:visited,
.ng-btn--outline,
.ng-btn--outline:link,
.ng-btn--outline:visited {
  background: transparent !important;
  color: var(--color-accent) !important;
  border: 1px solid rgba(0, 212, 255, 0.6) !important;
}

.btn-outline-accent:hover,
.ng-btn--outline:hover {
  background: rgba(0, 212, 255, 0.12);
}

.btn-soft-pink,
.btn-soft-pink:link,
.btn-soft-pink:visited,
.ng-btn--soft,
.ng-btn--soft:link,
.ng-btn--soft:visited {
  background: rgba(255, 105, 180, 0.18) !important;
  color: #ffd9ea !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-soft-pink:hover,
.ng-btn--soft:hover {
  background: rgba(255, 105, 180, 0.28);
}

/*
 * =============================================================
 * Newgen Button System
 * -------------------------------------------------------------
 * Usage:
 *   <a class="btn-variant btn-neo">...</a>
 *   or alias classes: <a class="ng-btn ng-btn--neo">...</a>
 * Variants: neo, night, outline, soft
 * =============================================================
 */

.button-showcase {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Ensure primary menu renders even without legacy scripts */
#header .primary-menu .menu-container {
  display: flex !important;
  gap: 1.6rem;
  align-items: center;
}

#header .primary-menu {
  display: block !important;
}

#header .primary-menu .menu-item {
  list-style: none;
  display: inline-flex;
}

#header .primary-menu .menu-link {
  color: #f5f8ff;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.78rem;
  display: inline-flex;
  align-items: center;
}

#header .primary-menu .menu-link div {
  display: inline;
}

#header .primary-menu .menu-link:hover,
#header .primary-menu .menu-item.current .menu-link {
  color: var(--color-accent);
}

/* intentionally keep nav-specific overrides in css/global.css for single-sourcing */

.btn-variant,
.btn-variant:link,
.btn-variant:visited,
.ng-btn,
.ng-btn:link,
.ng-btn:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.7rem 1.6rem;
  border-radius: 999px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
}

.btn-variant:hover,
.ng-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -18px rgba(0, 0, 0, 0.8);
}

.btn-variant:focus-visible,
.ng-btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.btn-neo,
.btn-neo:link,
.btn-neo:visited,
.ng-btn--neo,
.ng-btn--neo:link,
.ng-btn--neo:visited {
  background: var(--color-accent) !important;
  color: #04121a !important;
}

.btn-variant.btn-neo,
.btn-variant.btn-neo:hover,
.btn-variant.btn-neo:focus-visible,
.ng-btn.ng-btn--neo,
.ng-btn.ng-btn--neo:hover,
.ng-btn.ng-btn--neo:focus-visible {
  border: none;
}

.btn-neo:hover,
.ng-btn--neo:hover {
  background: #33ddff;
}

.btn-night,
.btn-night:link,
.btn-night:visited,
.ng-btn--night,
.ng-btn--night:link,
.ng-btn--night:visited {
  background: rgba(5, 12, 20, 0.88) !important;
  color: #ff69b4 !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-night:hover,
.ng-btn--night:hover {
  background: rgba(5, 12, 20, 1);
  color: #ffc0dd;
}

.btn-outline-accent,
.btn-outline-accent:link,
.btn-outline-accent:visited,
.ng-btn--outline,
.ng-btn--outline:link,
.ng-btn--outline:visited {
  background: transparent !important;
  color: var(--color-accent) !important;
  border: 1px solid rgba(0, 212, 255, 0.6) !important;
}

.btn-outline-accent:hover,
.ng-btn--outline:hover {
  background: rgba(0, 212, 255, 0.12);
}

.btn-soft-pink,
.btn-soft-pink:link,
.btn-soft-pink:visited,
.ng-btn--soft,
.ng-btn--soft:link,
.ng-btn--soft:visited {
  background: rgba(255, 105, 180, 0.18) !important;
  color: #ffd9ea !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-soft-pink:hover,
.ng-btn--soft:hover {
  background: rgba(255, 105, 180, 0.28);
}

/*
 * =============================================================
 * Newgen Button System
 * -------------------------------------------------------------
 * Usage:
 *   <a class="btn-variant btn-neo">...</a>
 *   or alias classes: <a class="ng-btn ng-btn--neo">...</a>
 * Variants: neo, night, outline, soft
 * =============================================================
 */

.button-showcase {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Ensure primary menu renders even without legacy scripts */
#header .primary-menu .menu-container {
  display: flex !important;
  gap: 1.6rem;
  align-items: center;
}

#header .primary-menu {
  display: block !important;
}

#header .primary-menu .menu-item {
  list-style: none;
  display: inline-flex;
}

#header .primary-menu .menu-link {
  color: #f5f8ff;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.78rem;
  display: inline-flex;
  align-items: center;
}

#header .primary-menu .menu-link div {
  display: inline;
}

#header .primary-menu .menu-link:hover,
#header .primary-menu .menu-item.current .menu-link {
  color: var(--color-accent);
}

/* intentionally keep nav-specific overrides in css/global.css for single-sourcing */

.btn-variant,
.btn-variant:link,
.btn-variant:visited,
.ng-btn,
.ng-btn:link,
.ng-btn:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.7rem 1.6rem;
  border-radius: 999px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
}

.btn-variant:hover,
.ng-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -18px rgba(0, 0, 0, 0.8);
}

.btn-variant:focus-visible,
.ng-btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.btn-neo,
.btn-neo:link,
.btn-neo:visited,
.ng-btn--neo,
.ng-btn--neo:link,
.ng-btn--neo:visited {
  background: var(--color-accent) !important;
  color: #04121a !important;
}

.btn-variant.btn-neo,
.btn-variant.btn-neo:hover,
.btn-variant.btn-neo:focus-visible,
.ng-btn.ng-btn--neo,
.ng-btn.ng-btn--neo:hover,
.ng-btn.ng-btn--neo:focus-visible {
  border: none;
}

.btn-neo:hover,
.ng-btn--neo:hover {
  background: #33ddff;
}

.btn-night,
.btn-night:link,
.btn-night:visited,
.ng-btn--night,
.ng-btn--night:link,
.ng-btn--night:visited {
  background: rgba(5, 12, 20, 0.88) !important;
  color: #ff69b4 !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-night:hover,
.ng-btn--night:hover {
  background: rgba(5, 12, 20, 1);
  color: #ffc0dd;
}

.btn-outline-accent,
.btn-outline-accent:link,
.btn-outline-accent:visited,
.ng-btn--outline,
.ng-btn--outline:link,
.ng-btn--outline:visited {
  background: transparent !important;
  color: var(--color-accent) !important;
  border: 1px solid rgba(0, 212, 255, 0.6) !important;
}

.btn-outline-accent:hover,
.ng-btn--outline:hover {
  background: rgba(0, 212, 255, 0.12);
}

.btn-soft-pink,
.btn-soft-pink:link,
.btn-soft-pink:visited,
.ng-btn--soft,
.ng-btn--soft:link,
.ng-btn--soft:visited {
  background: rgba(255, 105, 180, 0.18) !important;
  color: #ffd9ea !important;
  border: 1px solid rgba(255, 105, 180, 0.45) !important;
}

.btn-soft-pink:hover,
.ng-btn--soft:hover {
  background: rgba(255, 105, 180, 0.28);
}

/*
 * =============================================================
 * Newgen Button System
 * -------------------------------------------------------------
 * Usage:
 *   <a class="btn-variant btn-neo">...</a>
 *   or alias classes: <a class="ng-btn ng-btn--neo">...</a>
 * Variants: neo, night, outline, soft
 * =============================================================
 */

.button-showcase {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Ensure primary menu renders even without legacy scripts */
#header .primary-menu .menu-container {
  display: flex !important;
  gap: 1.6rem;
  align-items: center;
}

#header .primary-menu {
  display: block !important;
}

#header .primary-menu .menu-item {
  list-style: none;
  display: inline-flex;
}

#header .primary-menu .menu-link {
  color: #f5f8ff;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.78rem;
  display: inline-flex;
  align-items: center;
}

#header .primary-menu .menu-link div {
  display: inline;
}

#header .primary-menu .menu-link:hover,
#header .primary-menu .menu-item.current .menu-link {
  color: var(--color-accent);
}

/* Showcase tag: outlined deep pink, deep pink text, smoke/blur fill, smaller size */
.badge-pink-outline {
  display: inline-block;
  padding: 0.28em 0.7em;
  font-size: 0.72em;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 1.2em;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: rgba(194, 24, 91, 0.10); /* smoke/blur fill, deep pink */
  color: #c2185b;
  border: 1.5px solid #c2185b;
  box-shadow: 0 2px 8px rgba(194,24,91,0.10);
  margin-right: 0.18em;
}

/* Bulletproof pink badge styles for showcase tags */
.pink-b {
  display: inline-block !important;
  padding: 0.5em 1em !important;
  font-size: 0.85em !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  text-align: center !important;
  white-space: nowrap !important;
  vertical-align: baseline !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background-color: #ff0080 !important;
  color: #ffffff !important;
  border: none !important;
  margin-right: 0.25em !important;
}

.pink-b-outline {
  display: inline-block !important;
  padding: 0.5em 1em !important;
  font-size: 0.85em !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  text-align: center !important;
  white-space: nowrap !important;
  vertical-align: baseline !important;
  border-radius: 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background-color: rgba(255, 0, 128, 0.2) !important;
  color: #ff0080 !important;
  border: 1px solid #ff0080 !important;
  margin-right: 0.25em !important;
}

/* Bold and outlined pink badge styles for showcase tags */
.pink-b {
  display: inline-block;
  padding: 0.5em 1em;
  font-size: 0.85em;
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background-color: #ff0080;
  color: #ffffff;
}

.pink-b-outline {
  display: inline-block;
  padding: 0.5em 1em;
  font-size: 0.85em;
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background-color: rgba(255, 0, 128, 0.2);
  color: #ff0080;
  border: 1px solid #ff0080;
}

/* Pink badge that matches the original royal blue tag style */
.badge-pink-2 {
  display: inline-block;
  padding: 0.35em 0.65em;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25rem;
  background-color: #ff69b4;
  box-shadow: 0 2px 8px rgba(255,105,180,0.12);
  border: none;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-right: 0.25em;
}

/* Pink badge that matches the original royal blue tag style */

/* Fully enforced pink badge/button style for showcase tags */
.badge-pink {
  background: #ff69b4 !important;
  color: #fff !important;
  font-weight: 700 !important;
  padding: 0.35em 0.65em !important;
  border-radius: 0.25rem !important;
  display: inline-block !important;
  font-size: 0.75em !important;
  line-height: 1 !important;
  text-align: center !important;
  white-space: nowrap !important;
  vertical-align: baseline !important;
  margin-right: 0.25em !important;
  box-shadow: 0 2px 8px rgba(255,105,180,0.12) !important;
  border: none !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

/* Pink badge for showcase tags */
.badge-pink {
  background: #ff69b4;
  color: #fff;
  font-weight: 600;
  padding: 0.35em 0.65em;
  border-radius: 0.25rem;
  display: inline-block;
  font-size: 0.75em;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  margin-right: 0.25em;
}

/* Badge Styles (for project tags, etc.) */
.badge {
  display: inline-block;
  padding: 0.35em 0.65em;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25rem;
}

.badge.bg-primary {
  background-color: #ff69b4 !important;
}

.badge.bg-secondary {
  background-color: #ffb3d6 !important;
}

/* Project Tag Badges */
.badge.bg-primary {
  background-color: #ff69b4 !important;
  color: #ffffff;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.35em 0.8em;
  font-size: 0.75rem;
}

.badge.bg-secondary {
  background-color: rgba(255, 105, 180, 0.85) !important;
  color: #ffffff;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.35em 0.8em;
  font-size: 0.75rem;
}

/* Project Tags - brand pink style */
.ng-tag {
  display: inline-block;
  padding: 0.35rem 0.8rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  background: #ff69b4;
  color: #ffffff;
  margin: 0.25rem;
  transition: all 0.2s ease;
}

.ng-tag:hover {
  background: #ff7dbe;
  transform: translateY(-1px);
}

/* Mobile Responsiveness - 2025 Update */
@media (max-width: 768px) {
  /* Header & Navigation */
  #header #header-wrap .container {
    padding-left: 20px;
    padding-right: 20px;
  }
  
  .primary-menu .menu-container {
    flex-direction: column;
    gap: 0.8rem;
    position: absolute; /* Changed from fixed to absolute */
    top: 100%; /* Position it right below the header */
    left: 0;
    right: 0;
    background: rgba(3, 3, 5, 0.95);
    backdrop-filter: blur(10px);
    padding: 1rem;
    display: none !important;
    max-height: calc(100vh - var(--header-height) - 20px); /* Prevent overflow */
    overflow-y: auto; /* Allow scrolling if menu is too tall */
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  }

  .primary-menu.show .menu-container {
    display: flex !important;
  }

  /* Ensure header stays on top */
  #header {
    position: sticky;
    top: 0;
    background: rgba(3, 3, 5, 0.95);
    backdrop-filter: blur(10px);
  }

  /* Hero Section Adjustments */
  .engineered-hero {
    min-height: calc(var(--hero-min-height-svh, 42) * 1svh);
    padding: calc(var(--header-height, 80px) + 2svh) 0 4svh;
  }

  .hero-content {
    padding: 1.5rem;
    margin: 0 1rem;
  }

  .hero-main-title {
    font-size: clamp(2rem, 8vw, 2.5rem);
    margin: 0.4rem 0 0.8rem;
  }

  .hero-subtitle {
    font-size: 1rem;
  }

  /* Typography Scaling */
  .ng-hero-title {
    font-size: 2.5rem;
    letter-spacing: -0.01em;
  }

  .ng-hero-subtitle {
    font-size: 1.1rem;
  }

  .ng-section-header {
    font-size: 1rem;
  }

  .ng-featured-quote {
    font-size: 1.6rem;
    padding: 0.75rem 1.25rem;
  }

  .ng-design-quote {
    font-size: 1.4rem;
    padding: 1.5rem;
  }

  /* Content & Layout */
  .ng-text-container {
    padding: 1rem 0.75rem;
  }

  body:not(.home-newgen) #content .content-wrap {
    padding-top: 1rem;
    padding-bottom: 3rem;
  }

  .callout-highlight {
    padding: 1.4rem 1.6rem;
    margin: 1.5rem 0;
  }

  .list-feature {
    padding-left: 1.2rem;
  }

  /* Button System */
  .ng-btn,
  .btn-variant {
    padding: 0.7rem 1.4rem;
    min-height: 40px;
    width: 100%;
    margin-bottom: 0.5rem;
  }

  .button-showcase {
    flex-direction: column;
    gap: 0.5rem;
  }

  /* Performance Optimizations */
  .hero-bg,
  .ng-btn:hover,
  .btn-variant:hover,
  .ng-tag:hover {
    transform: none !important;
    transition: opacity 0.3s ease !important;
  }

  .primary-menu .menu-container .menu-item.has-submenu > .submenu,
  #header #header-wrap .nav-glass {
    backdrop-filter: blur(6px) saturate(110%);
  }

  /* Tag adjustments for mobile */
  .ng-tag {
    font-size: 0.7rem;
    padding: 0.3rem 0.7rem;
    margin: 0.2rem;
  }
}

/* -----------------------------------------------------------
   Subpage 2: content smoke/blur panel (blue framed)
   ----------------------------------------------------------- */
body.page-subpage-2 .sub2-glass{
  background: rgba(14,16,22, var(--sub2-glass-alpha, 0.42));
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  backdrop-filter: blur(10px) saturate(120%);
  border: 2px solid var(--color-accent);
  border-radius: 12px;
  padding: 2rem;
  box-shadow: 0 18px 40px -24px rgba(0,0,0,.6);
}

body.page-subpage-2 .sub2-glass .callout-highlight{
  background: rgba(5, 9, 18, 0.65);
}

/* Global: tighten hero top space on all pages except index */
body:not(.home-newgen) .engineered-hero{
  padding-top: calc(var(--header-height, 112px) + 1svh);
  padding-bottom: 2svh;
}

/* Global: ensure comfortable content spacing (non-index) */
body:not(.home-newgen) #content .content-wrap{
  padding-top: 1.5rem;
  padding-bottom: 5rem;
}

/* Subpages: tighten space beneath nav and before content */
body.page-subpage-1 .engineered-hero,
body.page-subpage-2 .engineered-hero,
body.page-works .engineered-hero{
  min-height: 44svh;
  padding: calc(var(--header-height, 112px) + 0.4svh) 0 1.4svh;
}

body.page-subpage-1 #content .content-wrap,
body.page-subpage-2 #content .content-wrap,
body.page-works #content .content-wrap{
  --content-pad-top: 1rem;
}

.exit-loader{
  position:fixed; inset:0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
  display:flex; align-items:center; justify-content:center;
  z-index: 1500;
  opacity:0;
  pointer-events:none;
  transition: opacity 0.26s cubic-bezier(.45,.05,.55,.95);
}
.exit-loader.hidden{ display:none; }
.exit-loader.active{
  opacity:1;
  pointer-events:all;
}
.exit-loader__content{ text-align:center; color:#00d4ff; }
.exit-loader__text{ margin-top:18px; letter-spacing:0.12em; text-transform:uppercase; font-size:12px; }