/* ════════════════════════════════════════════════════════════════
   AHSIS INNOVATIONS — UPGRADED CSS
   Architecture: @layer · oklch · @property · nesting · container queries
   ════════════════════════════════════════════════════════════════ */

/* ── 1. LAYER ORDER (specificity stacking — never use !important again) ── */
@layer reset, tokens, base, layout, components, animations, utilities, overrides;

/* ── 2. @property: typed, animatable CSS variables ── */
@property --gradient-angle {
  syntax: "<angle>";
  initial-value: 135deg;
  inherits: false;
}
@layer overrides {
  .ft-credit-wrap {
    display: flex;
    justify-content: center;
    margin: 12px 0 18px;
  }
  .ft-credit {
    color: var(--color-brand);
    background: linear-gradient(
      90deg,
      oklch(from var(--color-brand) l c h / 0.06),
      oklch(from var(--color-brand) l c h / 0.02)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.12);
    padding: 8px 14px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 13px;
    box-shadow: 0 10px 30px oklch(from var(--color-brand) l c h / 0.06);
  }
  .ft-credit .ft-credit-name {
    margin-left: 8px;
    color: oklch(from var(--color-brand) l c h / 0.98);
    font-weight: 800;
  }
  @media (max-width: 760px) {
    .ft-credit {
      font-size: 12px;
      padding: 7px 10px;
    }
  }
  /* Gentle global saturation boost to restore vibrancy */
  html {
    filter: saturate(1.06);
  }
}
@property --gradient-stop-1 {
  syntax: "<color>";
  initial-value: oklch(72% 0.19 152);
  inherits: false;
}
@property --gradient-stop-2 {
  syntax: "<color>";
  initial-value: oklch(72% 0.16 72);
  inherits: false;
}
@property --shadow-opacity {
  syntax: "<number>";
  initial-value: 0;
  inherits: false;
}
@property --progress-width {
  syntax: "<percentage>";
  initial-value: 0%;
  inherits: false;
}

/* ════════════════════════════════════════════════════════════════
   3. TOKENS — Two-tier: primitives → semantics
   ════════════════════════════════════════════════════════════════ */
@layer tokens {
  :root {
    /* ── Tier 1: Primitives — oklch for perceptual uniformity ── */
    /* Fallback sRGB primitives for older browsers (overridden by oklch below) */
    --sky-950: #071725;
    --sky-900: #123a56;
    --sky-700: #2c6aa3;
    --sky-600: #3a8fe0;
    --sky-500: #5aa6ff;
    --sky-400: #8bc6ff;
    --sky-100: #f3fbff;
    --sky-50: #fbfdff;

    --green-950: #0f3d2a;
    --green-900: #12684a;
    --green-800: #1f8a5f;
    --green-700: #167a5b;
    --green-600: #23a66d;
    --green-500: #2fbf7a;
    --green-400: #5ed39b;
    --green-300: #8fe6be;
    --green-100: #f0faf5;
    --green-50: #fbfffb;

    --amber-900: #b07a00;
    --amber-700: #d19b00;
    --amber-500: #f2b705;
    --amber-400: #ffd66a;
    --amber-100: #fff9ee;
    --amber-50: #fffdf5;

    --ink-950: #071118;
    --ink-800: #17242b;
    --ink-700: #26343b;
    --ink-600: #3a444b;
    --ink-400: #616b70;
    --ink-200: #9aa1a6;
    --ink-100: #cfd4d6;
    --ink-50: #eef0f1;
    --ink-20: #f7f8f8;

    /* Semantic fallbacks */
    --color-action: var(--sky-600);
    --color-brand: var(--green-700);
    --color-gold: var(--amber-500);
    --text-ink: var(--ink-950);
    --surface-white: #ffffff;
    --surface-off: #fbfaf9;
    --surface-soft: #f4f6f8;
    --surface-border: #e6e9eb;
    --surface-border2: #f0f2f3;

    /* Sky blues */
    --sky-950: oklch(18% 0.08 232);
    --sky-900: oklch(26% 0.12 232);
    --sky-700: oklch(42% 0.18 232);
    --sky-600: oklch(52% 0.22 232);
    --sky-500: oklch(60% 0.22 232);
    --sky-400: oklch(70% 0.18 232);
    --sky-100: oklch(94% 0.04 232);
    --sky-50: oklch(97% 0.02 232);

    /* Forest greens */
    --green-950: oklch(14% 0.07 152);
    --green-900: oklch(20% 0.1 152);
    --green-800: oklch(28% 0.12 152);
    --green-700: oklch(38% 0.16 152);
    --green-600: oklch(46% 0.18 152);
    --green-500: oklch(56% 0.2 152);
    --green-400: oklch(66% 0.2 152);
    --green-300: oklch(72% 0.19 152);
    --green-100: oklch(93% 0.05 152);
    --green-50: oklch(97% 0.02 152);

    /* Amber/gold */
    --amber-900: oklch(28% 0.1 72);
    --amber-700: oklch(48% 0.16 72);
    --amber-500: oklch(68% 0.16 72);
    --amber-400: oklch(76% 0.14 72);
    --amber-100: oklch(94% 0.04 72);
    --amber-50: oklch(97% 0.02 72);

    /* Neutral ink */
    --ink-950: oklch(10% 0.02 152);
    --ink-800: oklch(22% 0.03 152);
    --ink-700: oklch(32% 0.04 152);
    --ink-600: oklch(46% 0.04 152);
    --ink-400: oklch(62% 0.03 152);
    --ink-200: oklch(82% 0.02 152);
    --ink-100: oklch(90% 0.01 152);
    --ink-50: oklch(95% 0.01 152);
    --ink-20: oklch(98% 0.005 152);

    /* ── Tier 2: Semantic tokens — only these go into components ── */

    /* Hero/dark surfaces */
    --surface-hero: var(--green-950);
    --surface-dark: var(--green-900);
    --surface-forest: var(--green-800);

    /* Light surfaces */
    --surface-white: oklch(100% 0 0);
    --surface-off: oklch(97% 0.005 72);
    --surface-soft: oklch(95% 0.01 72);
    --surface-border: oklch(90% 0.01 72);
    --surface-border2: oklch(85% 0.015 72);

    /* Typography */
    --text-ink: var(--ink-950);
    --text-ink2: var(--ink-800);
    --text-ink3: var(--ink-800);
    --text-ink4: var(--ink-700);

    /* Action (primary CTAs, interactive elements) */
    --color-action: var(--sky-600);
    --color-action-hover: var(--sky-500);
    --color-action-light: var(--sky-400);
    --color-action-surface: var(--sky-50);
    --color-action-border: var(--sky-100);

    /* Brand green (anchors, secondary actions) */
    --color-brand: var(--green-700);
    --color-brand-mid: var(--green-500);
    --color-brand-bright: var(--green-300);
    --color-brand-surface: var(--green-50);

    /* Accent gold */
    --color-gold: var(--amber-500);
    --color-gold-surface: var(--amber-50);
    --color-gold-border: var(--amber-100);

    /* Backward-compatible aliases for legacy inline styles and injected UI */
    --white: var(--surface-white);
    --soft: var(--surface-soft);
    --border: var(--surface-border);
    --border2: var(--surface-border2);
    --ink: var(--text-ink);
    --ink2: var(--text-ink2);
    --ink3: var(--text-ink3);
    --ink4: var(--text-ink4);
    --gold: var(--color-gold);
    --green: var(--green-600);
    --green-m: var(--color-brand-mid);
    --orange: var(--amber-700);
    --orange-p: oklch(from var(--amber-500) l c h / 0.14);
    --orange-p2: oklch(from var(--amber-500) l c h / 0.34);

    /* ── Elevation shadows (pseudo-element approach — GPU-only) ── */
    --shadow-action: 0 8px 32px oklch(from var(--color-action) l c h / 0.35);
    --shadow-sm: 0 1px 4px oklch(10% 0.02 152 / 0.08);
    --shadow-md: 0 4px 18px oklch(10% 0.02 152 / 0.11);
    --shadow-lg: 0 16px 56px oklch(10% 0.02 152 / 0.17);

    /* ── Motion tokens ── */
    --duration-instant: 100ms;
    --duration-fast: 180ms;
    --duration-base: 260ms;
    --duration-slow: 420ms;
    --duration-xslow: 700ms;

    /* ── Z-index scale (organized stacking contexts) ── */
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;
    --z-loader: 12000;
    --z-progress: 9999;

    /* Spring easing — linear() for physics-based motion */
    --ease-spring: linear(
      0,
      0.009,
      0.035 2.1%,
      0.141 4.4%,
      0.281 6.7%,
      0.723 12.2%,
      0.939,
      1.046 20.4%,
      1.008 24.5%,
      1 100%
    );
    --ease-overshoot: linear(0, 0.97 30%, 1.04 45%, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);

    /* ── Shape ── */
    --radius-sm: 8px;
    --radius-md: 10px;
    --radius-lg: 18px;
    --radius-pill: 999px;

    /* ── Spacing rhythm ── */
    --section-pad: clamp(72px, 8vw, 110px);
    --wrap-pad: clamp(20px, 5vw, 56px);
    --wrap-max: 1240px;
    /* Breakpoints */
    --bp-xs: 360px;
    --bp-sm: 560px;
    --bp-md: 900px;
    --bp-lg: 1100px;
    --bp-xl: 1400px;

    /* Type scale */
    --type-scale-base: 16px;
    --type-scale-sm: 14px;
    --type-scale-lg: 20px;
    /* Water / liquid tokens */
    --water-color-1: oklch(70% 0.12 230);
    --water-color-2: oklch(74% 0.14 200);
    --water-color-3: oklch(78% 0.12 260);
    --water-opacity: 0.06;
    --water-blur: 44px;
    --water-duration: 20s;
    --water-scale: 1.06;

    /* Utility spacing */
    --gap-sm: 8px;
    --gap-md: 16px;
    --gap-lg: 24px;

    /* Focus token */
    --focus-ring-color: var(--color-action);
    --focus-ring-size: 6px;
  }
}

/* ════════════════════════════════════════════════════════════════
   4. RESET
   ════════════════════════════════════════════════════════════════ */
@layer reset {
  *,
  *::before,
  *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }

  html {
    scroll-behavior: smooth;
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  img,
  video,
  canvas,
  svg {
    display: block;
    max-width: 100%;
  }
  a {
    text-decoration: none;
    color: inherit;
  }
  button {
    cursor: pointer;
    font-family: inherit;
    border: none;
    background: none;
  }
  ul,
  ol {
    list-style: none;
  }
  input,
  textarea,
  select {
    font-family: inherit;
  }

  ::-webkit-scrollbar {
    width: 4px;
  }
  ::-webkit-scrollbar-track {
    background: var(--surface-dark);
  }
  ::-webkit-scrollbar-thumb {
    background: var(--color-action);
    border-radius: 4px;
  }

  /* Respect reduced motion — globally */
  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
    }
  }
}

/* ════════════════════════════════════════════════════════════════
   5. BASE
   ════════════════════════════════════════════════════════════════ */
@layer base {
  body {
    font-family: "DM Sans", system-ui, sans-serif;
    background: var(--surface-white);
    color: var(--text-ink);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    /* Composite transitions system-wide — no more scattered declarations */
    & * {
      transition-property:
        color, background-color, border-color, box-shadow, transform, translate,
        opacity, filter;
      transition-duration: var(--duration-fast);
      transition-timing-function: var(--ease-out);
    }
  }

  /* ── Content visibility for off-screen sections ── */
  section {
    padding: var(--section-pad) 0;
    content-visibility: auto;
    contain-intrinsic-size: auto 800px;
  }

  /* Focus visible — accessible but styled */
  :focus-visible {
    outline: 2px solid var(--color-action);
    outline-offset: 3px;
    border-radius: 4px;
  }
}

/* ════════════════════════════════════════════════════════════════
   6. LAYOUT UTILITIES
   ════════════════════════════════════════════════════════════════ */
@layer layout {
  .wrap {
    max-width: var(--wrap-max);
    margin: 0 auto;
    padding-inline: var(--wrap-pad);
    contain: layout style;
  }

  .grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(32px, 5vw, 80px);
    align-items: center;

    @media (max-width: 900px) {
      grid-template-columns: 1fr;
    }
  }

  .geo-dots {
    background-image: radial-gradient(
      circle,
      var(--surface-border) 1px,
      transparent 1px
    );
    background-size: 22px 22px;
  }
}

/* ════════════════════════════════════════════════════════════════
   7. COMPONENTS — with CSS nesting
   ════════════════════════════════════════════════════════════════ */
@layer components {
  /* ── TYPOGRAPHY ATOMS ── */
  .eyebrow {
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-action);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;

    &::before {
      content: "";
      width: 20px;
      height: 1.5px;
      background: var(--color-action);
      flex-shrink: 0;
    }
  }

  .h2 {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(28px, 3.8vw, 52px);
    font-weight: 800;
    line-height: 1.07;
    letter-spacing: -0.025em;
    color: var(--text-ink);

    & em {
      font-style: normal;
      color: var(--color-brand-mid);
    }
  }

  .lead {
    font-size: clamp(15px, 1.3vw, 18px);
    line-height: 1.75;
    color: var(--text-ink3);
    margin-top: 16px;
    max-width: 580px;
  }

  /* ── SCROLL PROGRESS ── */
  #prog {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(
      90deg,
      var(--color-action),
      var(--color-gold),
      var(--color-brand-bright)
    );
    z-index: 9999;
    width: 0;
    /* scroll-driven progress bar — no JS needed */
    animation: progressTrack linear;
    animation-timeline: scroll(root);
    animation-range: 0% 100%;

    &::after {
      content: "";
      position: absolute;
      inset: 0;
      box-shadow: 0 0 12px oklch(from var(--color-action) l c h / 0.5);
    }
  }

  @keyframes progressTrack {
    to {
      width: 100%;
    }
  }

  /* ── NAV ── */
  /* Site preloader */
  body.site-loading {
    overflow: hidden;
  }

  body.site-loading #prog {
    opacity: 0;
  }

  .site-loader {
    position: fixed;
    inset: 0;
    z-index: var(--z-loader);
    display: grid;
    place-items: center;
    min-height: 100vh;
    padding: 24px;
    color: #fff;
    background:
      linear-gradient(90deg, oklch(100% 0 0 / 0.04) 1px, transparent 1px),
      linear-gradient(0deg, oklch(100% 0 0 / 0.035) 1px, transparent 1px),
      linear-gradient(
        135deg,
        oklch(7% 0.045 152),
        oklch(10% 0.055 218) 54%,
        oklch(9% 0.045 152)
      );
    background-size:
      72px 72px,
      72px 72px,
      auto;
    opacity: 1;
    visibility: visible;
    transition:
      opacity 520ms var(--ease-out, ease),
      visibility 520ms var(--ease-out, ease);
  }

  .site-loader::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
      repeating-linear-gradient(
        115deg,
        transparent 0 54px,
        oklch(from var(--color-action) l c h / 0.08) 54px 55px,
        transparent 55px 118px
      ),
      linear-gradient(
        90deg,
        transparent,
        oklch(from var(--color-gold) l c h / 0.12),
        transparent
      );
    opacity: 0.58;
    animation: loaderTerrainDrift 9s linear infinite;
  }

  .site-loader::after {
    content: "";
    position: absolute;
    inset-inline: 0;
    top: 0;
    height: 3px;
    background: linear-gradient(
      90deg,
      var(--color-action),
      var(--color-gold),
      var(--color-brand-bright)
    );
    transform-origin: left;
    animation: loaderTopLine 1.8s cubic-bezier(0.2, 0.9, 0.2, 1) infinite;
  }

  body.site-loaded .site-loader {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  .loader-shell {
    position: relative;
    z-index: 1;
    width: min(92vw, 420px);
    display: grid;
    justify-items: center;
    gap: 22px;
    padding: 34px 28px 30px;
    border: 1px solid oklch(100% 0 0 / 0.16);
    border-radius: 8px;
    background:
      linear-gradient(180deg, oklch(100% 0 0 / 0.1), oklch(100% 0 0 / 0.045)),
      oklch(5% 0.035 180 / 0.84);
    box-shadow:
      0 30px 90px oklch(0% 0 0 / 0.38),
      inset 0 1px 0 oklch(100% 0 0 / 0.16);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .loader-mark {
    position: relative;
    width: 164px;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
  }

  .loader-map {
    position: relative;
    width: 118px;
    aspect-ratio: 1;
    overflow: hidden;
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.38);
    border-radius: 8px;
    background:
      linear-gradient(90deg, oklch(100% 0 0 / 0.08) 1px, transparent 1px),
      linear-gradient(0deg, oklch(100% 0 0 / 0.08) 1px, transparent 1px),
      linear-gradient(
        145deg,
        oklch(from var(--color-action) l c h / 0.18),
        oklch(from var(--color-brand-bright) l c h / 0.14)
      );
    background-size:
      18px 18px,
      18px 18px,
      auto;
    box-shadow:
      0 18px 42px oklch(from var(--color-action) l c h / 0.18),
      inset 0 1px 0 oklch(100% 0 0 / 0.18);
  }

  .loader-scan {
    position: absolute;
    inset: -10%;
    background: linear-gradient(
      105deg,
      transparent 0 42%,
      oklch(from var(--color-gold) l c h / 0.42) 48%,
      transparent 56% 100%
    );
    transform: translateX(-72%);
    animation: loaderScan 1.9s ease-in-out infinite;
  }

  .loader-leaf {
    position: absolute;
    inset: 20px;
    width: auto;
    height: auto;
    fill: none;
    stroke: oklch(90% 0.12 152);
    stroke-width: 5;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(
      0 10px 24px oklch(from var(--color-brand-bright) l c h / 0.24)
    );
    animation: loaderLeaf 2.4s ease-in-out infinite;
  }

  .loader-node {
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--color-gold);
    box-shadow: 0 0 0 7px oklch(from var(--color-gold) l c h / 0.1);
    animation: loaderNode 1.8s ease-in-out infinite;
  }

  .loader-node-a {
    left: 18px;
    top: 32px;
  }

  .loader-node-b {
    right: 22px;
    top: 54px;
    animation-delay: 0.35s;
    background: var(--color-action-light);
    box-shadow: 0 0 0 7px oklch(from var(--color-action) l c h / 0.12);
  }

  .loader-node-c {
    left: 58px;
    bottom: 18px;
    animation-delay: 0.7s;
    background: var(--color-brand-bright);
    box-shadow: 0 0 0 7px oklch(from var(--color-brand-bright) l c h / 0.12);
  }

  .loader-orbit {
    position: absolute;
    inset: 0;
    border: 1px solid oklch(100% 0 0 / 0.18);
    border-radius: 50%;
  }

  .loader-orbit::before {
    content: "";
    position: absolute;
    left: 50%;
    top: -4px;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--color-gold);
    box-shadow: 0 0 16px oklch(from var(--color-gold) l c h / 0.55);
  }

  .loader-orbit-one {
    animation: loaderOrbit 4.8s linear infinite;
  }

  .loader-orbit-two {
    inset: 18px;
    border-color: oklch(from var(--color-action) l c h / 0.24);
    animation: loaderOrbit 3.8s linear infinite reverse;
  }

  .loader-copy {
    display: grid;
    gap: 7px;
    text-align: center;
  }

  .loader-kicker {
    color: var(--color-gold);
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
  }

  .loader-copy strong {
    color: #fff;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(24px, 5vw, 34px);
    font-weight: 850;
    line-height: 1.08;
    letter-spacing: 0;
  }

  .loader-copy small {
    color: oklch(100% 0 0 / 0.7);
    font-size: 14px;
    line-height: 1.55;
  }

  .loader-progress {
    position: relative;
    width: min(100%, 280px);
    height: 6px;
    overflow: hidden;
    border-radius: 999px;
    background: oklch(100% 0 0 / 0.11);
  }

  .loader-progress span {
    position: absolute;
    inset-block: 0;
    left: 0;
    width: 44%;
    border-radius: inherit;
    background: linear-gradient(
      90deg,
      var(--color-action),
      var(--color-gold),
      var(--color-brand-bright)
    );
    box-shadow: 0 0 18px oklch(from var(--color-gold) l c h / 0.28);
    animation: loaderProgress 1.35s ease-in-out infinite;
  }

  @keyframes loaderTerrainDrift {
    to {
      background-position:
        180px 0,
        100% 0;
    }
  }

  @keyframes loaderTopLine {
    0% {
      transform: scaleX(0.08);
    }
    55% {
      transform: scaleX(0.74);
    }
    100% {
      transform: scaleX(1);
    }
  }

  @keyframes loaderScan {
    0% {
      transform: translateX(-78%);
    }
    52%,
    100% {
      transform: translateX(78%);
    }
  }

  @keyframes loaderLeaf {
    0%,
    100% {
      transform: translateY(0) scale(1);
      opacity: 0.9;
    }
    50% {
      transform: translateY(-3px) scale(1.035);
      opacity: 1;
    }
  }

  @keyframes loaderNode {
    0%,
    100% {
      transform: scale(0.82);
      opacity: 0.72;
    }
    50% {
      transform: scale(1.18);
      opacity: 1;
    }
  }

  @keyframes loaderOrbit {
    to {
      transform: rotate(360deg);
    }
  }

  @keyframes loaderProgress {
    0% {
      transform: translateX(-105%);
    }
    55% {
      transform: translateX(80%);
    }
    100% {
      transform: translateX(238%);
    }
  }

  @media (max-width: 520px) {
    .site-loader {
      padding: 18px;
    }

    .loader-shell {
      width: min(100%, 340px);
      padding: 28px 20px 24px;
      gap: 18px;
    }

    .loader-mark {
      width: 136px;
    }

    .loader-map {
      width: 100px;
    }

    .loader-copy small {
      font-size: 13px;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .site-loader::before,
    .site-loader::after,
    .loader-scan,
    .loader-leaf,
    .loader-node,
    .loader-orbit,
    .loader-progress span {
      animation: none !important;
    }
  }

  /* Nav */
  nav {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 500;
    transition:
      background var(--duration-base),
      box-shadow var(--duration-base);

    &.scrolled {
      background: oklch(from var(--surface-hero) l c h / 0.95);
      backdrop-filter: blur(28px);
      box-shadow: 0 1px 0 oklch(from var(--color-brand-bright) l c h / 0.08);
    }

    /* :has() replaces JS class toggling for open mobile menu */
    &:has(.mobile-menu.open) {
      background: oklch(from var(--surface-hero) l c h / 0.98);
    }
  }

  .nav-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 68px;
    max-width: var(--wrap-max);
    margin: 0 auto;
    padding-inline: var(--wrap-pad);
  }

  .nav-brand {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .logo-hex {
    width: 36px;
    height: 36px;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 800;
    font-size: 17px;
    color: #fff;
    flex-shrink: 0;

    /* GPU-only shadow via ::after */
    position: relative;
    &::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: 0 4px 14px oklch(from var(--color-action) l c h / 0.4);
      opacity: 1;
      transition: opacity var(--duration-fast);
    }
    &:hover::after {
      opacity: 0;
    }
  }

  .nav-name {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 800;
    font-size: 17px;
    color: #fff;
    letter-spacing: -0.01em;
  }

  .nav-sub {
    font-family: "JetBrains Mono", monospace;
    font-size: 9px;
    color: oklch(100% 0 0 / 0.95);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    display: block;
  }

  .nav-links {
    display: flex;
    gap: 2px;

    & a {
      font-size: 13px;
      font-weight: 500;
      color: oklch(100% 0 0 / 0.95);
      padding: 6px 11px;
      border-radius: 7px;

      &:hover,
      &.active {
        color: var(--color-brand-bright);
        background: oklch(from var(--color-brand-bright) l c h / 0.07);
      }
    }
  }

  .nav-right {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .nav-badge {
    font-family: "JetBrains Mono", monospace;
    font-size: 9.5px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-gold);
    background: oklch(from var(--color-gold) l c h / 0.12);
    border: 1px solid oklch(from var(--color-gold) l c h / 0.25);
    padding: 5px 11px;
    border-radius: var(--radius-pill);
    white-space: nowrap;
  }

  .nav-cta {
    font-size: 13px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    padding: 9px 20px;
    border-radius: var(--radius-pill);
    position: relative;
    overflow: hidden;

    /* GPU shadow */
    &::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: var(--shadow-action);
      opacity: 1;
      transition: opacity var(--duration-fast);
    }
    /* Shimmer sweep */
    &::after {
      content: "";
      position: absolute;
      top: 0;
      left: -100%;
      width: 60%;
      height: 100%;
      background: linear-gradient(
        90deg,
        transparent,
        oklch(100% 0 0 / 0.22),
        transparent
      );
      animation: shimmerSweep 2.4s ease-in-out infinite;
      pointer-events: none;
    }
    &:hover {
      translate: 0 -2px;
      &::before {
        opacity: 1.5;
      }
    }
  }

  .ham {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: oklch(100% 0 0 / 0.08);
    border-radius: 8px;
    cursor: pointer;

    & span {
      width: 22px;
      height: 2px;
      background: #fff;
      border-radius: 2px;
    }
    &.open span:nth-child(1) {
      transform: translateY(7px) rotate(45deg);
    }
    &.open span:nth-child(2) {
      opacity: 0;
    }
    &.open span:nth-child(3) {
      transform: translateY(-7px) rotate(-45deg);
    }
  }

  /* Mobile nav: show hamburger and hide desktop links on small screens */
  @media (max-width: 900px) {
    .ham {
      display: flex;
    }
    .nav-links {
      /* Keep nav compact — only as wide as content + small padding so the
         hero remains visible on both sides. */
      width: min(calc(var(--wrap-max) + 48px), calc(100% - 160px));
      max-width: calc(var(--wrap-max) + 48px);
      .nav-cta {
        display: none !important;
      }
      .nav-badge {
        display: none !important;
      }
    }
    .mobile-menu.open {
      display: block;
      pointer-events: all;
    }
  }

  /* Accessibility helpers */
  .sr-only,
  .visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
  }

  .mobile-menu {
    display: none;
    position: fixed;
    top: 106px;
    inset-inline: 0;
    background: oklch(from var(--surface-hero) l c h / 0.97);
    backdrop-filter: blur(24px);
    padding: 20px var(--wrap-pad);
    border-bottom: 1px solid oklch(100% 0 0 / 0.06);
    z-index: 499;
    translate: 0 -10px;
    opacity: 0;
    transition:
      translate var(--duration-base) var(--ease-spring),
      opacity var(--duration-base);
    pointer-events: none;

    &.open {
      translate: 0 0;
      opacity: 1;
      pointer-events: all;

      & li {
        animation: menuItemIn var(--duration-base) var(--ease-spring) both;
      }
      & li:nth-child(1) {
        animation-delay: 0.05s;
      }
      & li:nth-child(2) {
        animation-delay: 0.1s;
      }
      & li:nth-child(3) {
        animation-delay: 0.15s;
      }
      & li:nth-child(4) {
        animation-delay: 0.2s;
      }
      & li:nth-child(5) {
        animation-delay: 0.25s;
      }
      & li:nth-child(6) {
        animation-delay: 0.3s;
      }
      & li:nth-child(7) {
        animation-delay: 0.35s;
      }
      & li:nth-child(8) {
        animation-delay: 0.4s;
      }
      & li:nth-child(9) {
        animation-delay: 0.45s;
      }
    }

    & a {
      font-size: 16px;
      font-weight: 600;
      color: oklch(100% 0 0 / 0.7);
      padding: 10px 0;
      border-bottom: 1px solid oklch(100% 0 0 / 0.05);
      display: block;
      &:hover {
        color: #fff;
      }
    }
  }

  /* ── HERO ── */
  .hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: var(--surface-hero);
    overflow: hidden;
    padding-top: 106px;
    contain: layout style paint;
  }

  .hero-bg-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    opacity: 0;
    transform: scale(1.04);
    transition:
      opacity 0.9s ease-in-out,
      transform 6s ease;
    pointer-events: none;
    will-change: opacity, transform;
  }

  .hero-bg-img.active {
    opacity: 1;
    transform: scale(1);
  }

  /* Liquid water overlay directly on hero for 'flow' effect */
  .hero::before {
    content: "";
    position: absolute;
    inset: 0;
    /* keep water effect below the main dark overlay so text stays readable */
    z-index: 8;
    pointer-events: none;
    opacity: var(--water-opacity, 0.12);
    mix-blend-mode: screen;
    filter: blur(var(--water-blur, 44px)) saturate(125%);
    background-image:
      radial-gradient(
        40% 26% at 8% 18%,
        color-mix(
            in srgb,
            var(--water-color-1, var(--color-action)) 44%,
            transparent
          )
          0%,
        transparent 36%
      ),
      radial-gradient(
        36% 24% at 82% 38%,
        color-mix(
            in srgb,
            var(--water-color-2, var(--color-brand-bright)) 44%,
            transparent
          )
          0%,
        transparent 40%
      ),
      radial-gradient(
        30% 20% at 50% 78%,
        color-mix(
            in srgb,
            var(--water-color-3, var(--color-gold)) 36%,
            transparent
          )
          0%,
        transparent 38%
      );
    background-repeat: no-repeat;
    background-size:
      160% 140%,
      160% 140%,
      180% 160%;
    animation: waterDrift var(--water-duration, 20s) ease-in-out infinite;
    will-change: transform;
  }

  /* Subtle dark overlay to improve contrast between background image
     and hero text. Sits above the water layer but below the content. */
  .hero::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 9;
    pointer-events: none;
    /* Add a left-centered radial dark spot plus vertical fade to protect lower text */
    background-image:
      radial-gradient(
        60% 42% at 22% 56%,
        rgba(6, 12, 18, 0.78) 0%,
        rgba(6, 12, 18, 0.48) 36%,
        rgba(6, 12, 18, 0) 70%
      ),
      linear-gradient(
        180deg,
        rgba(6, 12, 18, 0.6) 0%,
        rgba(6, 12, 18, 0.4) 36%,
        rgba(6, 12, 18, 0.18) 68%,
        rgba(6, 12, 18, 0) 100%
      );
    background-repeat: no-repeat, no-repeat;
    background-size: cover, cover;
    mix-blend-mode: normal;
    transition: opacity var(--duration-base);
  }

  /* Focused dark band behind the left column to increase readability of lower text */
  .hero-inner > div:first-child {
    position: relative;
    z-index: 11;
  }
  .hero-inner > div:first-child::before {
    content: "";
    position: absolute;
    inset: 0 40% 0 0;
    z-index: 10;
    pointer-events: none;
    background: radial-gradient(
      ellipse at 22% 48%,
      rgba(6, 12, 18, 0.78) 0%,
      rgba(6, 12, 18, 0.52) 36%,
      rgba(6, 12, 18, 0) 75%
    );
    filter: blur(18px);
    transition: opacity var(--duration-base);
  }

  .hero-overlay::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(
        oklch(from var(--color-brand-bright) l c h / 0.06) 1px,
        transparent 1px
      ),
      linear-gradient(
        90deg,
        oklch(from var(--color-brand-bright) l c h / 0.06) 1px,
        transparent 1px
      );
    background-size: 40px 40px;
    pointer-events: none;
  }

  .hero-inner {
    position: relative;
    z-index: 10;
    max-width: var(--wrap-max);
    margin: 0 auto;
    padding: 160px var(--wrap-pad) 80px;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 60px;
    align-items: center;

    @media (max-width: 900px) {
      grid-template-columns: 1fr;
      gap: 40px;
      padding: 140px var(--wrap-pad) 60px;
    }
  }

  .hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 24px;
  }

  .hero-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--color-gold);
    animation: beacon 2s infinite;
  }

  .hero-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(44px, 7vw, 96px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.02em;
    color: #fff;
    text-shadow: 0 18px 56px rgba(0, 0, 0, 0.65);
    -webkit-font-smoothing: antialiased;

    & span {
      --gradient-stop-1: var(--color-brand-bright);
      --gradient-stop-2: var(--color-gold);
      background: linear-gradient(
        var(--gradient-angle),
        var(--gradient-stop-1),
        oklch(72% 0.17 140),
        var(--gradient-stop-2)
      );
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      transition:
        --gradient-stop-1 var(--duration-slow),
        --gradient-stop-2 var(--duration-slow);

      &:hover {
        --gradient-stop-1: var(--color-action-light);
        --gradient-stop-2: var(--color-brand-bright);
      }
    }
  }

  .hero-desc {
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.75;
    color: #fff;
    text-shadow: 0 12px 32px rgba(0, 0, 0, 0.6);
    font-weight: 700;
    margin-top: 20px;
    max-width: 560px;
  }

  /* Stronger button contrast when placed on the hero background */
  .hero .btn-glow {
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.58);
  }
  .hero .btn-ow {
    color: #fff;
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
  }

  .hero-actions {
    display: flex;
    gap: 12px;
    margin-top: 32px;
    flex-wrap: wrap;

    @media (max-width: 600px) {
      flex-direction: column;
    }
  }

  /* ── MISSION VISUAL CARD ── */
  .mission-visual {
    background: var(--surface-dark);
    color: oklch(100% 0 0 / 1);
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.12);
    border-radius: var(--radius-lg);
    padding: 28px;
    backdrop-filter: blur(8px);
    position: relative;
    overflow: hidden;
    animation: floatY 5.5s ease-in-out infinite;
    contain: layout style paint;
    will-change: transform;
    box-shadow: var(--shadow-md);
    transition: transform var(--duration-base) var(--ease-spring);

    &::before {
      content: "";
      position: absolute;
      inset-block-start: 0;
      inset-inline: 0;
      height: 3px;
      background: linear-gradient(
        90deg,
        var(--color-action),
        var(--color-gold),
        var(--color-brand-bright),
        var(--color-action-light)
      );
      opacity: 0.95;
    }
    &::after {
      content: "";
      position: absolute;
      bottom: -60px;
      right: -60px;
      width: 180px;
      height: 180px;
      border-radius: 50%;
      background: radial-gradient(
        circle,
        oklch(from var(--color-brand-bright) l c h / 0.06),
        transparent 70%
      );
      pointer-events: none;
    }
  }

  .mv-img {
    width: 100%;
    height: 220px;
    object-fit: contain;
    object-position: center;
    border-radius: 10px;
    margin-bottom: 14px;
    box-shadow: 0 12px 32px oklch(0% 0 0 / 0.45);
    border: 1px solid oklch(from var(--surface-border) l c h / 0.06);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.06),
      oklch(100% 0 0 / 0.02)
    );
  }

  .mv-tagline {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    line-height: 1.35;
    margin-bottom: 10px;

    & em {
      font-style: normal;
      --gradient-stop-1: var(--color-brand-bright);
      --gradient-stop-2: var(--color-gold);
      background: linear-gradient(
        var(--gradient-angle),
        var(--gradient-stop-1),
        var(--gradient-stop-2)
      );
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
  }

  .mv-sub {
    font-size: 13.5px;
    color: oklch(100% 0 0 / 0.9);
    line-height: 1.7;
    margin-bottom: 18px;
    max-width: 480px;
  }

  .mv-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
  }

  .mv-badge {
    font-family: "JetBrains Mono", monospace;
    font-size: 9.5px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-gold);
    background: oklch(from var(--color-gold) l c h / 0.12);
    border: 1px solid oklch(from var(--color-gold) l c h / 0.28);
    padding: 5px 12px;
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);

    &:nth-child(1) {
      animation: tagBob 3.5s ease-in-out infinite;
    }
    &:nth-child(2) {
      animation: tagBob 3.5s ease-in-out 0.6s infinite;
    }
    &:nth-child(3) {
      animation: tagBob 3.5s ease-in-out 1.2s infinite;
    }
    &:nth-child(4) {
      animation: tagBob 3.5s ease-in-out 1.8s infinite;
    }
  }

  /* ── HERO CARD ── */
  .hero-card {
    background: oklch(100% 0 0 / 0.03);
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.15);
    border-radius: var(--radius-lg);
    padding: 30px;
    backdrop-filter: blur(20px);
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      inset-block-start: 0;
      inset-inline: 0;
      height: 2px;
      background: linear-gradient(
        90deg,
        var(--color-action),
        var(--color-gold),
        var(--color-brand-bright),
        var(--color-action-light)
      );
    }

    @media (max-width: 900px) {
      max-width: 480px;
    }
  }

  .hc-label {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: oklch(100% 0 0 / 0.95);
    margin-bottom: 14px;
  }

  .hc-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 6px;
  }

  .hc-sub {
    font-size: 13px;
    color: oklch(100% 0 0 / 0.95);
    line-height: 1.6;
    margin-bottom: 18px;
  }

  .hc-sep {
    .wx-close {
      background: none;
      border: none;
      color: var(--text-ink3);
      cursor: pointer;
      font-size: 13px;
      padding: 6px 8px;
      border-radius: 8px;
      transition:
        background 0.12s,
        color 0.12s;
    }
    .wx-close:hover {
      background: rgba(2, 6, 23, 0.03);
      color: rgba(7, 17, 39, 0.95);
    }
    height: 1px;
    background: oklch(from var(--color-brand-bright) l c h / 0.1);
    margin: 16px 0;
    animation: dividerGlow 3s ease-in-out infinite;
  }

  .mono-block {
    font-family: "JetBrains Mono", monospace;
    font-size: 12px;
    color: oklch(100% 0 0 / 0.95);
    line-height: 2;

    & em {
      color: var(--color-brand-bright);
      font-style: normal;
    }
  }

  .mini-pills {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
    margin-top: 8px;
  }

  .mp {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-gold);
    background: oklch(from var(--color-gold) l c h / 0.12);
    border: 1px solid oklch(from var(--color-gold) l c h / 0.25);
    padding: 4px 11px;
    border-radius: var(--radius-pill);
  }

  /* ── BUTTONS ── */
  .btn-glow {
    font-size: 15px;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    padding: 16px 34px;
    border-radius: var(--radius-pill);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    position: relative;
    overflow: hidden;

    /* Shadow via pseudo — GPU only */
    &::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: 0 22px 64px oklch(from var(--color-action) l c h / 0.36);
      opacity: 1;
      transition: opacity var(--duration-base);
    }
    /* Shimmer sweep */
    &::after {
      content: "";
      position: absolute;
      top: 0;
      left: -100%;
      width: 60%;
      height: 100%;
      background: linear-gradient(
        90deg,
        transparent,
        oklch(100% 0 0 / 0.22),
        transparent
      );
      animation: shimmerSweep 1.8s ease-in-out infinite;
      pointer-events: none;
    }
    &:hover {
      translate: 0 -4px;
      transition-timing-function: var(--ease-spring);
      &::before {
        opacity: 1.8;
      }
    }
  }

  .btn-ghost-dark {
    font-size: 14px;
    font-weight: 600;
    color: oklch(100% 0 0 / 0.75);
    border: 1.5px solid oklch(from var(--color-brand-bright) l c h / 0.25);
    padding: 14px 28px;
    border-radius: var(--radius-pill);
    backdrop-filter: blur(8px);
    background: oklch(from var(--color-brand-bright) l c h / 0.04);

    &:hover {
      border-color: var(--color-brand-bright);
      color: var(--color-brand-bright);
      translate: 0 -3px;
      background: oklch(from var(--color-brand-bright) l c h / 0.08);
      transition-timing-function: var(--ease-spring);
    }
  }

  .btn-white {
    font-size: 15px;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    padding: 14px 32px;
    border-radius: var(--radius-pill);
    position: relative;

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: var(--shadow-action);
      opacity: 1;
      transition: opacity var(--duration-base);
    }
    &:hover {
      translate: 0 -3px;
      transition-timing-function: var(--ease-spring);
      &::before {
        opacity: 1.8;
      }
    }
  }

  .btn-ow {
    font-size: 15px;
    font-weight: 600;
    color: oklch(100% 0 0 / 0.7);
    border: 1.5px solid oklch(100% 0 0 / 0.2);
    padding: 14px 32px;
    border-radius: var(--radius-pill);

    &:hover {
      border-color: var(--color-brand-bright);
      color: var(--color-brand-bright);
      background: oklch(from var(--color-brand-bright) l c h / 0.06);
    }
  }

  /* ── STATS BAR ── */
  .stats-section {
    position: relative;
    z-index: 20;
    padding-bottom: 0;
  }

  .stats-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: linear-gradient(
      135deg,
      oklch(14% 0.05 152),
      oklch(10% 0.04 152)
    );
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.12);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow:
      0 24px 64px oklch(from var(--surface-hero) l c h / 0.7),
      0 0 0 1px oklch(from var(--color-brand-bright) l c h / 0.06);
    margin-inline: var(--wrap-pad);
    translate: 0 -36px;
    contain: layout style paint;

    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  .si {
    padding: 28px 20px;
    text-align: center;
    border-right: 1px solid oklch(from var(--color-brand-bright) l c h / 0.08);
    position: relative;

    &:last-child {
      border-right: none;
    }

    &::before {
      content: "";
      position: absolute;
      inset-block-start: 0;
      inset-inline: 0;
      height: 2px;
      background: linear-gradient(
        90deg,
        var(--color-action),
        var(--color-gold)
      );
      scale: 1 0;
      transform-origin: left;
      transition: scale var(--duration-slow) var(--ease-spring);
    }

    &:hover {
      background: oklch(from var(--color-action) l c h / 0.04);
      &::before {
        scale: 1;
      }
    }
  }

  .si-num {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(24px, 3vw, 38px);
    font-weight: 800;
    color: var(--color-brand-bright);
    line-height: 1;
    display: block;
    /* Removed will-change — not animated */
  }

  .si-lbl {
    font-size: 12px;
    color: oklch(100% 0 0 / 0.95);
    margin-top: 5px;
    font-weight: 500;
    font-family: "JetBrains Mono", monospace;
    letter-spacing: 0.05em;
  }

  /* ── SECTION HEADERS ── */
  .sec-header {
    margin-bottom: clamp(36px, 4vw, 60px);

    &.center {
      text-align: center;
      & .lead {
        margin-inline: auto;
      }
    }
  }

  /* ── ABOUT BANNER ── */
  .badge-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 28px;
  }

  .bp {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-ink2);
    background: var(--surface-off);
    border: 1.5px solid var(--surface-border);
    padding: 6px 14px;
    border-radius: var(--radius-pill);

    &:hover {
      border-color: var(--color-action);
      color: var(--color-action);
    }
  }

  .about-banner {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;

    /* GPU shadow */
    &::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: var(--shadow-lg);
      opacity: 1;
      transition: opacity var(--duration-base);
      pointer-events: none;
      z-index: 1;
    }

    &:hover .about-banner-img {
      transform: scale(1.04);
    }
  }

  .about-banner-img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    display: block;
    transition: transform var(--duration-slow) var(--ease-in-out);
    will-change: transform;
  }

  .about-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      to top,
      oklch(from var(--surface-hero) l c h / 0.95) 45%,
      oklch(from var(--surface-hero) l c h / 0.25) 100%
    );
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 28px;
  }

  .ab-label {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 10px;
  }

  .ab-text {
    font-size: 15px;
    line-height: 1.75;
    color: oklch(100% 0 0 / 0.88);
    margin-bottom: 16px;
    & strong {
      color: #fff;
      font-weight: 700;
    }
  }

  .ab-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
  }

  .ab-badge {
    font-family: "JetBrains Mono", monospace;
    font-size: 9.5px;
    font-weight: 600;
    letter-spacing: 0.09em;
    color: var(--color-gold);
    background: oklch(from var(--color-gold) l c h / 0.14);
    border: 1px solid oklch(from var(--color-gold) l c h / 0.3);
    padding: 4px 11px;
    border-radius: var(--radius-pill);
  }

  /* ── GALLERY ── */
  .gallery-collage {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 20px;
  }

  .gallery-thumb {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 1;
    background: var(--surface-soft);

    & img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform var(--duration-slow) var(--ease-in-out);
      display: block;
      will-change: transform;
    }
    &:hover img {
      transform: scale(1.1);
    }

    &::after {
      content: "";
      position: absolute;
      inset: 0;
      background: oklch(from var(--color-action) l c h / 0.55);
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      transition: opacity var(--duration-fast);
    }
    &:hover::after {
      opacity: 1;
    }
  }

  /* Lightbox */
  #lightbox {
    position: fixed;
    inset: 0;
    background: oklch(0% 0 0 / 0.92);
    z-index: 9000;
    display: none;
    align-items: center;
    justify-content: center;

    &.open {
      display: flex;
    }
  }

  .lb-inner {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;

    & img {
      max-width: 90vw;
      max-height: 85vh;
      object-fit: contain;
      border-radius: 10px;
    }
  }

  .lb-close {
    position: absolute;
    top: -14px;
    right: -14px;
    width: 36px;
    height: 36px;
    background: #fff;
    color: #000;
    border-radius: 50%;
    font-size: 18px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 1;

    @media (max-width: 500px) {
      position: fixed;
      top: 14px !important;
      right: 14px !important;
      z-index: 9100;
    }
  }

  .lb-prev,
  .lb-next {
    position: fixed;
    top: 50%;
    translate: 0 -50%;
    background: oklch(100% 0 0 / 0.12);
    border: 1.5px solid oklch(100% 0 0 / 0.2);
    color: #fff;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9001;
    &:hover {
      background: oklch(100% 0 0 / 0.25);
    }
  }
  .lb-prev {
    left: 16px;
  }
  .lb-next {
    right: 16px;
  }

  /* ── FOCUS AREAS ── */
  .focus {
    background: linear-gradient(
      180deg,
      var(--surface-off),
      oklch(97% 0.01 152 / 1)
    );
    padding-block: clamp(36px, 6vw, 72px);
  }

  .f-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    align-items: start;

    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr;
    }
  }

  .fc {
    background: linear-gradient(
      180deg,
      var(--surface-white),
      var(--surface-off)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: calc(var(--radius-lg) + 6px);
    padding: clamp(20px, 2.5vw, 32px);
    position: relative;
    overflow: visible;
    transition:
      transform var(--duration-base),
      box-shadow var(--duration-base),
      border-color var(--duration-base);
    box-shadow: 0 18px 48px oklch(10% 0.02 152 / 0.06);

    &::before {
      content: "";
      position: absolute;
      top: 20px;
      bottom: 20px;
      left: 18px;
      width: 8px;
      border-radius: 8px;
      background: linear-gradient(
        180deg,
        var(--color-action),
        var(--color-gold)
      );
      transform: translateX(-8px);
      transition:
        transform var(--duration-base) var(--ease-spring),
        opacity var(--duration-fast);
      opacity: 0.95;
    }

    &:hover,
    &:focus-within {
      transform: translateY(-8px) scale(1.01);
      box-shadow: 0 28px 84px oklch(10% 0.02 152 / 0.12);
      border-color: oklch(from var(--color-action) l c h / 0.18);
      &::before {
        transform: translateX(0);
      }
      & .fc-title {
        color: var(--color-action);
      }
      & .fc-icon {
        transform: rotate(-6deg) scale(1.05);
      }
    }
    &:focus-visible {
      outline: none;
      box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
      transform: translateY(-6px);
    }
  }

  .fc-icon {
    width: 64px;
    height: 64px;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-brand-bright),
      var(--color-action)
    );
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    margin-bottom: 18px;
    transition:
      transform var(--duration-base) var(--ease-spring),
      background var(--duration-base);
    box-shadow: 0 12px 30px oklch(from var(--color-brand-bright) l c h / 0.12);
    color: #fff;
  }

  .fc-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: var(--text-ink);
    margin-bottom: 12px;
  }

  .fc-desc {
    font-size: 15px;
    line-height: 1.72;
    color: var(--text-ink3);
  }

  /* ── SERVICES (modern card grid) ── */
  .svc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
    align-items: stretch;
    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr;
    }
  }

  .sc {
    background: linear-gradient(
      180deg,
      var(--surface-white),
      var(--surface-off)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: calc(var(--radius-lg) + 6px);
    padding: 28px 26px;
    position: relative;
    overflow: visible;
    cursor: pointer;
    container-type: inline-size;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition:
      transform var(--duration-base),
      box-shadow var(--duration-base),
      border-color var(--duration-base);
    will-change: transform;

    & .sc-bar {
      position: absolute;
      top: 18px;
      bottom: 18px;
      left: 0;
      width: 8px;
      border-radius: 8px;
      background: linear-gradient(
        180deg,
        var(--color-action),
        var(--color-gold)
      );
      box-shadow: 0 10px 30px oklch(from var(--color-action) l c h / 0.08);
      transform: translateX(-6px);
      opacity: 0.9;
      transition:
        transform var(--duration-base) var(--ease-spring),
        opacity var(--duration-fast);
    }

    &:hover,
    &:focus-within {
      transform: translateY(-8px) scale(1.02);
      box-shadow: 0 28px 80px oklch(10% 0.02 152 / 0.12);
      border-color: oklch(from var(--color-action) l c h / 0.18);

      & .sc-bar {
        transform: translateX(0);
        opacity: 1;
      }
      & .st {
        color: var(--color-action);
      }
      & .sl {
        gap: 10px;
        color: var(--color-action);
      }
      & .sl svg {
        transform: translateX(6px);
      }
    }

    &:focus-visible {
      outline: none;
      box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
      transform: translateY(-6px);
    }
  }

  .sn {
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    color: var(--text-ink4);
    margin-bottom: 12px;
    font-weight: 500;
  }
  .sc-emoji {
    width: 72px;
    height: 72px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 34px;
    color: #fff;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-brand-bright),
      var(--color-gold)
    );
    box-shadow: 0 14px 40px oklch(from var(--color-brand-bright) l c h / 0.12);
    margin-bottom: 14px;
  }
  .st {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 700;
    color: var(--text-ink);
    margin-bottom: 10px;
  }
  .sd {
    font-size: 14px;
    line-height: 1.72;
    color: var(--text-ink3);
    margin-bottom: 18px;
    flex: 1 1 auto;
    overflow: hidden;
    display: -webkit-box;
    line-clamp: 5;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    white-space: normal;
  }
  .sl {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-brand-mid);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    & svg {
      transition: transform var(--duration-fast);
    }
  }

  /* ── QUOTE SECTION ── */
  .quote-sec {
    background: linear-gradient(
      135deg,
      var(--color-brand),
      oklch(14% 0.08 152)
    );
    padding: 56px 0;
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(135deg, oklch(10% 0.06 232), oklch(14% 0.04 232)),
        linear-gradient(oklch(100% 0 0 / 0.04) 1px, transparent 1px),
        linear-gradient(90deg, oklch(100% 0 0 / 0.04) 1px, transparent 1px);
      background-size:
        cover,
        48px 48px,
        48px 48px;
    }
  }

  /* ── MAPPING TOOL BANNER ── */
  .mapping-tool-banner {
    position: relative;
    overflow: hidden;
    padding: clamp(48px, 6vw, 84px) 0;
    background: linear-gradient(
      135deg,
      var(--surface-dark),
      oklch(15% 0.08 152)
    );

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(
          circle at 15% 20%,
          oklch(100% 0 0 / 0.08),
          transparent 28%
        ),
        radial-gradient(
          circle at 82% 18%,
          oklch(from var(--color-action) l c h / 0.16),
          transparent 24%
        ),
        linear-gradient(90deg, oklch(100% 0 0 / 0.035) 1px, transparent 1px),
        linear-gradient(180deg, oklch(100% 0 0 / 0.035) 1px, transparent 1px);
      background-size:
        auto,
        auto,
        44px 44px,
        44px 44px;
      opacity: 0.9;
      pointer-events: none;
    }
  }

  .mtb-card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(180px, 0.66fr);
    gap: clamp(18px, 2.6vw, 30px);
    align-items: center;
    padding: clamp(22px, 3.4vw, 38px);
    border-radius: calc(var(--radius-lg) + 10px);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.98),
      oklch(97% 0.01 72 / 0.96)
    );
    border: 1px solid oklch(100% 0 0 / 0.08);
    box-shadow: 0 28px 90px oklch(0% 0 0 / 0.22);
    isolation: isolate;

    &::after {
      content: "";
      position: absolute;
      right: -64px;
      bottom: -72px;
      width: 220px;
      height: 220px;
      border-radius: 50%;
      background: radial-gradient(
        circle,
        oklch(from var(--color-action) l c h / 0.12),
        transparent 64%
      );
      filter: blur(10px);
      pointer-events: none;
      z-index: -1;
    }

    @media (max-width: 960px) {
      grid-template-columns: 1fr;
    }
  }

  .mtb-copy {
    position: relative;
    z-index: 1;
    max-width: 660px;
  }

  .mtb-emoji {
    font-size: 24px;
    line-height: 1;
    margin-bottom: 12px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: var(--color-brand-surface);
    border: 1px solid oklch(from var(--color-brand) l c h / 0.12);
    box-shadow: 0 10px 26px oklch(from var(--color-brand) l c h / 0.08);
  }

  .mtb-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 800;
    line-height: 1.06;
    letter-spacing: -0.03em;
    color: var(--surface-dark);
    margin-bottom: 12px;
  }

  .mtb-desc {
    font-size: clamp(15px, 1.35vw, 18px);
    line-height: 1.75;
    color: var(--text-ink3);
    max-width: 64ch;
    margin-bottom: 20px;
  }

  .mtb-features {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;

    & li {
      font-family: "JetBrains Mono", monospace;
      font-size: 10.5px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--color-brand);
      background: var(--color-brand-surface);
      border: 1px solid oklch(from var(--color-brand) l c h / 0.12);
      padding: 10px 14px;
      border-radius: var(--radius-pill);
    }
  }

  .mtb-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
  }

  .mtb-meta-item {
    min-width: 180px;
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--surface-off);
    border: 1px solid var(--surface-border);
    box-shadow: 0 8px 24px oklch(10% 0.02 152 / 0.05);

    strong {
      display: block;
      font-family: "Plus Jakarta Sans", sans-serif;
      font-size: 14px;
      font-weight: 800;
      color: var(--text-ink);
      margin-bottom: 4px;
    }

    span {
      display: block;
      font-size: 12px;
      line-height: 1.55;
      color: var(--text-ink4);
    }
  }

  .mtb-visual {
    position: relative;
    min-height: 220px;
    width: min(100%, 320px);
    justify-self: end;
    border-radius: 24px;
    background: linear-gradient(
      145deg,
      var(--surface-dark),
      var(--color-brand)
    );
    overflow: hidden;
    display: grid;
    place-items: center;
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.12);

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, oklch(100% 0 0 / 0.06) 1px, transparent 1px),
        linear-gradient(180deg, oklch(100% 0 0 / 0.06) 1px, transparent 1px),
        radial-gradient(
          circle at 18% 20%,
          oklch(100% 0 0 / 0.12),
          transparent 18%
        ),
        radial-gradient(
          circle at 82% 78%,
          oklch(100% 0 0 / 0.1),
          transparent 18%
        );
      background-size:
        40px 40px,
        40px 40px,
        auto,
        auto;
      opacity: 0.8;
    }
  }

  .mtb-orb {
    position: relative;
    width: min(100%, 210px);
    aspect-ratio: 1;
    border-radius: 50%;
    background:
      radial-gradient(
        circle at 35% 30%,
        oklch(100% 0 0 / 0.2),
        transparent 28%
      ),
      radial-gradient(
        circle at center,
        oklch(from var(--color-action) l c h / 0.18),
        transparent 62%
      ),
      radial-gradient(
        circle at 50% 50%,
        oklch(100% 0 0 / 0.05),
        transparent 68%
      );
    border: 1px solid oklch(100% 0 0 / 0.14);
    box-shadow:
      inset 0 0 0 1px oklch(100% 0 0 / 0.06),
      0 24px 54px oklch(0% 0 0 / 0.22);
    backdrop-filter: blur(8px);
  }

  .mtb-orb-ring {
    position: absolute;
    inset: 50%;
    border-radius: 50%;
    border: 1px solid oklch(100% 0 0 / 0.14);
    transform: translate(-50%, -50%);
  }

  .mtb-orb-ring-one {
    width: 72%;
    height: 72%;
  }

  .mtb-orb-ring-two {
    width: 44%;
    height: 44%;
    border-color: oklch(100% 0 0 / 0.18);
  }

  .mtb-orb-chip {
    position: absolute;
    padding: 8px 12px;
    border-radius: var(--radius-pill);
    font-family: "JetBrains Mono", monospace;
    font-size: 9.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #fff;
    background: oklch(100% 0 0 / 0.08);
    border: 1px solid oklch(100% 0 0 / 0.12);
    backdrop-filter: blur(12px);
    box-shadow: 0 12px 28px oklch(0% 0 0 / 0.16);
  }

  .mtb-orb-chip-top {
    top: 12%;
    left: 50%;
    transform: translateX(-50%);
  }

  .mtb-orb-chip-left {
    left: -4%;
    top: 50%;
    transform: translateY(-50%);
  }

  .mtb-orb-chip-right {
    right: -6%;
    top: 52%;
    transform: translateY(-50%);
  }

  .mtb-orb-chip-bottom {
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
  }

  .mtb-btn {
    justify-self: start;
    align-self: start;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 22px;
    border-radius: var(--radius-pill);
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(
      135deg,
      var(--color-action),
      var(--color-brand-mid)
    );
    box-shadow: 0 18px 40px oklch(from var(--color-action) l c h / 0.24);
    border: 1px solid oklch(100% 0 0 / 0.08);
    transition:
      transform var(--duration-base) var(--ease-spring),
      box-shadow var(--duration-base),
      filter var(--duration-base);

    svg {
      transition: transform var(--duration-base);
    }

    &:hover {
      transform: translateY(-3px);
      box-shadow: 0 24px 50px oklch(from var(--color-action) l c h / 0.3);
      filter: saturate(1.05);

      svg {
        transform: translateX(2px);
      }
    }

    @media (max-width: 960px) {
      justify-self: start;
      margin-top: 6px;
    }
  }

  .quote-wrap {
    max-width: 980px;
    margin: 0 auto;
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.98),
      oklch(98% 0.01 72 / 0.96)
    );
    border-radius: calc(var(--radius-lg) + 8px);
    padding: 32px 36px;
    box-shadow: 0 28px 80px oklch(10% 0.02 152 / 0.12);
    text-align: center;
    display: grid;
    gap: 10px;
    align-items: center;
    position: relative;
  }

  .qt {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(20px, 3vw, 32px);
    font-weight: 800;
    color: var(--surface-dark);
    letter-spacing: -0.02em;
    line-height: 1.25;
    max-width: 820px;

    & em {
      font-style: normal;
      --gradient-stop-1: var(--color-gold);
      --gradient-stop-2: var(--color-action-light);
      background: linear-gradient(
        var(--gradient-angle),
        var(--gradient-stop-1),
        var(--gradient-stop-2)
      );
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
  }

  .qa {
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    color: oklch(100% 0 0 / 0.95);
    letter-spacing: 0.15em;
    text-transform: uppercase;
  }

  /* ── COURSES ── */
  .courses {
    background: var(--surface-soft);
  }

  .filter-bar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-block: 36px;
    align-items: center;
  }

  .filter-pill {
    font-family: "JetBrains Mono", monospace;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--text-ink3);
    background: var(--surface-white);
    border: 1.5px solid var(--surface-border);
    padding: 9px 18px;
    border-radius: var(--radius-pill);
    cursor: pointer;
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;

    & span {
      position: relative;
      z-index: 1;
    }

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(
        var(--gradient-angle),
        var(--color-action),
        var(--color-action-light)
      );
      scale: 0 1;
      transition: scale var(--duration-fast) var(--ease-spring);
      transform-origin: left;
    }

    &.active,
    &:hover {
      color: #fff;
      border-color: var(--color-action);
      &::before {
        scale: 1;
      }
    }
  }

  .course-count {
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    color: var(--text-ink4);
    margin-left: auto;
    letter-spacing: 0.05em;
  }
  .co-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    align-items: stretch;
    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr;
    }
  }

  .cc {
    background: linear-gradient(
      180deg,
      var(--surface-white),
      var(--surface-off)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: calc(var(--radius-lg) + 6px);
    padding: 26px;
    position: relative;
    overflow: visible;
    display: flex;
    flex-direction: column;
    min-height: 320px;
    transition:
      transform var(--duration-base),
      box-shadow var(--duration-base),
      border-color var(--duration-base);
    will-change: transform;

    &:hover,
    &:focus-within {
      transform: translateY(-8px) scale(1.01);
      box-shadow: 0 28px 80px oklch(10% 0.02 152 / 0.12);
      border-color: oklch(from var(--color-action) l c h / 0.16);
    }

    &.hidden,
    &.pager-hidden {
      display: none !important;
    }

    & .cc-corner {
      position: absolute;
      top: 0;
      right: 0;
      width: 0;
      height: 0;
      border-left: 36px solid transparent;
      border-top: 36px solid oklch(from var(--color-brand-bright) l c h / 0.14);
      transition: border-top-color var(--duration-fast);
    }
    &:hover .cc-corner {
      border-top-color: oklch(from var(--color-action) l c h / 0.18);
    }
    &:hover .cl {
      gap: 9px;
      color: var(--color-action);
    }
    &:focus-visible {
      outline: none;
      box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
    }
  }

  .cd-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-action);
    background: oklch(from var(--color-action) l c h / 0.06);
    border: 1px solid oklch(from var(--color-action) l c h / 0.12);
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    margin-bottom: 16px;
  }

  .ct {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 800;
    color: var(--ink);
    margin-bottom: 6px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .cx {
    font-size: 14px;
    line-height: 1.72;
    color: var(--text-ink3);
    margin-bottom: 18px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .cc-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 16px;
    border-top: 1px solid oklch(from var(--color-brand-bright) l c h / 0.04);
    gap: 12px;
    margin-top: auto;
  }

  .cl {
    font-size: 14px;
    font-weight: 800;
    color: var(--color-brand-mid);
    display: inline-flex;
    align-items: center;
    gap: 6px;
  }
  .cc-tag {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    color: var(--text-ink4);
    padding: 4px 10px;
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: var(--radius-pill);
    max-width: 48%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-shrink: 0;
  }

  /* ── PROJECTS ── */
  #projects {
    background: var(--surface-off);
  }

  .proj-sub-label {
    font-family: "JetBrains Mono", monospace;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-action);
    border-left: 3px solid var(--color-action);
    padding-left: 14px;
    margin: 44px 0 22px;
    display: flex;
    align-items: center;
    gap: 10px;
    & svg {
      opacity: 0.6;
    }
    &:first-of-type {
      margin-top: 8px;
    }
  }

  .research-grid .pj-vis {
    background: linear-gradient(
      135deg,
      oklch(20% 0.08 232),
      oklch(34% 0.14 232)
    ) !important;
  }

  .pj-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
    container-type: inline-size;
    align-items: stretch;
    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr;
    }
  }

  .pjc {
    background: linear-gradient(
      180deg,
      var(--surface-white),
      var(--surface-soft)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: calc(var(--radius-lg) + 6px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 420px;
    transition:
      transform var(--duration-base),
      box-shadow var(--duration-base),
      border-color var(--duration-base);
    will-change: transform;

    &.pager-hidden {
      display: none !important;
    }

    &:hover,
    &:focus-within {
      transform: translateY(-8px) scale(1.01);
      box-shadow: 0 30px 90px oklch(10% 0.02 152 / 0.1);
      border-color: oklch(from var(--color-action) l c h / 0.16);
    }

    &:hover .pj-vis {
      transform: scale(1.06);
    }
    &:focus-visible {
      outline: none;
      box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.06);
    }
  }

  .pj-vis {
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    position: relative;
    overflow: hidden;
    transition:
      transform var(--duration-slow) var(--ease-in-out),
      filter var(--duration-base);
    will-change: transform, filter;
    background: linear-gradient(
      135deg,
      oklch(95% 0 232 / 0.035),
      transparent 80%
    );
  }

  .pj-vis-grid {
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(oklch(100% 0 0 / 0.08) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.08) 1px, transparent 1px);
    background-size: 24px 24px;
    opacity: 0.45;
  }

  .pj-vis-pulse,
  .pj-vis-pulse2 {
    position: absolute;
    border-radius: 50%;
    border: 1.5px solid oklch(from var(--color-brand) l c h / 0.14);
    animation: ripple 2.6s infinite;
  }
  .pj-vis-pulse {
    width: 64px;
    height: 64px;
  }
  .pj-vis-pulse2 {
    animation-delay: 0.8s;
    width: 100px;
    height: 100px;
  }

  .pj-body {
    padding: 22px;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .pj-tag {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-action);
    margin-bottom: 8px;
  }
  .pj-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 17px;
    font-weight: 700;
    color: var(--text-ink);
    margin-bottom: 7px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: anywhere;
  }
  .pj-desc {
    font-size: 13px;
    line-height: 1.72;
    color: var(--text-ink3);
    margin-bottom: 14px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: anywhere;
  }
  .pj-link {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-brand-mid);
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-top: auto;
  }

  /* ── INTERN SHOWCASE CAROUSEL ── */
  .sic-carousel-wrap {
    position: relative;
    overflow: hidden;
    margin: 0 -4px;
    margin-bottom: 36px;
  }
  .sic-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 18px;
    margin-bottom: 36px;
    align-items: stretch;

    @media (max-width: 900px) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr;
    }
  }

  .sic-track {
    display: flex;
    gap: 18px;
    transition: transform var(--duration-slow) var(--ease-in-out);
    will-change: transform;
    padding: 6px 4px 8px;
  }

  .sic {
    background: linear-gradient(
      180deg,
      var(--surface-white),
      var(--surface-off)
    );
    border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
    border-radius: calc(var(--radius-lg) + 6px);
    overflow: hidden;
    position: relative;
    text-align: left;
    contain: layout style paint;
    display: flex;
    flex-direction: column;
    min-height: 340px;
    transition:
      transform var(--duration-base),
      box-shadow var(--duration-base),
      border-color var(--duration-base);

    &:hover,
    &:focus-within {
      transform: translateY(-6px);
      box-shadow: 0 24px 72px oklch(10% 0.02 152 / 0.08);
    }

    @media (max-width: 900px) {
      min-height: 320px;
    }
    @media (max-width: 560px) {
      min-height: 300px;
    }
  }

  .sic-img {
    width: 100%;
    height: auto;
    min-height: 140px;
    max-height: 260px;
    object-fit: contain; /* show full image without cropping */
    object-position: center;
    display: block;
    background: oklch(100% 0 0 / 0.04);
    cursor: pointer;
  }

  .sic-body {
    padding: 18px 16px 20px;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .sic-role {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-action);
    margin-bottom: 6px;
  }
  .sic-name {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    font-weight: 800;
    color: var(--text-ink);
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .sic-quote {
    font-size: 13px;
    color: var(--text-ink3);
    line-height: 1.65;
    font-style: italic;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: auto;
  }

  .sic-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 4px 0 28px;
  }
  .sic-dots {
    display: flex;
    gap: 7px;
    align-items: center;
  }
  .sic-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--surface-border2);
    cursor: pointer;
    border: none;
    &.active {
      background: var(--color-action);
      width: 20px;
      border-radius: 4px;
    }
  }
  .sic-arrows {
    display: flex;
    gap: 8px;
  }
  .sic-arr {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1.5px solid var(--surface-border2);
    background: var(--surface-white);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    & svg {
      width: 15px;
      height: 15px;
      stroke: var(--text-ink);
      stroke-width: 2.2;
      fill: none;
    }
    &:hover {
      border-color: var(--color-action);
      background: var(--color-action-surface);
    }
    &:disabled {
      opacity: 0.3;
      cursor: not-allowed;
    }
  }

  .verify-row {
    text-align: center;
    margin-top: 16px;
  }

  .btn-verify {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    padding: 12px 28px;
    border-radius: var(--radius-pill);
    border: none;
    cursor: pointer;
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: var(--shadow-action);
      opacity: 1;
      transition: opacity var(--duration-fast);
    }
    &:hover {
      translate: 0 -3px;
      transition-timing-function: var(--ease-spring);
      &::before {
        opacity: 1.8;
      }
    }
  }

  /* Verify modal */
  .verify-modal-body {
    padding: 32px 28px;
  }
  .verify-input-wrap {
    display: flex;
    gap: 10px;
    margin-top: 20px;
  }
  .verify-input {
    flex: 1;
    background: var(--surface-soft);
    border: 1.5px solid var(--surface-border);
    border-radius: 9px;
    color: var(--text-ink);
    font-family: "DM Sans", sans-serif;
    font-size: 14px;
    padding: 11px 15px;
    outline: none;
    &:focus {
      border-color: var(--color-action);
    }
  }
  .verify-submit {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: var(--color-action);
    border: none;
    border-radius: 9px;
    padding: 11px 22px;
    cursor: pointer;
    white-space: nowrap;
    &:hover {
      background: var(--color-action-hover);
      translate: 0 -2px;
    }
  }
  .verify-note {
    font-size: 12px;
    color: var(--text-ink4);
    margin-top: 12px;
    font-family: "JetBrains Mono", monospace;
    letter-spacing: 0.04em;
  }

  /* ── JOURNEY / TIMELINE ── */
  .journey {
    background: var(--surface-soft);
  }

  .jrn-grid {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: clamp(32px, 5vw, 80px);
    align-items: start;
    @media (max-width: 900px) {
      grid-template-columns: 1fr;
    }
  }

  .tl {
    position: relative;
    padding-left: 32px;

    &::before {
      content: "";
      position: absolute;
      inset-inline-start: 0;
      inset-block: 8px 0;
      width: 2px;
      background: linear-gradient(
        180deg,
        var(--color-action) 0%,
        var(--color-gold) 50%,
        var(--surface-border) 100%
      );
      border-radius: 2px;
    }
  }

  .tli {
    position: relative;
    margin-bottom: 32px;
    cursor: pointer;

    &:hover .tli-dot {
      background: var(--color-action);
      scale: 1.2;
    }
  }

  .tli-dot {
    position: absolute;
    left: -39px;
    top: 5px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: var(--surface-white);
    border: 2.5px solid var(--color-action);
    animation: tlPulse 2.5s infinite;
  }

  .tli-future .tli-dot {
    border-color: var(--color-brand-mid);
    background: var(--color-brand-surface);
  }
  .tli-date {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 700;
    color: var(--color-action);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 3px;
  }
  .tli-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--color-action-surface);
    border-radius: 7px;
    font-size: 14px;
    margin-bottom: 6px;
    border: 1px solid var(--color-action-border);
  }
  .tli-yr {
    font-family: "JetBrains Mono", monospace;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--color-action);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .tli-future .tli-yr {
    color: var(--color-brand-mid);
  }
  .tli-h {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--text-ink);
    margin-bottom: 5px;
  }
  .tli-b {
    font-size: 14px;
    line-height: 1.7;
    color: var(--text-ink3);
  }

  .vm-stack {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .vmc {
    background: var(--surface-white);
    border: 1px solid var(--surface-border);
    border-radius: var(--radius-lg);
    padding: clamp(24px, 2.5vw, 36px);
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      inset-block-start: 0;
      inset-inline: 0;
      height: 3px;
      background: linear-gradient(
        90deg,
        var(--color-action),
        var(--color-gold),
        var(--color-brand-bright)
      );
    }

    &:hover {
      translate: 0 -3px;
      transition-timing-function: var(--ease-spring);
    }
  }

  .vmc-eye {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-action);
    margin-bottom: 12px;
  }
  .vmc-h {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: var(--text-ink);
    margin-bottom: 10px;
  }
  .vmc-t {
    font-size: 14px;
    line-height: 1.78;
    color: var(--text-ink3);
  }

  /* ── SDG SECTION ── */
  .sdg-sec {
    background: linear-gradient(
      160deg,
      oklch(8% 0.05 152) 0%,
      oklch(14% 0.07 152) 55%,
      oklch(8% 0.04 152) 100%
    );
    padding: var(--section-pad) 0;
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(
          oklch(from var(--color-brand-bright) l c h / 0.04) 1px,
          transparent 1px
        ),
        linear-gradient(
          90deg,
          oklch(from var(--color-brand-bright) l c h / 0.04) 1px,
          transparent 1px
        );
      background-size: 36px 36px;
    }

    &::after {
      content: "";
      position: absolute;
      bottom: -120px;
      left: 50%;
      translate: -50% 0;
      width: 700px;
      height: 350px;
      border-radius: 50%;
      background: radial-gradient(
        ellipse,
        oklch(from var(--color-action) l c h / 0.07),
        transparent 70%
      );
      pointer-events: none;
    }

    & .eyebrow {
      color: var(--color-gold);
      &::before {
        background: var(--color-gold);
      }
    }
    & .h2 {
      color: #fff;
      & em {
        background: linear-gradient(
          135deg,
          var(--color-brand-bright),
          var(--color-gold)
        );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        font-style: normal;
      }
    }
    & .lead {
      color: oklch(100% 0 0 / 0.95);
    }
  }

  .sdg-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    position: relative;
    z-index: 1;
    @media (max-width: 900px) {
      grid-template-columns: repeat(3, 1fr);
    }
    @media (max-width: 600px) {
      grid-template-columns: 1fr 1fr;
    }
  }

  .sgc {
    background: oklch(100% 0 0 / 0.04);
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.12);
    border-radius: var(--radius-md);
    padding: 18px 14px;
    text-align: center;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition:
      transform var(--duration-base) var(--ease-overshoot),
      box-shadow var(--duration-base);

    &::before {
      content: "";
      position: absolute;
      inset-block-start: 0;
      inset-inline: 0;
      height: 2px;
      /* accent uses SDG color where available */
      background: linear-gradient(
        90deg,
        var(--sdg-color, var(--color-brand-bright)) 0%,
        rgba(255, 255, 255, 0.06) 100%
      );
      transform-origin: left;
      transform: scaleX(0);
      transition: transform var(--duration-base) var(--ease-spring);
    }

    &::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      background: linear-gradient(
        120deg,
        var(--sdg-color, rgba(0, 0, 0, 0.06)),
        transparent 55%
      );
      opacity: 0;
      mix-blend-mode: overlay;
      transform: scale(0.98);
      transition:
        opacity 220ms var(--ease-out),
        transform 220ms var(--ease-out);
      border-radius: inherit;
    }

    &:hover {
      transform: translateY(-8px) scale(1.02);
      box-shadow: var(--shadow-lg);
      border-color: var(--sdg-color);
    }
    &:hover::before {
      transform: scaleX(1);
    }
    &:hover::after {
      opacity: 0.14;
      transform: scale(1);
    }
    &:hover .sgt {
      color: #fff;
      font-weight: 800;
    }
    &:hover .sgd {
      color: rgba(255, 255, 255, 0.95);
      font-weight: 600;
    }

    &:focus {
      box-shadow: 0 12px 40px oklch(from var(--color-action) l c h / 0.1);
      outline: none;
      border-color: var(--sdg-color);
    }
  }

  /* short description collapsed, expands when card gets .expanded */
  .sgd {
    font-size: 13px;
    line-height: 1.6;
    color: oklch(100% 0 0 / 0.95);
    max-height: 3.6em;
    overflow: hidden;
    transition: max-height 320ms var(--ease-out);
  }
  .sgc.expanded .sgd {
    max-height: 600px;
  }

  .sgn {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 32px;
    font-weight: 800;
    display: block;
    margin-bottom: 8px;
    color: #fff; /* initial white */
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45);
  }
  .sgt {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 14px;
    font-weight: 700;
    margin: 6px 0 8px;
    color: #fff; /* initial white */
  }

  /* SDG official color map (1..17) — used via attribute selectors */
  .sgc[data-sdg] {
    --sdg-color: var(--color-brand-bright);
  }
  .sgc[data-sdg="1"] {
    --sdg-color: #e5243b;
  }
  .sgc[data-sdg="2"] {
    --sdg-color: #dda63a;
  }
  .sgc[data-sdg="3"] {
    --sdg-color: #4c9f38;
  }
  .sgc[data-sdg="4"] {
    --sdg-color: #c5192d;
  }
  .sgc[data-sdg="5"] {
    --sdg-color: #ff3a21;
  }
  .sgc[data-sdg="6"] {
    --sdg-color: #26bde2;
  }
  .sgc[data-sdg="7"] {
    --sdg-color: #fcc30b;
  }
  .sgc[data-sdg="8"] {
    --sdg-color: #a21942;
  }
  .sgc[data-sdg="9"] {
    --sdg-color: #fd6925;
  }
  .sgc[data-sdg="10"] {
    --sdg-color: #dd1367;
  }
  .sgc[data-sdg="11"] {
    --sdg-color: #fd9d24;
  }
  .sgc[data-sdg="12"] {
    --sdg-color: #bf8b2e;
  }
  .sgc[data-sdg="13"] {
    --sdg-color: #3f7e44;
  }
  .sgc[data-sdg="14"] {
    --sdg-color: #0a97d9;
  }
  .sgc[data-sdg="15"] {
    --sdg-color: #56c02b;
  }
  .sgc[data-sdg="16"] {
    --sdg-color: #00689d;
  }
  .sgc[data-sdg="17"] {
    --sdg-color: #19486a;
  }

  /* apply color to badge/title on hover/active */
  /* initial appearance: white text, then change to SDG color on hover */
  .sgc .sgn {
    color: #fff;
    transition:
      color 220ms var(--ease-out),
      text-shadow 220ms var(--ease-out);
  }
  .sgc .sgt {
    transition:
      color 220ms var(--ease-out),
      font-weight 160ms ease;
  }
  .sgc .sgd {
    color: #fff;
    transition:
      color 220ms var(--ease-out),
      font-weight 160ms ease;
  }

  .sgc:hover .sgn,
  .sgc:focus .sgn {
    color: var(--sdg-color);
    text-shadow: none;
  }
  .sgc:hover .sgt,
  .sgc:focus .sgt {
    color: var(--sdg-color);
    font-weight: 900;
  }
  .sgc:hover .sgd,
  .sgc:focus .sgd {
    color: color-mix(in srgb, var(--sdg-color) 72%, #fff 28%);
    font-weight: 600;
  }

  /* Wave entrance animation for SDG cards */
  @keyframes sdgWave {
    from {
      opacity: 0;
      transform: translateY(18px) scale(0.98);
    }
    to {
      opacity: 1;
      transform: translateY(0) scale(1);
    }
  }
  .sdg-grid .sgc {
    opacity: 0;
    transform: translateY(18px) scale(0.98);
    animation: sdgWave 520ms var(--ease-out) both;
  }
  /* Stagger delays — gentle wave left→right, then next row */
  .sdg-grid .sgc:nth-child(1) {
    animation-delay: 0.04s;
  }
  .sdg-grid .sgc:nth-child(2) {
    animation-delay: 0.08s;
  }

  /* ── SCROLL SCRUB HELPERS ── */
  .reveal {
    --section-progress: 0;
  }
  .sec-header.reveal h1,
  .sec-header.reveal h2,
  .sec-header.reveal h3,
  .reveal .section-title,
  .reveal .section-heading {
    transform: translateY(calc((1 - var(--section-progress)) * 18px));
    opacity: calc(0.94 + var(--section-progress) * 0.06);
    transition:
      transform var(--reveal-duration) var(--reveal-ease),
      opacity var(--reveal-duration) var(--reveal-ease);
    will-change: transform, opacity;
  }
  .sec-header.reveal .lead,
  section.reveal > .lead,
  section.reveal > p {
    transform: translateY(calc((1 - var(--section-progress)) * 12px));
    opacity: calc(0.96 + var(--section-progress) * 0.04);
    transition:
      transform var(--reveal-duration) var(--reveal-ease),
      opacity var(--reveal-duration) var(--reveal-ease);
    will-change: transform, opacity;
  }

  .hero {
    position: relative;
    overflow: hidden;
  }
  .hero .hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: translateY(calc((var(--section-progress) - 0.5) * -24px));
    transition: transform 260ms var(--reveal-ease);
    will-change: transform;
  }
  .hero .hero-content {
    transform: translateZ(calc(var(--section-progress) * 12px))
      translateY(calc((1 - var(--section-progress)) * 8px));
    transition: transform 220ms var(--reveal-ease);
    will-change: transform;
  }

  .sdg-grid .sgc {
    transform: translateY(calc((1 - var(--section-progress)) * 20px))
      scale(calc(0.98 + var(--section-progress) * 0.02));
    opacity: var(--section-progress);
    transition:
      transform 220ms var(--reveal-ease),
      opacity 220ms var(--reveal-ease);
    will-change: transform, opacity;
  }

  [data-parallax] {
    transform: translateY(
      calc((var(--section-progress) - 0.5) * var(--parallax-strength, 18px))
    );
    transition: transform 200ms var(--reveal-ease);
    will-change: transform;
  }

  @media (prefers-reduced-motion: reduce) {
    .reveal {
      --section-progress: 1 !important;
    }
    .hero .hero-bg,
    .hero .hero-content,
    [data-parallax],
    .sdg-grid .sgc {
      transition: none !important;
      transform: none !important;
      opacity: 1 !important;
    }
  }

  /* ── INTERNSHIP SECTION ── */
}
.sdg-grid .sgc:nth-child(4) {
  animation-delay: 0.16s;
}
.sdg-grid .sgc:nth-child(5) {
  animation-delay: 0.2s;
}
.sdg-grid .sgc:nth-child(6) {
  animation-delay: 0.24s;
}
.sdg-grid .sgc:nth-child(7) {
  animation-delay: 0.28s;
}
.sdg-grid .sgc:nth-child(8) {
  animation-delay: 0.32s;
}
.sdg-grid .sgc:nth-child(9) {
  animation-delay: 0.36s;
}
.sdg-grid .sgc:nth-child(10) {
  animation-delay: 0.4s;
}
.sdg-grid .sgc:nth-child(11) {
  animation-delay: 0.44s;
}
.sdg-grid .sgc:nth-child(12) {
  animation-delay: 0.48s;
}
.sdg-grid .sgc:nth-child(13) {
  animation-delay: 0.52s;
}
.sdg-grid .sgc:nth-child(14) {
  animation-delay: 0.56s;
}
.sdg-grid .sgc:nth-child(15) {
  animation-delay: 0.6s;
}
.sdg-grid .sgc:nth-child(16) {
  animation-delay: 0.64s;
}
.sdg-grid .sgc:nth-child(17) {
  animation-delay: 0.68s;
}
.sdg-grid .sgc:nth-child(18) {
  animation-delay: 0.72s;
}
.sdg-grid .sgc:nth-child(19) {
  animation-delay: 0.76s;
}
.sdg-grid .sgc:nth-child(20) {
  animation-delay: 0.8s;
}
/* ── SCROLL REVEAL (global) ── */
:root {
  --reveal-duration: 620ms;
  --reveal-stagger: 0.08s;
  --reveal-ease: cubic-bezier(0.2, 0.9, 0.25, 1);
}

.reveal,
.reveal-left,
.reveal-right {
  opacity: 0;
  transform: translateY(18px) scale(0.995);
  will-change: opacity, transform;
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
.reveal-left {
  transform: translateX(-24px) translateY(10px) scale(0.995);
}
.reveal-right {
  transform: translateX(24px) translateY(10px) scale(0.995);
}
.reveal.on,
.reveal-left.on,
.reveal-right.on {
  opacity: 1;
  transform: none;
}
.reveal .reveal-item,
.reveal > * {
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity 420ms var(--reveal-ease),
    transform 420ms var(--reveal-ease);
  transition-delay: calc(var(--i, 0) * var(--reveal-stagger));
}
.reveal.on .reveal-item,
.reveal.on > * {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal .reveal-item,
  .reveal > * {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}

/* ── INTERNSHIP SECTION ── */
.internship-sec {
  background: var(--surface-white);
  padding: var(--section-pad) 0;
}

.intern-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
  margin-bottom: clamp(48px, 5vw, 80px);
  @media (max-width: 900px) {
    grid-template-columns: 1fr;
  }
}

.intern-intro-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  @media (max-width: 600px) {
    grid-template-columns: 1fr 1fr;
  }
}

.ist-card {
  background: var(--surface-soft);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-md);
  padding: 24px;
  position: relative;
  overflow: hidden;

  &::before {
    content: "";
    position: absolute;
    inset-block-start: 0;
    inset-inline: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-action), var(--color-gold));
  }

  &:hover {
    translate: 0 -3px;
    transition-timing-function: var(--ease-spring);
  }
}

.ist-num {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  color: var(--color-action);
  line-height: 1;
  display: block;
}
.ist-lbl {
  font-size: 13px;
  color: var(--text-ink3);
  margin-top: 5px;
  font-weight: 500;
}

.intern-cards-title {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-ink4);
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--surface-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.intern-filter {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.if-btn {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-ink3);
  background: var(--surface-soft);
  border: 1.5px solid var(--surface-border);
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  &.active,
  &:hover {
    color: var(--color-action);
    border-color: var(--color-action);
    background: var(--color-action-surface);
  }
}

.intern-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  @media (max-width: 900px) {
    grid-template-columns: 1fr 1fr;
  }
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}

.intern-card {
  background: var(--surface-white);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  container-type: inline-size;

  &:hover {
    translate: 0 -6px;
    transition-timing-function: var(--ease-spring);
  }
}

.ic-banner {
  height: 100px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.ic-banner-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(oklch(100% 0 0 / 0.12) 1px, transparent 1px),
    linear-gradient(90deg, oklch(100% 0 0 / 0.12) 1px, transparent 1px);
  background-size: 16px 16px;
}

.ic-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 3px solid oklch(100% 0 0 / 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}

.ic-status {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  display: flex;
  align-items: center;
  gap: 5px;
  &.completed {
    background: oklch(from var(--color-gold) l c h / 0.18);
    color: var(--color-gold);
    border: 1px solid oklch(from var(--color-gold) l c h / 0.3);
  }
  &.active {
    background: oklch(52% 0.12 200 / 0.2);
    color: oklch(70% 0.16 200);
    border: 1px solid oklch(52% 0.12 200 / 0.3);
  }
}

.ic-status-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  .ic-status.active & {
    animation: pulse 1.5s infinite;
  }
}

.ic-body {
  padding: 20px;
}
.ic-name {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 2px;
}
.ic-role {
  font-size: 12.5px;
  color: var(--text-ink3);
  margin-bottom: 14px;
  font-weight: 500;
}
.ic-project-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-ink4);
  margin-bottom: 6px;
}
.ic-project-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-ink);
  margin-bottom: 14px;
  line-height: 1.35;
}
.ic-meta {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 16px;
}
.ic-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--text-ink3);
}
.ic-meta-icon {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--color-action-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}

.ic-cert {
  display: flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(
    135deg,
    var(--color-action-surface),
    var(--color-action-border)
  );
  border: 1px solid var(--color-action-border);
  border-radius: 8px;
  padding: 10px 12px;
  margin-top: 14px;
  background-size: 200% auto;
  animation: certShimmer 3s ease infinite;
}
.ic-cert-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: var(--color-action);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 14px;
  flex-shrink: 0;
}
.ic-cert-text {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-action);
  line-height: 1.3;
}
.ic-cert-sub {
  font-size: 10.5px;
  color: var(--color-action-hover);
  font-weight: 500;
}

.ic-progress {
  margin-top: 14px;
}
.ic-progress-label {
  display: flex;
  justify-content: space-between;
  font-size: 11.5px;
  color: var(--text-ink3);
  margin-bottom: 6px;
}
.ic-progress-bar {
  height: 5px;
  background: var(--surface-border);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.ic-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-action), var(--color-gold));
  border-radius: var(--radius-pill);
  &.animated {
    animation: fillBar 1.4s ease 0.3s both;
  }
}

/* Enhanced CTA cards — visual polish + animations */
.intern-cta-row {
  display: flex;
  gap: clamp(16px, 3vw, 28px);
  margin-top: clamp(32px, 4vw, 56px);
  align-items: stretch;
  flex-wrap: wrap;
  justify-content: center;
  @media (max-width: 900px) {
    flex-direction: column;
    gap: 16px;
  }
}

.intern-cta-card {
  flex: 1;
  min-width: 260px;
  background: linear-gradient(
    180deg,
    var(--surface-white),
    var(--surface-soft)
  );
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
  box-shadow: 0 8px 28px oklch(10% 0.02 152 / 0.06);
  position: relative;
  overflow: visible;
  transform: translateZ(0);
  transition:
    transform var(--duration-base) var(--ease-overshoot),
    box-shadow var(--duration-base),
    border-color var(--duration-base);
  will-change: transform, box-shadow;
  @media (prefers-reduced-motion: no-preference) {
    &.reveal {
      animation: cardPop 520ms var(--ease-out) both;
    }
  }

  &::after {
    content: "";
    position: absolute;
    right: -36px;
    bottom: -36px;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.12),
      transparent 55%
    );
    filter: blur(24px);
    opacity: 0.9;
    pointer-events: none;
    transition:
      transform var(--duration-base),
      opacity var(--duration-base);
  }

  &:hover {
    transform: translateY(-10px) scale(1.01);
    box-shadow: 0 22px 64px oklch(from var(--color-action) l c h / 0.16);
    border-color: oklch(from var(--color-brand-bright) l c h / 0.12);
    @media (prefers-reduced-motion: no-preference) {
      &::after {
        transform: translateY(6px) scale(1.03);
        opacity: 1;
      }
    }
  }

  @media (max-width: 900px) {
    min-width: unset;
    width: 100%;
    padding: 22px;
  }
}

.ictc-icon {
  width: 64px;
  height: 64px;
  border-radius: 14px;
  background: linear-gradient(
    135deg,
    oklch(from var(--color-action) l c h / 0.06),
    oklch(from var(--color-brand-bright) l c h / 0.04)
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  flex-shrink: 0;
  border: 1px solid oklch(from var(--surface-border) l c h / 0.06);
  box-shadow: 0 10px 28px oklch(from var(--color-action) l c h / 0.08);
  transition:
    transform var(--duration-base),
    box-shadow var(--duration-base),
    background var(--duration-base);
}
.intern-cta-card:hover .ictc-icon {
  transform: rotate(-8deg) scale(1.06);
  box-shadow: 0 18px 48px oklch(from var(--color-action) l c h / 0.16);
}

.ictc-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 6px;
}
.ictc-desc {
  font-size: 14px;
  color: var(--text-ink3);
  line-height: 1.65;
  margin-bottom: 14px;
}

.ul-check {
  list-style: none;
  margin-bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  & li {
    font-size: 13px;
    color: var(--text-ink2);
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
    padding-left: 26px;
    transition:
      transform var(--duration-fast),
      color var(--duration-fast);
  }
  & li::before {
    content: "✓";
    font-weight: 800;
    color: #fff;
    font-size: 11px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: inline-grid;
    place-items: center;
    background: linear-gradient(
      180deg,
      var(--color-action),
      var(--color-action-light)
    );
    box-shadow: 0 6px 18px oklch(from var(--color-action) l c h / 0.12);
  }
  & li:hover {
    transform: translateX(6px);
    color: var(--text-ink);
  }
}

/* Card pop animation for reveal */
@keyframes cardPop {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.995);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ── TEAM CAROUSELS ── */
#team {
  background: var(--surface-off);
}

.ts-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-ink4);
  margin: 48px 0 22px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--surface-border);
  display: flex;
  align-items: center;
  gap: 12px;
  &:first-of-type {
    margin-top: clamp(36px, 4vw, 56px);
  }
}

.tm-carousel {
  position: relative;
  overflow: hidden;
  margin: 0 -4px;
}
.tm-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;

  @media (max-width: 900px) {
    grid-template-columns: 1fr 1fr;
  }
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}
.tm-track {
  display: flex;
  gap: 14px;
  transition: transform var(--duration-slow) var(--ease-in-out);
  will-change: transform;
  padding: 4px;

  & .tmc {
    flex: 0 0 calc(33.333% - 10px);
    min-width: 0;
    @media (max-width: 900px) {
      flex: 0 0 calc(50% - 7px);
    }
    @media (max-width: 560px) {
      flex: 0 0 100%;
    }
  }
}

.tm-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
}
.tm-dots {
  display: flex;
  gap: 7px;
  align-items: center;
}
.tm-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--surface-border2);
  cursor: pointer;
  display: block;
  border: 0;
  padding: 0;
  text-decoration: none;
  &.active {
    background: var(--color-action);
    width: 20px;
    border-radius: 4px;
  }
}
.tm-arrows {
  display: flex;
  gap: 8px;
}
.tm-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1.5px solid var(--surface-border2);
  background: var(--surface-white);
  color: var(--text-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  text-decoration: none;
  & svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    stroke-width: 2.2;
    fill: none;
  }
  &:hover {
    border-color: var(--color-action);
    background: var(--color-action-surface);
    scale: 1.08;
  }
  &:disabled {
    opacity: 0.32;
    cursor: not-allowed;
    scale: 1;
  }

  &.is-disabled {
    opacity: 0.32;
    cursor: not-allowed;
    pointer-events: none;
    scale: 1;
  }
}
.tm-counter {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--text-ink4);
  letter-spacing: 0.05em;
}

.cc-empty {
  grid-column: 1 / -1;
  text-align: center;
}

.tmc {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
  border-radius: calc(var(--radius-lg) + 6px);
  padding: 24px;
  position: relative;
  overflow: visible;
  cursor: pointer;
  transition:
    transform var(--duration-base),
    box-shadow var(--duration-base),
    border-color var(--duration-base);
  box-shadow: 0 16px 44px oklch(8% 0.02 230 / 0.06);

  &::before {
    content: "";
    position: absolute;
    top: 18px;
    bottom: 18px;
    left: 0;
    width: 8px;
    border-radius: 8px;
    background: linear-gradient(180deg, var(--color-action), var(--color-gold));
    transform: translateX(-8px);
    transition:
      transform var(--duration-base) var(--ease-spring),
      opacity var(--duration-fast);
    opacity: 0.95;
  }

  &:hover,
  &:focus-within {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 26px 72px oklch(10% 0.02 152 / 0.12);
    border-color: oklch(from var(--color-action) l c h / 0.16);
    & .tm-name {
      color: var(--color-action);
    }
    &::before {
      transform: translateX(0);
    }
  }
}

.tm-av {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  background: linear-gradient(
    135deg,
    oklch(100% 0 0 / 0.04),
    var(--color-action-surface)
  );
  border: 1px solid oklch(from var(--color-action) l c h / 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: var(--color-action);
  margin-bottom: 14px;
  box-shadow: 0 12px 30px oklch(from var(--color-action) l c h / 0.06);
}
.tm-name {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 6px;
}
.tm-role {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-ink3);
}

/* ── BLOG ── */
.blog {
  background: var(--surface-soft);
}

.bl-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  align-items: stretch;
  @media (max-width: 900px) {
    grid-template-columns: 1fr 1fr;
  }
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}

.blc {
  background: var(--surface-white);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 320px;

  @media (max-width: 900px) {
    height: 310px;
  }

  @media (max-width: 600px) {
    height: 295px;
  }

  &.pager-hidden {
    display: none !important;
  }

  &:hover {
    translate: 0 -5px;
    transition-timing-function: var(--ease-spring);
    & .blc-top {
      background-position: 100% 0;
    }
    & .bl-link {
      gap: 9px;
    }
  }
}

.blc-top {
  height: 6px;
  background: linear-gradient(
    90deg,
    var(--color-action),
    var(--color-gold),
    var(--color-brand-bright)
  );
  background-size: 200% auto;
  transition: background-position var(--duration-slow);
}
.blc-body {
  padding: 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.bl-cat {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-action);
  margin-bottom: 11px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.bl-dot-placeholder {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-brand-bright);
}
.bl-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--text-ink);
  line-height: 1.4;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  overflow-wrap: anywhere;
}
.bl-exc {
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-ink3);
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  overflow: hidden;
  text-overflow: ellipsis;
  overflow-wrap: anywhere;
}
.bl-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-action);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: auto;
}
.blog-see-all-wrap {
  text-align: center;
  margin-top: 36px;
}
.btn-see-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-action);
  border: 2px solid var(--color-action);
  padding: 12px 28px;
  border-radius: var(--radius-pill);
  &:hover {
    background: var(--color-action);
    color: #fff;
    translate: 0 -2px;
    transition-timing-function: var(--ease-spring);
  }
}

/* ── TESTIMONIALS ── */
section:has(.te-grid) {
  background: var(--surface-white);
}

.te-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: stretch;
  @media (max-width: 900px) {
    grid-template-columns: 1fr 1fr;
  }
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}

.tec {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
  border-radius: calc(var(--radius-lg) + 6px);
  padding: 30px 28px;
  position: relative;
  overflow: visible;
  display: flex;
  flex-direction: column;
  min-height: 320px;
  height: auto;
  transition:
    transform var(--duration-base),
    box-shadow var(--duration-base),
    border-color var(--duration-base);
  box-shadow: 0 18px 56px oklch(8% 0.02 230 / 0.06);

  &::before {
    content: "";
    position: absolute;
    top: 16px;
    left: 16px;
    right: 16px;
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(
      90deg,
      var(--color-action),
      var(--color-gold),
      var(--color-brand-bright)
    );
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--duration-base) var(--ease-spring);
  }

  &:hover,
  &:focus-within {
    transform: translateY(-8px);
    box-shadow: 0 30px 84px oklch(10% 0.02 152 / 0.12);
    border-color: oklch(from var(--color-action) l c h / 0.16);
    &::before {
      transform: scaleX(1);
    }
  }
}

.te-q-mark {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 88px;
  font-weight: 900;
  color: var(--color-action);
  line-height: 0.78;
  margin-bottom: 14px;
  display: block;
  opacity: 0.42;
  animation: quoteBob 5s ease-in-out infinite;
}
.te-text {
  font-size: 16px;
  line-height: 1.78;
  color: var(--text-ink2);
  font-style: italic;
  margin-bottom: 22px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  line-clamp: 5;
  overflow: hidden;
  text-overflow: ellipsis;
  overflow-wrap: anywhere;
}
.te-auth {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 18px;
  border-top: 1px solid var(--surface-border);
  margin-top: auto;
}
.te-av {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  background: linear-gradient(145deg, var(--surface-white), var(--surface-off));
  border: 2px solid oklch(from var(--color-brand) l c h / 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  font-weight: 900;
  color: var(--text-ink);
  flex-shrink: 0;
  overflow: hidden;
  box-shadow: 0 14px 40px oklch(8% 0.02 230 / 0.08);
}
.te-av img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform-origin: center;
  transition: transform 0.35s var(--ease-spring);
}
.tec:hover .te-av img {
  transform: scale(1.04);
}
@media (max-width: 600px) {
  .te-av {
    width: 48px;
    height: 48px;
    font-size: 14px;
  }
}
.te-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-ink);
}
.te-role {
  font-size: 12px;
  color: var(--text-ink4);
  margin-top: 1px;
}

/* ── NAV: modern white bar ── */
#nav {
  background: var(--surface-white);
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  backdrop-filter: saturate(120%) blur(6px);
  -webkit-backdrop-filter: saturate(120%) blur(6px);
  border-bottom: 1px solid var(--surface-border2);
  transition:
    background var(--duration-fast),
    box-shadow var(--duration-fast),
    transform var(--duration-fast);
}

#nav .nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px var(--wrap-pad);
  max-width: var(--wrap-max);
  margin: 0 auto;
}

#nav .nav-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}
/* Emphasize logo with black border */
#nav .logo {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  overflow: visible;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 18px rgba(2, 8, 23, 0.06);
  border: 3px solid #0b0b0b; /* bold black border to catch the eye */
  background: white;
}
#nav .logo-svg {
  width: 36px;
  height: 36px;
  display: block;
}
#nav .nav-name {
  color: var(--text-ink);
  font-weight: 800;
  letter-spacing: 0.2px;
}
#nav .nav-sub {
  color: green;
  font-size: 12px;
  margin-top: -2px;
}

#nav .nav-links a {
  color: var(--text-ink2);
  font-weight: 600;
  padding: 8px 10px;
  border-radius: 10px;
  transition:
    background var(--duration-base),
    color var(--duration-base);
}
#nav .nav-links a:hover {
  background: var(--surface-soft);
  /*color: var(--text-ink);*/
  color: green;
}
/* Wave highlight effect */
#nav .nav-links a {
  position: relative;
  overflow: visible;
}
#nav .nav-links a::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scaleX(0);
  width: 120%;
  height: 44px;
  background: linear-gradient(
    90deg,
    rgba(2, 132, 199, 0.08),
    rgba(61, 220, 132, 0.06)
  );
  border-radius: 12px;
  transition:
    transform 0.42s var(--ease-spring),
    opacity 0.32s;
  z-index: -1;
  opacity: 0;
}
#nav .nav-links a:hover::after {
  transform: translate(-50%, -50%) scaleX(1);
  opacity: 1;
}
/* Active/keyboard focus state */
#nav .nav-links a.active,
#nav .nav-links a:focus {
  color: var(--text-ink);
  outline: none;
  font-weight: 700;
}

#nav .nav-cta {
  background: linear-gradient(90deg, var(--color-brand), var(--color-action));
  color: #fff;
  border-radius: 12px;
  padding: 10px 14px;
  box-shadow: var(--shadow-sm);
  border: none;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

#nav .nav-badge {
  background: var(--surface-soft);
  border: 1px solid var(--surface-border);
  padding: 6px 8px;
  border-radius: 8px;
  color: var(--text-ink4);
  font-size: 12px;
  margin-right: 6px;
}

#nav .ham span {
  background: var(--text-ink);
}

#nav.scrolled {
  box-shadow: var(--shadow-md);
  background: rgba(255, 255, 255, 0.96);
}

/* Entrance animation for navbar + logo drawing */
#nav {
  opacity: 0;
  transform: translateY(-12px);
  transition:
    transform 620ms cubic-bezier(0.2, 0.9, 0.25, 1),
    opacity 420ms var(--ease-out);
}
#nav.nav-loaded {
  opacity: 1;
  transform: translateY(0);
}

@media (min-width: 900px) {
  /* combine with existing center transform */
  #nav {
    transform: translateX(-50%) translateY(-12px);
  }
  #nav.nav-loaded {
    transform: translateX(-50%) translateY(0);
  }
}

/* Logo SVG stroke draw + leaf reveal */
#nav .logo-svg #aOutline {
  stroke-dasharray: 320;
  stroke-dashoffset: 320;
  transition: stroke-dashoffset 900ms cubic-bezier(0.2, 0.9, 0.25, 1);
}
#nav.nav-loaded .logo-svg #aOutline {
  stroke-dashoffset: 0;
}
#nav .logo-svg #aFill {
  opacity: 0;
  transition: opacity 520ms var(--ease-out) 220ms;
}
#nav.nav-loaded .logo-svg #aFill {
  opacity: 0.9;
}
#nav .logo-svg .leaf {
  opacity: 0;
  transform: translateY(-8px) scale(0.96);
  transition:
    transform 520ms var(--ease-out),
    opacity 420ms var(--ease-out);
}
#nav.nav-loaded .logo-svg .leaf {
  opacity: 1;
  transform: none;
}

/* Ticker highlight pulse when new updates arrive */
.ticker-track.pulse {
  /* pause scrolling briefly and add a gentle uplift to indicate freshness */
  animation-play-state: paused;
  transform: translateZ(0);
}
.ticker-track.pulse .ticker-item {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.04),
    rgba(255, 255, 255, 0.02)
  );
  border-radius: 8px;
  padding: 0 18px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
  transform-origin: center;
  animation: livePop 900ms var(--ease-out) both;
}

/* shimmer overlay that sweeps across the ticker when pulsing */
.ticker-track.pulse::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 60%;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.06) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  transform: translateX(-100%) skewX(-6deg);
  pointer-events: none;
  animation: tickerShimmer 900ms ease-out 1;
  mix-blend-mode: overlay;
}

@keyframes livePop {
  0% {
    transform: translateY(8px) scale(0.98);
    opacity: 0.85;
  }
  50% {
    transform: translateY(-2px) scale(1.03);
    opacity: 1;
  }
  100% {
    transform: translateY(0) scale(1);
    opacity: 1;
    box-shadow: none;
  }
}

@keyframes tickerShimmer {
  0% {
    transform: translateX(-100%) skewX(-6deg);
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  100% {
    transform: translateX(120%) skewX(-6deg);
    opacity: 0;
  }
}

@media (max-width: 900px) {
  #nav .nav-wrap {
    padding: 10px 18px;
  }
  #nav .nav-links {
    display: none;
  }
  #nav .nav-right {
    display: flex;
    align-items: center;
    gap: 10px;
  }
}

/* Float/center small screen nav */
@media (min-width: 900px) {
  #nav {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 160px);
    max-width: calc(var(--wrap-max) + 160px);
    border-radius: 14px;
    top: 18px;
    padding: 6px 0;
    box-shadow: 0 10px 40px rgba(2, 8, 23, 0.06);
    background: rgba(255, 255, 255, 0.96);
    z-index: 200;
  }
  body {
    padding-top: 86px;
  }
}

/* Mobile menu overlay */
.mobile-menu {
  position: fixed;
  left: 0;
  right: 0;
  top: 68px;
  background: var(--surface-white);
  border-top: 1px solid var(--surface-border2);
  box-shadow: 0 12px 40px rgba(18, 24, 31, 0.06);
  z-index: 79;
  max-height: calc(100vh - 68px);
  overflow: auto;
  transform: translateY(-6px);
  opacity: 0;
  visibility: hidden;
  transition:
    transform 0.28s var(--ease-spring),
    opacity 0.2s,
    visibility 0.2s;
}
.mobile-menu.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.mobile-menu ul {
  list-style: none;
  margin: 0;
  padding: 18px var(--wrap-pad);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mobile-menu a {
  display: block;
  padding: 12px 14px;
  border-radius: 10px;
  color: var(--text-ink);
  text-decoration: none;
  font-weight: 700;
}
.mobile-menu a:hover {
  background: var(--surface-soft);
}

/* Hero responsive tweaks */
@media (max-width: 900px) {
  .hero {
    min-height: 64vh;
    padding-top: 84px;
  }
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 64px var(--wrap-pad) 28px;
  }
  .hero-title {
    font-size: clamp(26px, 6.5vw, 40px);
  }
  .hero-desc {
    max-width: 480px;
  }
  .mv-img {
    height: 160px;
    border-radius: 10px;
    object-fit: contain;
  }
}
@media (max-width: 600px) {
  .hero {
    min-height: 56vh;
    padding-top: 72px;
  }
  .hero-inner {
    padding: 56px var(--wrap-pad) 18px;
  }
  .hero-title {
    font-size: clamp(20px, 7vw, 32px);
  }
  .mv-img {
    height: 120px;
  }
  .mobile-menu {
    top: 64px;
    max-height: calc(100vh - 64px);
  }
}

/* ── GET INVOLVED ── */
.involved {
  background: var(--surface-off);
}

.inv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  @media (max-width: 900px) {
    grid-template-columns: 1fr;
  }
}

.invc {
  background: var(--surface-white);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 2.5vw, 36px);
  position: relative;
  overflow: hidden;

  &::after {
    content: "";
    position: absolute;
    inset-block-end: 0;
    inset-inline: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-action), var(--color-gold));
    scale: 0 1;
    transform-origin: left;
    transition: scale var(--duration-base) var(--ease-spring);
  }

  &:hover {
    translate: 0 -5px;
    transition-timing-function: var(--ease-spring);
    background: var(--color-action-surface);
    & .inv-t {
      color: var(--color-action);
    }
    & .inv-ic {
      transform: scale(1.1) rotate(-5deg);
      background: var(--color-action-border);
    }
    &::after {
      scale: 1;
    }
  }
}

.inv-ic {
  width: 52px;
  height: 52px;
  background: var(--color-action-surface);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 18px;
}
.inv-t {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 20px;

  /* Internship showcase images: ensure full image is visible (no cropping) */
  #grid-interns .sic-img {
    width: 100%;
    height: auto !important;
    max-height: 360px;
    object-fit: contain !important;
    object-position: center;
    border-radius: 8px 8px 0 0;
    background-color: var(--surface-off);
  }

  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 9px;
}
.inv-d {
  font-size: 14px;
  line-height: 1.72;
  color: var(--text-ink3);
  margin-bottom: 22px;
}
.inv-btn {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-action);
  border: 1.5px solid var(--color-action);
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  display: inline-block;
  &:hover {
    background: var(--color-action);
    color: #fff;
    translate: 0 -2px;
  }
}

/* ── LOCATIONS ── */
section:has(.loc-grid) {
  background: var(--surface-soft);
}

.loc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  @media (max-width: 900px) {
    grid-template-columns: 1fr;
  }
}

.locc {
  background: var(--surface-white);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
  cursor: pointer;
  transition:
    translate 0.25s var(--ease-spring),
    border-color 0.25s ease,
    background 0.25s ease,
    box-shadow 0.25s ease;

  &:hover {
    background: var(--color-action-surface);
    border-color: var(--color-action-border);
    translate: 0 -3px;
    transition-timing-function: var(--ease-spring);
  }
}
.locc.is-map-active {
  background: linear-gradient(
    135deg,
    oklch(from var(--color-action-surface) l c h / 0.92),
    oklch(99% 0.01 210)
  );
  border-color: var(--color-action-border);
  box-shadow: 0 18px 34px oklch(from var(--color-action) l c h / 0.12);
}
.locc:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 4px oklch(from var(--color-action) l c h / 0.14),
    0 18px 34px oklch(from var(--color-action) l c h / 0.12);
}

.loc-pin {
  width: 48px;
  height: 48px;
  background: var(--color-action-surface);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.loc-type {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-action);
  margin-bottom: 5px;
}
.loc-name {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 4px;
}
.loc-addr {
  font-size: 14px;
  color: var(--text-ink3);
  line-height: 1.6;
}
.loc-coords {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--text-ink4);
  margin-top: 7px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.loc-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-action);
  text-decoration: none;
}
.loc-link:hover {
  text-decoration: underline;
}

/* ── CONTACT ── */
#contact {
  background: var(--surface-off);
}

.ct-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
  @media (max-width: 900px) {
    grid-template-columns: 1fr;
  }
}

.ct-info {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cii {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 18px;
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
  border-radius: calc(var(--radius-md) + 6px);
  box-shadow: 0 12px 36px oklch(8% 0.02 230 / 0.06);
  transition:
    transform var(--duration-base),
    box-shadow var(--duration-base),
    border-color var(--duration-base);
  &:hover {
    transform: translateY(-6px);
    border-color: oklch(from var(--color-action) l c h / 0.16);
    box-shadow: 0 26px 64px oklch(10% 0.02 152 / 0.1);
  }
}

.cii-ic {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(
    145deg,
    var(--color-action),
    var(--color-brand-bright)
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  color: #fff;
  box-shadow: 0 10px 30px oklch(from var(--color-action) l c h / 0.08);
}
.cii-lbl {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-ink4);
  margin-bottom: 3px;
}
.cii-val {
  font-size: 14px;
  color: var(--text-ink2);
  font-weight: 600;
}

.form-wrap {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border: 1px solid oklch(from var(--color-brand) l c h / 0.06);
  border-radius: calc(var(--radius-lg) + 6px);
  padding: clamp(24px, 3vw, 40px);
  box-shadow: 0 18px 56px oklch(8% 0.02 230 / 0.06);

  /* :has() — submit button enhances when form is valid */
  &:has(input:valid) .form-btn {
    box-shadow: var(--shadow-action);
  }
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  @media (max-width: 900px) {
    grid-template-columns: 1fr;
  }
}

.fg {
  margin-bottom: 16px;

  & label {
    display: block;
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    color: var(--text-ink3);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 7px;
  }

  & input,
  & textarea,
  & select {
    width: 100%;
    background: var(--surface-white);
    border: 1.5px solid var(--surface-border);
    border-radius: 9px;
    color: var(--text-ink);
    font-family: "DM Sans", sans-serif;
    font-size: 14px;
    padding: 11px 15px;
    outline: none;
    transition:
      border-color var(--duration-fast),
      box-shadow var(--duration-fast);

    &:focus {
      border-color: var(--color-action);
      box-shadow: 0 0 0 4px oklch(from var(--color-action) l c h / 0.1);
      animation: focusRing var(--duration-slow) ease;
    }
  }

  & textarea {
    height: 110px;
    resize: vertical;
  }
}

.form-btn {
  width: 100%;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(
    var(--gradient-angle),
    var(--color-action),
    var(--color-action-light)
  );
  border: none;
  padding: 15px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  overflow: hidden;

  &::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow: var(--shadow-action);
    opacity: 1;
    transition: opacity var(--duration-base);
  }
  &::after {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 60%;
    height: 100%;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(100% 0 0 / 0.22),
      transparent
    );
    animation: shimmerSweep 2.4s ease-in-out infinite;
    pointer-events: none;
  }
  &:hover {
    translate: 0 -3px;
    transition-timing-function: var(--ease-spring);
    &::before {
      opacity: 1.8;
    }
  }
  &:focus {
    outline: none;
    box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
  }
  &:disabled {
    opacity: 0.7;
    translate: 0;
    cursor: not-allowed;
  }
}

/* ── CTA BANNER ── */
.cta-banner {
  background: linear-gradient(160deg, var(--surface-hero), oklch(14% 0.06 152));
  padding: clamp(60px, 8vw, 100px) 0;
  position: relative;
  overflow: hidden;
  background-size: 200% 200%;
  animation: bgDrift 8s ease infinite;

  &::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      radial-gradient(
        ellipse 70% 70% at 50% 100%,
        oklch(from var(--color-action) l c h / 0.12),
        transparent
      ),
      radial-gradient(
        ellipse 40% 50% at 80% 20%,
        oklch(from var(--color-brand-bright) l c h / 0.08),
        transparent
      );
    background-image:
      linear-gradient(
        oklch(from var(--color-brand-bright) l c h / 0.03) 1px,
        transparent 1px
      ),
      linear-gradient(
        90deg,
        oklch(from var(--color-brand-bright) l c h / 0.03) 1px,
        transparent 1px
      );
    background-size: 40px 40px;
  }
}

.cta-inner {
  position: relative;
  z-index: 1;
  text-align: center;
}
.cta-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(26px, 4.5vw, 56px);
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: 14px;
  & em {
    font-style: normal;
    --gradient-stop-1: var(--color-gold);
    --gradient-stop-2: var(--color-action-light);
    background: linear-gradient(
      var(--gradient-angle),
      var(--gradient-stop-1),
      var(--gradient-stop-2)
    );
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
}
.cta-sub {
  font-size: clamp(14px, 1.2vw, 18px);
  color: oklch(100% 0 0 / 0.95);
  margin-bottom: 36px;
  max-width: 560px;
  margin-inline: auto;
}
.cta-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  @media (max-width: 600px) {
    flex-direction: column;
    align-items: center;
  }
}

/* ── FOOTER ── */
footer {
  background: linear-gradient(160deg, oklch(6% 0.03 152), oklch(8% 0.04 152));
  border-top: 1px solid oklch(from var(--color-brand-bright) l c h / 0.08);
  padding: clamp(48px, 6vw, 72px) 0 28px;
}

.ft-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  margin-bottom: 44px;
  @media (max-width: 1100px) {
    grid-template-columns: 1fr 1fr;
  }
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}

/* Footer newsletter + social */
.ft-news {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ft-news-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ft-news-row {
  display: flex;
  gap: 8px;
}
.ft-news-input {
  flex: 1 1 auto;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid oklch(100% 0 0 / 0.06);
  background: oklch(100% 0 0 / 0.04);
  color: #fff;
  font-size: 14px;
}
.ft-news-input:focus {
  outline: none;
  box-shadow: 0 8px 30px oklch(from var(--color-action) l c h / 0.08);
  border-color: var(--color-action);
}
.ft-news-btn {
  background: linear-gradient(135deg, var(--color-action), var(--color-gold));
  color: #06202a;
  border: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 8px 24px rgba(3, 10, 18, 0.28);
  transition:
    transform 160ms var(--ease-out),
    box-shadow 160ms var(--ease-out);
}
.ft-news-btn:hover {
  transform: translateY(-3px);
}
.ft-news-sub {
  font-size: 12px;
  color: oklch(100% 0 0 / 0.95);
}
.ft-social {
  display: flex;
  gap: 10px;
  margin-top: 8px;
}
.ft-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: oklch(100% 0 0 / 0.03);
  color: #fff;
  transition:
    transform 160ms var(--ease-out),
    background 160ms;
}
.ft-social-link:hover {
  transform: translateY(-4px);
  background: oklch(from var(--color-brand-bright) l c h / 0.14);
}

/* Back to top */
.back-to-top {
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: linear-gradient(
    135deg,
    var(--color-action),
    rgba(255, 255, 255, 0.06)
  );
  color: #06202a;
  box-shadow: 0 12px 36px rgba(3, 10, 18, 0.28);
  display: inline-grid;
  place-items: center;
  font-weight: 800;
  border: none;
  cursor: pointer;
  transform: translateY(12px) scale(0.98);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 240ms var(--ease-out),
    transform 240ms var(--ease-out);
  z-index: 2200;
}
.back-to-top.show {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Footer success message — visible, high-contrast */
.ft-news-success {
  color: #ffffff;
  font-weight: 800;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.03),
    rgba(255, 255, 255, 0.02)
  );
  padding: 10px 12px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 8px 28px rgba(3, 10, 18, 0.28);
}

.ft-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.ft-logo-img {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 8px 30px rgba(3, 10, 18, 0.28);
  border: 2px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
  transition:
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out);
}
.ft-logo-img:focus {
  outline: 3px solid var(--color-action);
  outline-offset: 4px;
  border-radius: 50%;
}
.ft-logo:hover .ft-logo-img {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 14px 40px rgba(3, 10, 18, 0.36);
}
@media (max-width: 600px) {
  .ft-logo-img {
    width: 48px;
    height: 48px;
  }
}
.ft-brand {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 19px;
  font-weight: 800;
  color: #fff;
}
.ft-sub {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.95);
  line-height: 1.65;
  margin-bottom: 18px;
  max-width: 260px;
}
.ft-contact {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.95);
  line-height: 2.1;
  & a {
    color: var(--color-gold);
    opacity: 0.8;
    &:hover {
      opacity: 1;
    }
  }
}
.ft-ct {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-gold);
  opacity: 0.7;
  margin-bottom: 18px;
}
.ft-links {
  & li {
    margin-bottom: 9px;
  }
  & a {
    font-size: 14px;
    color: oklch(100% 0 0 / 0.95);
    display: inline-flex;
    align-items: center;
    &:hover {
      color: var(--color-gold);
      translate: 4px 0;
    }
  }
}
.ft-div {
  height: 1px;
  background: oklch(100% 0 0 / 0.06);
  margin-bottom: 22px;
}
.ft-bot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.ft-copy {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.95);
}
.ft-visitors {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.95);
  margin-left: 12px;
}
.ft-cins {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  color: oklch(100% 0 0 / 0.95);
  letter-spacing: 0.05em;
  text-align: right;
}

/* ── MODALS ── */
.m-overlay {
  position: fixed;
  inset: 0;
  z-index: 3000;
  /* darker, subtle backdrop to focus modal content */
  background: rgba(6, 10, 18, 0.72);
  backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base);

  &.open {
    opacity: 1;
    pointer-events: all;
    & .m-box {
      translate: 0;
      scale: 1;
    }
  }

  @media (max-width: 700px) {
    padding: 8px 12px 70px;
    align-items: flex-start;
    overflow-y: auto;
  }
}

.m-box {
  background: var(--surface-white);
  border-radius: var(--radius-lg);
  width: 100%;
  max-height: calc(var(--real-vh, 1vh) * 92);
  overflow-y: auto;
  position: relative;
  translate: 0 24px;
  scale: 0.97;
  transition:
    translate var(--duration-slow) var(--ease-spring),
    scale var(--duration-slow) var(--ease-spring);

  &.wide {
    max-width: 860px;
  }
  &.slim {
    max-width: 560px;
  }
  &.mid {
    max-width: 700px;
  }

  @media (max-width: 700px) {
    margin-top: 16px;
  }
}
/* Close control: absolute inside modal for consistent layout */
.m-close {
  position: absolute;
  top: 12px;
  right: 12px;
  margin: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--surface-soft);
  border: 1px solid var(--surface-border);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  color: var(--text-ink3);
  z-index: 16;
  transition:
    background-color var(--duration-fast),
    color var(--duration-fast),
    transform var(--duration-fast);
}
.m-close:hover,
.m-close:focus {
  background: var(--color-action-surface);
  color: var(--color-action);
  border-color: var(--color-action-border);
  transform: translateY(-2px);
  outline: none;
}
.m-close:focus-visible {
  box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
}

/* ── EXIT-INTENT POPUP (standalone overlay) ── */
#exitPopup {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(6, 10, 18, 0.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base);
}
#exitPopup.open {
  opacity: 1;
  pointer-events: all;
}
.ep-box {
  width: 100%;
  max-width: 760px;
  background: linear-gradient(
    180deg,
    oklch(100% 0 0 / 0.98),
    oklch(98% 0.01 72 / 0.96)
  );
  border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.06);
  border-radius: calc(var(--radius-lg) + 4px);
  padding: 28px;
  box-shadow: 0 24px 68px oklch(10% 0.02 152 / 0.18);
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(8px) saturate(110%);
}
.ep-top {
  display: flex;
  gap: 16px;
  align-items: center;
}
.ep-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  border: 1px solid var(--surface-border);
  background: linear-gradient(
    135deg,
    oklch(100% 0 0 / 0.06),
    var(--surface-soft)
  );
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}
.ep-emoji {
  font-size: 40px;
  line-height: 1;
}
.ep-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 800;
  color: var(--text-ink);
}
.ep-sub {
  color: var(--text-ink3);
  font-size: 14px;
}
.ep-body {
  margin-top: 14px;
}
.ep-perks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}
.ep-perk {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  color: var(--text-ink2);
}
.ep-perk-icon {
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--surface-off);
  font-size: 18px;
}
.ep-input-row {
  display: flex;
  gap: 10px;
  margin-top: 16px;
}
.ep-input {
  flex: 1;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1.5px solid var(--surface-border);
  background: var(--surface-soft);
  font-size: 14px;
}
.ep-submit {
  padding: 14px 22px;
  border-radius: 12px;
  border: none;
  background: linear-gradient(
    var(--gradient-angle),
    var(--color-action),
    var(--color-gold)
  );
  color: #fff;
  cursor: pointer;
  font-weight: 800;
}
.ep-dismiss {
  display: block;
  margin-top: 12px;
  text-align: center;
  color: var(--text-ink3);
  cursor: pointer;
}
.ep-success {
  display: none;
  padding: 28px;
  text-align: center;
}
.ep-success.show {
  display: block;
}

.m-header {
  padding: 36px 36px 0;
  @media (max-width: 600px) {
    padding: 20px 20px 0;
  }
}
.m-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-action);
  margin-bottom: 10px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  &::before {
    content: "";
    width: 16px;
    height: 1.5px;
    background: var(--color-action);
    flex-shrink: 0;
  }
}
.m-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(20px, 3vw, 30px);
  font-weight: 800;
  color: var(--text-ink);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 8px;
}
.m-sub {
  font-size: 14px;
  color: var(--text-ink3);
  line-height: 1.7;
}
.m-body {
  padding: 24px 36px 36px;
  @media (max-width: 600px) {
    padding: 20px;
  }
}
.m-sep {
  height: 1px;
  background: var(--surface-border);
  margin: 22px 0;
}
.m-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}

.m-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-action);
  background: var(--color-action-surface);
  border: 1px solid var(--color-action-border);
  padding: 5px 13px;
  border-radius: var(--radius-pill);
  margin-bottom: 18px;
}

.m-vis {
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
  border-radius: var(--radius-md);
  position: relative;
  overflow: hidden;
  margin-bottom: 24px;
  @media (max-width: 600px) {
    height: 120px;
    font-size: 36px;
  }
}
.m-vis-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(oklch(100% 0 0 / 0.14) 1px, transparent 1px),
    linear-gradient(90deg, oklch(100% 0 0 / 0.14) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: 0.6;
}

.m-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  margin: 20px 0;
  @media (max-width: 600px) {
    grid-template-columns: repeat(2, 1fr);
  }
}
.m-stat {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.06);
  border-radius: calc(var(--radius-md) + 6px);
  padding: 18px 14px;
  text-align: center;
  box-shadow: 0 12px 36px oklch(8% 0.02 230 / 0.06);
}
.m-stat-num {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 28px;
  font-weight: 900;
  color: var(--color-action);
}
.m-stat-lbl {
  font-size: 11px;
  color: var(--text-ink3);
  margin-top: 3px;
  font-family: "JetBrains Mono", monospace;
  letter-spacing: 0.05em;
}

.m-info-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 11px 0;
  border-bottom: 1px solid var(--surface-border);
  &:last-child {
    border-bottom: none;
  }
}
.m-info-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--color-action-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.m-info-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-ink4);
  margin-bottom: 2px;
}
.m-info-val {
  font-size: 13.5px;
  color: var(--text-ink2);
  font-weight: 600;
}
.m-section-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-ink);
  margin-bottom: 10px;
}
.m-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 8px;
}
.m-pill {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-ink2);
  background: var(--surface-soft);
  border: 1px solid var(--surface-border);
  padding: 5px 13px;
  border-radius: var(--radius-pill);
  &.green {
    color: var(--color-action);
    background: var(--color-action-surface);
    border-color: var(--color-action-border);
  }
}
.m-ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 10px;
  & li {
    font-size: 13.5px;
    color: var(--text-ink2);
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.5;
  }
  & li::before {
    content: "▹";
    color: var(--color-action);
    font-size: 12px;
    margin-top: 1px;
    flex-shrink: 0;
  }
}

.m-cert {
  display: flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(
    135deg,
    var(--color-action-surface),
    var(--color-action-border)
  );
  border: 1px solid var(--color-action-border);
  border-radius: 10px;
  padding: 14px 16px;
  margin-top: 16px;
}
.m-cert-icon {
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: var(--color-action);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.m-cert-text {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-action);
}
.m-cert-sub {
  font-size: 11.5px;
  color: var(--color-action-hover);
}
.m-progress-bar {
  height: 6px;
  background: var(--surface-border);
  border-radius: var(--radius-pill);
  overflow: hidden;
  margin-top: 6px;
}
.m-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-action), var(--color-gold));
  border-radius: var(--radius-pill);
  transition: width 1.2s ease;
}

.m-avatar {
  width: 80px;
  height: 80px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: var(--color-action);
  background: var(--color-action-surface);
  border: 2px solid var(--color-action-border);
  flex-shrink: 0;
  margin-bottom: 14px;
}
.m-leader-bio {
  font-size: 14px;
  line-height: 1.78;
  color: var(--text-ink3);
  margin-top: 12px;
}
.m-expertise-card {
  background: var(--surface-soft);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-md);
  padding: 14px;
}

.intern-view-btn {
  width: 100%;
  margin-top: 14px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--color-action);
  background: var(--color-action-surface);
  border: 1px solid var(--color-action-border);
  padding: 9px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  display: block;
  &:hover {
    background: var(--color-action);
    color: #fff;
  }
}

/* Form modal */
.fm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  @media (max-width: 600px) {
    grid-template-columns: 1fr;
  }
}
.fm-fg {
  margin-bottom: 14px;
  & label {
    display: block;
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    color: var(--text-ink3);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 7px;
  }
  & input,
  & textarea,
  & select {
    width: 100%;
    background: var(--surface-white);
    border: 1.5px solid var(--surface-border);
    border-radius: 9px;
    color: var(--text-ink);
    font-family: "DM Sans", sans-serif;
    font-size: 14px;
    padding: 11px 15px;
    outline: none;
    transition:
      border-color var(--duration-fast),
      box-shadow var(--duration-fast);
    &:focus {
      border-color: var(--color-action);
      box-shadow: 0 0 0 4px oklch(from var(--color-action) l c h / 0.12);
    }
  }
  & textarea {
    height: 100px;
    resize: vertical;
  }
}

.fm-btn {
  width: 100%;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(
    var(--gradient-angle),
    var(--color-action),
    var(--color-action-light)
  );
  border: none;
  padding: 15px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 6px;
  position: relative;
  overflow: hidden;
  &::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow: var(--shadow-action);
    opacity: 1;
    transition: opacity var(--duration-base);
  }
  &:hover {
    translate: 0 -3px;
    transition-timing-function: var(--ease-spring);
    &::before {
      opacity: 1.8;
    }
  }
  &:focus {
    outline: none;
    box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
  }
  &:disabled {
    opacity: 0.7;
    translate: 0;
    cursor: not-allowed;
  }
}

.fm-note {
  font-size: 12px;
  color: var(--text-ink4);
  text-align: center;
  margin-top: 12px;
}

.m-form-header {
  background: linear-gradient(
    135deg,
    var(--surface-forest),
    oklch(28% 0.12 152)
  );
  padding: 32px 36px 28px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  color: #fff;
  position: relative;
  overflow: hidden;
  &::before {
    content: "";
    position: absolute;
    inset-block-start: 0;
    inset-inline: 0;
    height: 3px;
    background: linear-gradient(
      90deg,
      var(--color-action),
      var(--color-gold),
      var(--color-brand-bright)
    );
  }
  &::after {
    content: "";
    position: absolute;
    bottom: -30px;
    right: -30px;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: oklch(100% 0 0 / 0.06);
  }
  & .m-title {
    color: #fff;
  }
  & .m-eyebrow {
    color: oklch(100% 0 0 / 0.7);
    &::before {
      background: oklch(100% 0 0 / 0.5);
    }
  }

  @media (max-width: 600px) {
    padding: 20px;
  }
}
.m-form-body {
  padding: 28px 36px 36px;
  @media (max-width: 600px) {
    padding: 20px;
  }
}

/* Toast */
.toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  translate: -50% 100px;
  background: linear-gradient(
    var(--gradient-angle),
    var(--color-action),
    var(--color-action-light)
  );
  color: #fff;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: var(--radius-pill);
  z-index: 9999;
  transition: translate var(--duration-slow) var(--ease-spring);
  display: flex;
  align-items: center;
  gap: 8px;

  &.show {
    translate: -50% 0;
  }

  @media (max-width: 700px) {
    bottom: 70px;
    left: 16px;
    right: 16px;
    translate: 0 80px;
    border-radius: 12px;
    text-align: center;
    justify-content: center;
    &.show {
      translate: 0 0;
    }
  }
}

/* ── WEATHER WIDGET ── */
#weatherWidget {
  position: fixed;
  bottom: 90px;
  left: 20px;
  z-index: var(--z-popover);
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  border: 1px solid rgba(11, 22, 40, 0.06);
  border-radius: 16px;
  padding: 14px 16px;
  min-width: 240px;
  transition:
    transform 0.18s ease,
    opacity var(--duration-base);
  user-select: none;
  -webkit-user-select: none;
  cursor: grab;
  box-shadow: 0 10px 30px rgba(8, 16, 32, 0.06);
  color: #0b1220;
  overflow: hidden;

  &.dragging {
    cursor: grabbing;
    transform: scale(1.01);
    box-shadow: 0 18px 38px rgba(8, 16, 32, 0.12);
  }
  &.hidden {
    transform: translateY(10px);
    opacity: 0;
    pointer-events: none;
  }

  &::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(180deg, #cbd5e1, #94a3b8);
    border-top-left-radius: 16px;
    border-bottom-left-radius: 16px;
    opacity: 1;
    pointer-events: none;
  }

  @media (max-width: 600px) {
    bottom: 72px;
    left: 10px;
    right: 10px;
    min-width: unset;
  }
}

.wx-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.wx-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #071127;
}
.wx-toggle {
  background: none;
  border: none;
  color: var(--text-ink3);
  cursor: pointer;
  font-size: 14px;
  padding: 4px 6px;
  border-radius: 8px;
  transition:
    background 0.14s,
    color 0.14s;
}
.wx-toggle:hover {
  background: rgba(2, 6, 23, 0.03);
  color: rgba(7, 17, 39, 0.95);
}
.wx-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
}
.wx-tab {
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-ink3);
  background: rgba(2, 6, 23, 0.02);
  border: 1px solid rgba(2, 6, 23, 0.04);
  border-radius: 8px;
  padding: 6px 10px;
  cursor: pointer;
  transition:
    background 0.12s,
    color 0.12s,
    transform 0.12s;
  &.active {
    color: var(--text-ink3);
    background: rgba(2, 6, 23, 0.04);
    border-color: rgba(2, 6, 23, 0.06);
    transform: translateY(-1px);
  }
}
.wx-body {
  display: flex;
  align-items: center;
  gap: 14px;
}
.wx-icon {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  line-height: 1;
  flex-shrink: 0;
  position: relative;
  background: linear-gradient(
    135deg,
    rgba(2, 6, 23, 0.02),
    rgba(2, 6, 23, 0.01)
  );
  box-shadow: 0 6px 14px rgba(11, 22, 40, 0.04);
  color: #071127;
  animation: wxFloat 5s ease-in-out infinite;
}
.wx-icon::after {
  content: "";
  position: absolute;
  width: 110%;
  height: 110%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(
    circle at 30% 30%,
    rgba(255, 255, 255, 0.06),
    transparent 30%
  );
  border-radius: 12px;
  filter: blur(8px);
  opacity: 0.6;
  pointer-events: none;
}
@keyframes wxFloat {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}
.wx-temp {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 34px;
  font-weight: 800;
  color: #071127;
  line-height: 1;
}
.wx-unit {
  font-size: 13px;
  color: var(--text-ink3);
  font-weight: 500;
  margin-left: 6px;
  vertical-align: super;
}
.wx-desc {
  font-size: 12px;
  color: var(--text-ink3);
  margin-top: 4px;
}
.wx-meta {
  display: flex;
  gap: 12px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(2, 6, 23, 0.04);
}
.wx-m {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  color: var(--text-ink3);
  display: flex;
  align-items: center;
  gap: 6px;
}
.wx-m svg {
  opacity: 0.9;
}
.wx-loading {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  color: var(--text-ink3);
  text-align: center;
  padding: 8px 0;
}

/* Reopen pill shown when widget is closed */
#wxReopen {
  position: fixed;
  bottom: 90px;
  left: 20px;
  z-index: 495;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #ffffff;
  border: 1px solid rgba(11, 22, 40, 0.06);
  color: #071127;
  padding: 8px 10px;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(8, 16, 32, 0.06);
  cursor: pointer;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 13px;
}
@media (max-width: 600px) {
  #wxReopen {
    left: 10px;
    bottom: 72px;
  }
}

/* ── Per-state accent colors (left bar & icon tints) ── */
#weatherWidget.wx-sunny::before {
  background: linear-gradient(180deg, #ffd54a, #ffb74d);
}
#weatherWidget.wx-sunny .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(255, 213, 74, 0.12),
    rgba(255, 183, 77, 0.06)
  );
  color: #6b3f00;
}

#weatherWidget.wx-partly::before {
  background: linear-gradient(180deg, #ffd86b, #9ad6ff);
}
#weatherWidget.wx-partly .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(255, 216, 107, 0.1),
    rgba(154, 214, 255, 0.06)
  );
  color: #2b3b4a;
}

#weatherWidget.wx-fog::before {
  background: linear-gradient(180deg, #cbd5e1, #94a3b8);
}
#weatherWidget.wx-fog .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(203, 213, 225, 0.08),
    rgba(148, 163, 184, 0.04)
  );
  color: #23303a;
}

#weatherWidget.wx-drizzle::before {
  background: linear-gradient(180deg, #91e6f4, #58c0d8);
}
#weatherWidget.wx-drizzle .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(145, 230, 244, 0.1),
    rgba(88, 192, 216, 0.06)
  );
  color: #083340;
}

#weatherWidget.wx-rain::before {
  background: linear-gradient(180deg, #7ec8ff, #4fa3f6);
}
#weatherWidget.wx-rain .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(126, 200, 255, 0.12),
    rgba(79, 163, 246, 0.06)
  );
  color: #072a4b;
}

#weatherWidget.wx-showers::before {
  background: linear-gradient(180deg, #80d0ff, #60a5fa);
}
#weatherWidget.wx-showers .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(128, 208, 255, 0.12),
    rgba(96, 165, 250, 0.06)
  );
  color: #08304f;
}

#weatherWidget.wx-snow::before {
  background: linear-gradient(180deg, #e6f7ff, #dbefff);
}
#weatherWidget.wx-snow .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(230, 247, 255, 0.12),
    rgba(219, 238, 255, 0.06)
  );
  color: #2b3b4a;
}

#weatherWidget.wx-thunder::before {
  background: linear-gradient(180deg, #c4b5fd, #7c3aed);
}
#weatherWidget.wx-thunder .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(196, 181, 253, 0.1),
    rgba(124, 58, 237, 0.06)
  );
  color: #2b083b;
}

#weatherWidget.wx-unknown::before {
  background: linear-gradient(180deg, #cbd5e1, #94a3b8);
}
#weatherWidget.wx-unknown .wx-icon {
  background: linear-gradient(
    135deg,
    rgba(203, 213, 225, 0.06),
    rgba(148, 163, 184, 0.03)
  );
  color: #23303a;
}

/* Weather widget — brand theme override and animations */
#weatherWidget {
  background: linear-gradient(
    180deg,
    var(--surface-white),
    color-mix(in srgb, var(--color-brand-surface) 8%, var(--surface-white) 92%)
  );
  border-color: oklch(from var(--color-brand) l c h / 0.12);
  box-shadow: var(--shadow-md);
  color: var(--text-ink2);
}
#weatherWidget::before {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-brand-mid) 28%, var(--surface-white) 72%),
    var(--color-brand-bright)
  );
}
/* apply brand accent regardless of weather state */
#weatherWidget[class*="wx-"]::before {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-brand-mid) 28%, var(--surface-white) 72%),
    var(--color-brand-bright)
  );
}
#weatherWidget[class*="wx-"] .wx-icon {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--color-brand) 14%, #fff 86%),
    color-mix(in srgb, var(--color-brand-mid) 8%, #fff 92%)
  );
  color: var(--surface-white);
  box-shadow: 0 10px 30px oklch(from var(--color-brand) l c h / 0.12);
}
.wx-title {
  color: var(--text-ink2);
}
.wx-tab.active {
  color: var(--color-brand);
  border-color: color-mix(
    in srgb,
    var(--color-brand) 12%,
    var(--surface-white) 88%
  );
  background: color-mix(
    in srgb,
    var(--color-brand-surface) 6%,
    var(--surface-white) 94%
  );
  transform: translateY(-1px);
}

/* Animations: subtle glow and temp pulse */
@keyframes wxPulseShadow {
  0% {
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.04);
  }
  50% {
    box-shadow: 0 18px 46px oklch(from var(--color-brand) l c h / 0.12);
  }
  100% {
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.04);
  }
}
.wx-icon {
  animation:
    wxFloat 5s ease-in-out infinite,
    wxPulseShadow 6.5s ease-in-out infinite;
}
@keyframes tempPulse {
  0%,
  100% {
    transform: scale(1);
    text-shadow: none;
  }
  50% {
    transform: scale(1.02);
    text-shadow: 0 6px 18px oklch(from var(--color-brand) l c h / 0.1);
  }
}
.wx-temp {
  animation: tempPulse 6s ease-in-out infinite;
  transform-origin: center;
  display: inline-block;
}

/* Reopen pill brand style */
#wxReopen {
  background: linear-gradient(
    135deg,
    var(--color-brand),
    var(--color-brand-mid)
  );
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 30px oklch(from var(--color-brand) l c h / 0.12);
}

/* ── CROP CALENDAR ── */
.crop-sec {
  background: var(--surface-white);
  padding: var(--section-pad) 0;
}
.crop-filter {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.crop-pill {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-ink3);
  background: var(--surface-soft);
  border: 1.5px solid var(--surface-border);
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  &.active {
    color: #fff;
    background: var(--color-brand-mid);
    border-color: var(--color-brand-mid);
  }
}
.crop-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--surface-border);
}
.crop-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 700px;
}
.crop-table th {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-ink4);
  background: var(--surface-soft);
  padding: 10px 8px;
  text-align: center;
  border-bottom: 1px solid var(--surface-border);
  border-right: 1px solid var(--surface-border);
  &:first-child {
    text-align: left;
    padding-left: 16px;
    width: 130px;
  }
}
.crop-table td {
  padding: 8px;
  border-right: 1px solid oklch(0% 0 0 / 0.04);
  border-bottom: 1px solid oklch(0% 0 0 / 0.04);
  text-align: center;
  vertical-align: middle;
  &:first-child {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: var(--text-ink);
    padding-left: 16px;
    text-align: left;
    background: var(--surface-white);
    border-right: 1px solid var(--surface-border);
  }
  &:last-child {
    border-bottom: none;
  }
}
.crop-cell {
  width: 100%;
  height: 28px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  letter-spacing: 0.05em;
  &.sow {
    background: linear-gradient(135deg, #bbf7d0, #4ade80);
    color: #065f36;
  }
  &.grow {
    background: linear-gradient(135deg, #bae6fd, #38bdf8);
    color: #0369a1;
  }
  &.harvest {
    background: linear-gradient(135deg, #fef08a, #fbbf24);
    color: #92400e;
  }
  &:not(.idle):hover {
    scale: 1 1.15;
  }
}
.crop-legend {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 16px;
  justify-content: center;
}
.crop-leg {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-ink3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.crop-leg-dot {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  &.sow {
    background: linear-gradient(135deg, #bbf7d0, #4ade80);
  }
  &.grow {
    background: linear-gradient(135deg, #bae6fd, #38bdf8);
  }
  &.harvest {
    background: linear-gradient(135deg, #fef08a, #fbbf24);
  }
}

/* ── MAP SECTION ── */
.map-sec {
  background: var(--surface-soft);
  padding: var(--section-pad) 0;
}
#ahsisMap,
#ahsisGoogleMap {
  height: 420px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--surface-border);
  overflow: hidden;
  z-index: 1;
  position: relative;
  background:
    radial-gradient(circle at top left, oklch(94% 0.04 150), transparent 40%),
    linear-gradient(135deg, oklch(82% 0.08 108), oklch(68% 0.07 194));
  @media (max-width: 700px) {
    height: 280px;
  }
}
.map-embed-shell,
.map-embed-frame {
  width: 100%;
  height: 100%;
}
.map-embed-frame {
  border: 0;
  display: block;
}
.map-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  max-width: min(320px, calc(100% - 32px));
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid oklch(from var(--surface-border) l c h / 0.9);
  background: oklch(100% 0 0 / 0.88);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(14px);
}
.map-badge-kicker {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-action);
  margin-bottom: 4px;
}
.map-badge-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: var(--text-ink);
  margin-bottom: 3px;
}
.map-badge-sub {
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-ink3);
}
.map-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  color: var(--surface-white);
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  line-height: 1.7;
}
.map-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 24px;
  @media (max-width: 700px) {
    grid-template-columns: 1fr;
  }
}

/* ── NEWSLETTER ── */
.newsletter-sec {
  background: linear-gradient(
    135deg,
    oklch(38% 0.18 232),
    oklch(52% 0.22 232),
    oklch(64% 0.2 232)
  );
  padding: clamp(48px, 6vw, 80px) 0;
  position: relative;
  overflow: hidden;
  &::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(oklch(100% 0 0 / 0.06) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.06) 1px, transparent 1px);
    background-size: 32px 32px;
  }
  &::after {
    content: "";
    position: absolute;
    bottom: -80px;
    right: -80px;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: oklch(100% 0 0 / 0.07);
    pointer-events: none;
  }
}
.nl-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
  @media (max-width: 800px) {
    grid-template-columns: 1fr;
  }
}
.nl-badge {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(100% 0 0 / 0.95);
  background: oklch(100% 0 0 / 0.1);
  border: 1px solid oklch(100% 0 0 / 0.2);
  padding: 5px 13px;
  border-radius: var(--radius-pill);
  display: inline-block;
  margin-bottom: 14px;
}
.nl-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(22px, 3.5vw, 38px);
  font-weight: 800;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}
.nl-sub {
  font-size: 15px;
  color: oklch(100% 0 0 / 0.95);
  line-height: 1.7;
}
.nl-perks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 18px;
}
.nl-perk {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: oklch(100% 0 0 / 0.95);
  &::before {
    content: "✓";
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: oklch(100% 0 0 / 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
    color: #fff;
  }
}
.nl-form-box {
  background: oklch(100% 0 0 / 0.1);
  backdrop-filter: blur(20px);
  border: 1px solid oklch(100% 0 0 / 0.2);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 3vw, 36px);
}
.nl-form-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 6px;
}
nl-form-sub {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.95);
  margin-bottom: 20px;
}
.nl-input-wrap {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nl-input {
  background: oklch(100% 0 0 / 0.12);
  border: 1.5px solid oklch(100% 0 0 / 0.2);
  border-radius: 9px;
  color: #fff;
  font-family: "DM Sans", sans-serif;
  font-size: 14px;
  padding: 12px 15px;
  outline: none;
  width: 100%;
  color: black;
  &::placeholder {
    color: oklch(100% 0 0 / 0.75);
  }
  &:focus {
    border-color: oklch(100% 0 0 / 0.6);
    background: oklch(100% 0 0 / 0.18);
  }
}
/* Ensure select inputs show readable (black) option text by default */
select.nl-input {
  color: #000;
}
select.nl-input option {
  color: #000;
}
.nl-btn {
  width: 100%;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--color-action);
  background: #fff;
  border: none;
  border-radius: 9px;
  padding: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  &:hover {
    translate: 0 -2px;
    background: oklch(96% 0.02 232);
    transition-timing-function: var(--ease-spring);
  }
}
.nl-count {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: oklch(100% 0 0 / 0.95);
  margin-top: 14px;
  text-align: center;
  letter-spacing: 0.04em;
}

/* Success panel for newsletter — hidden by default until subscription completes */
.nl-success {
  display: none;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(18px, 2.5vw, 28px);
}
.nl-success-icon {
  font-size: 36px;
  line-height: 1;
}
.nl-success-text {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
}
.nl-success-sub {
  font-size: 13px;
  color: oklch(100% 0 0 / 0.65);
}

/* ── STICKY BAR ── */
#stickyBar {
  position: fixed;
  right: 0;
  top: 50%;
  translate: 0 -50%;
  z-index: var(--z-fixed);
  display: flex;
  flex-direction: column;
  gap: 2px;

  @media (max-width: 700px) {
    top: auto;
    right: 0;
    left: 0;
    bottom: 0;
    flex-direction: row;
    translate: none;
    background: oklch(from var(--surface-hero) l c h / 0.96);
    backdrop-filter: blur(20px);
    border-top: 1px solid oklch(100% 0 0 / 0.08);
    padding: 0;
    gap: 0;
  }
}

.sb-btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
  &:first-child {
    border-radius: 12px 0 0 0;
  }
  &:last-child {
    border-radius: 0 0 0 12px;
  }
  &.wa {
    background: #25d366;
  }
  &.ph {
    background: var(--color-action);
  }
  &.em {
    background: oklch(22% 0.08 232);
  }
  &.eq {
    background: var(--color-brand-mid);
  }
  &:hover {
    width: 56px;
    border-radius: 12px 0 0 12px;
  }

  @media (max-width: 700px) {
    flex: 1;
    height: 54px;
    border-radius: 0 !important;
    font-size: 18px;
    flex-direction: column;
    gap: 3px;
    &:hover {
      width: 100%;
    }
    &::after {
      content: attr(data-label);
      font-family: "JetBrains Mono", monospace;
      font-size: 8px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: oklch(100% 0 0 / 0.6);
    }
  }
}

.sb-label {
  position: absolute;
  right: 48px;
  background: oklch(0% 0 0 / 0.82);
  color: #fff;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 6px 0 0 6px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  &:hover {
    opacity: 1;
  }
  @media (max-width: 700px) {
    display: none;
  }
}

/* ── EXIT POPUP ── */
#exitPopup {
  position: fixed;
  inset: 0;
  z-index: 9100;
  display: flex;
  align-items: center;
  justify-content: center;
  background: oklch(from var(--surface-hero) l c h / 0.7);
  backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base);
  &.open {
    opacity: 1;
    pointer-events: all;
    & .ep-box {
      scale: 1;
    }
  }

  @media (max-width: 500px) {
    align-items: flex-start;
    padding: 54px 10px 70px;
    overflow-y: auto;
  }
}

.ep-box {
  background: #fff;
  border-radius: 24px;
  max-width: 520px;
  width: 90%;
  overflow: hidden;
  scale: 0.94;
  transition: scale var(--duration-slow) var(--ease-spring);
  @media (max-width: 600px) {
    border-radius: 16px;
    width: 100%;
  }
}
.ep-top {
  background: linear-gradient(135deg, oklch(38% 0.18 232), oklch(64% 0.2 232));
  padding: 36px 32px 28px;
  position: relative;
  text-align: center;
  &::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(oklch(100% 0 0 / 0.07) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.07) 1px, transparent 1px);
    background-size: 24px 24px;
  }
  @media (max-width: 500px) {
    padding: 24px 18px 18px;
  }
}
.ep-emoji {
  font-size: 44px;
  display: block;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
}
.ep-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 6px;
  position: relative;
  z-index: 1;
  @media (max-width: 500px) {
    font-size: 18px;
  }
}
.ep-sub {
  font-size: 13.5px;
  color: oklch(100% 0 0 / 0.75);
  position: relative;
  z-index: 1;
}
.ep-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 30px;
  height: 30px;
  background: oklch(100% 0 0 / 0.15);
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  &:hover {
    background: oklch(100% 0 0 / 0.3);
  }
}
.ep-body {
  padding: 28px 32px;
  @media (max-width: 500px) {
    padding: 18px;
  }
}
.ep-perks {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-bottom: 22px;
}
.ep-perk {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--text-ink2);
  @media (max-width: 500px) {
    font-size: 13px;
  }
}
.ep-perk-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--color-action-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.ep-input-row {
  display: flex;
  gap: 9px;
  margin-bottom: 12px;
  @media (max-width: 500px) {
    flex-direction: column;
    gap: 8px;
  }
}
.ep-input {
  flex: 1;
  background: var(--surface-soft);
  border: 1.5px solid var(--surface-border);
  border-radius: 9px;
  color: var(--text-ink);
  font-family: "DM Sans", sans-serif;
  font-size: 14px;
  padding: 11px 14px;
  outline: none;
  &:focus {
    border-color: var(--color-action);
  }
}
.ep-submit {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(
    var(--gradient-angle),
    var(--color-action),
    var(--color-action-light)
  );
  border: none;
  border-radius: 9px;
  padding: 11px 20px;
  cursor: pointer;
  white-space: nowrap;
  &:hover {
    translate: 0 -2px;
    transition-timing-function: var(--ease-spring);
  }
  @media (max-width: 500px) {
    width: 100%;
    padding: 13px;
    text-align: center;
  }
}
.ep-dismiss {
  display: block;
  text-align: center;
  font-size: 12px;
  color: var(--text-ink4);
  cursor: pointer;
  margin-top: 2px;
  &:hover {
    color: var(--text-ink);
  }
}

/* ── NEWS TICKER ── */
.news-ticker-wrap {
  --ticker-height: 48px;
  background: linear-gradient(90deg, #07203a 0%, #0b5a4f 60%, #06b6d4 100%);
  height: var(--ticker-height);
  display: flex;
  align-items: center;
  overflow: hidden;
  position: fixed;
  top: 68px;
  inset-inline: 0;
  z-index: 210;
  padding: 0 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 8px 30px rgba(2, 8, 23, 0.12);
  backdrop-filter: blur(6px) saturate(120%);

  @media (max-width: 600px) {
    height: 44px;
    padding: 0 8px;
  }
}

.ticker-label {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  height: calc(var(--ticker-height) - 12px);
  background: linear-gradient(90deg, #ff4d4f, #ff9833);
  color: #fff;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 8px;
  white-space: nowrap;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  &::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
    animation: pulse 1.6s infinite;
    flex-shrink: 0;
  }
  @media (max-width: 600px) {
    display: none;
  }
}

.ticker-track-outer {
  flex: 1;
  overflow: hidden;
  margin-left: 12px;
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 40px,
    #000 calc(100% - 40px),
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 40px,
    #000 calc(100% - 40px),
    transparent 100%
  );
}

.ticker-track {
  display: flex;
  align-items: center;
  position: relative;
  animation: tickerScroll var(--ticker-duration, 32s) linear infinite;
  width: max-content;
  will-change: transform;
  &:hover {
    animation-play-state: paused;
  }
}

.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  padding: 0 26px;
  & svg {
    opacity: 0.95;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
  }
  @media (max-width: 600px) {
    font-size: 13px;
    padding: 0 16px;
  }
}
.ticker-sep {
  color: rgba(255, 255, 255, 0.28);
  font-size: 12px;
  padding-right: 4px;
}

.ticker-controls {
  flex-shrink: 0;
  margin-left: 12px;
}
.ticker-controls .ticker-btn {
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 8px;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12);
}
.ticker-controls .ticker-btn.paused {
  background: rgba(255, 255, 255, 0.12);
}

@media (prefers-reduced-motion: reduce) {
  .ticker-track {
    animation: none !important;
  }
}

/* ── PARTNERS ── */
.partners-sec {
  background: linear-gradient(
    160deg,
    oklch(8% 0.05 152) 0%,
    oklch(10% 0.04 152) 100%
  );
  padding: clamp(60px, 7vw, 88px) 0;
  overflow: hidden;
  position: relative;
  & .eyebrow {
    color: var(--color-gold);
    &::before {
      background: var(--color-gold);
    }
  }
  & .h2 {
    color: #fff;
    & em {
      background: linear-gradient(
        135deg,
        var(--color-brand-bright),
        var(--color-gold)
      );
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      font-style: normal;
    }
  }
  & .lead {
    color: oklch(100% 0 0 / 0.45);
  }
}

.partner-track-outer {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 80px,
    #000 calc(100% - 80px),
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 80px,
    #000 calc(100% - 80px),
    transparent 100%
  );
}
.partner-track {
  display: flex;
  gap: 18px;
  align-items: center;
  animation: partnerScroll 40s linear infinite;
  width: max-content;
  will-change: transform;
  &:hover {
    animation-play-state: paused;
  }
}

.partner-card {
  background: oklch(100% 0 0 / 0.04);
  border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.08);
  border-radius: calc(var(--radius-md) + 2px);
  padding: 20px 36px;
  margin: 0 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
  height: 92px;
  position: relative;
  overflow: hidden;
  transition:
    transform var(--duration-base),
    box-shadow var(--duration-base);
  &::before {
    content: "";
    position: absolute;
    inset-block-end: 0;
    inset-inline: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--color-action), var(--color-gold));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--duration-base) var(--ease-spring);
  }
  &:hover {
    border-color: oklch(from var(--color-gold) l c h / 0.38);
    transform: translateY(-6px) scale(1.03);
    box-shadow: 0 18px 40px oklch(8% 0.02 230 / 0.06);
    transition-timing-function: var(--ease-spring);
    & .partner-logo-text {
      color: var(--color-gold);
      filter: grayscale(0);
    }
    &::before {
      transform: scaleX(1);
    }
  }
}

.partner-logo-text {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: oklch(100% 0 0 / 0.55);
  letter-spacing: -0.01em;
  text-align: center;
  line-height: 1.3;
  filter: grayscale(1);
}
.partner-badge {
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: oklch(100% 0 0 / 0.4);
  margin-top: 3px;
  display: block;
}

/* Partner logo image styling */
.partner-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: inherit;
}
.partner-logo-img {
  height: 72px;
  width: auto;
  object-fit: contain;
  filter: grayscale(1);
  transition:
    filter 220ms ease,
    transform 220ms ease;
  display: block;
  transform-origin: center;
}
.partner-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0.08);
  border-radius: var(--radius-md);
}
@media (max-width: 900px) {
  .partner-card {
    min-width: 140px;
    height: 64px;
    padding: 12px 18px;
  }
  .partner-logo-img {
    height: 44px;
  }
  .partner-track {
    gap: 12px;
    animation-duration: 30s;
  }
}
@media (prefers-reduced-motion: reduce) {
  .partner-track {
    animation: none !important;
  }
}
.partner-card:hover .partner-logo-img {
  filter: grayscale(0);
  transform: scale(1.06);
}
/* Slightly adjust badge when image is present */
.partner-link .partner-badge {
  font-size: 10px;
  opacity: 0.9;
  margin-top: 4px;
}

/* ── LOGO SVG ── */
.logo {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: oklch(100% 0 0 / 0.04);
  padding: 6px;
  border-radius: 12px;
  backdrop-filter: blur(8px);
  overflow: hidden;
  cursor: pointer;
  &:hover .logo-svg {
    transform: scale(1.15);
  }
  &:hover .left {
    transform: rotate(-12deg) translateY(-3px);
  }
  &:hover .right {
    transform: rotate(12deg) translateY(-3px);
  }
}
.logo-svg {
  width: 42px;
  height: 42px;
}
#aOutline {
  animation: drawA 1s ease forwards;
}
#aFill {
  animation: fillA 0.6s ease forwards 1s;
}
.glow {
  animation: pulse 2.5s infinite ease-in-out;
}
.leaf {
  transition: all var(--duration-base);
  animation: leafIn 0.6s ease forwards 1.6s;
}
.ripple {
  position: absolute;
  border-radius: 50%;
  background: oklch(from var(--color-brand-bright) l c h / 0.4);
  transform: scale(0);
  &.active {
    animation: rippleAnim 0.6s linear;
  }
}

/* ── SCROLL REVEAL (CSS-only, no JS needed) ── */
.reveal {
  opacity: 0;
  translate: 0 30px;
  animation: revealUp linear both;
  animation-timeline: view();
  animation-range: entry 0% entry 30%;
}

.reveal-left {
  opacity: 0;
  translate: -30px 0;
  animation: revealLeft linear both;
  animation-timeline: view();
  animation-range: entry 0% entry 30%;
}

.reveal-right {
  opacity: 0;
  translate: 30px 0;
  animation: revealRight linear both;
  animation-timeline: view();
  animation-range: entry 0% entry 30%;
}

/* Staggered children */
.reveal-stagger > * {
  opacity: 0;
  translate: 0 20px;
  animation: revealUp linear both;
  animation-timeline: view();
  animation-range: entry 0% entry 30%;
  &:nth-child(1) {
    animation-delay: 0.05s;
  }
  &:nth-child(2) {
    animation-delay: 0.12s;
  }
  &:nth-child(3) {
    animation-delay: 0.19s;
  }
  &:nth-child(4) {
    animation-delay: 0.26s;
  }
  &:nth-child(5) {
    animation-delay: 0.33s;
  }
  &:nth-child(6) {
    animation-delay: 0.4s;
  }
}

/* ── SECTION IDS ── */
#services {
  background: var(--surface-white);
}
body {
  padding-bottom: 0;
}

@media (max-width: 700px) {
  body {
    padding-bottom: 54px;
  }
  .toast {
    bottom: 70px;
  }
}

/* ── JOURNEY (timeline) ── */
.journey {
  background: linear-gradient(180deg, var(--surface-off), var(--surface-white));
}
.journey .sec-header {
  margin-bottom: 18px;
}
.journey-inner {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: clamp(20px, 4vw, 48px);
  align-items: start;
}
.journey-vision {
  min-width: 280px;
}
@media (max-width: 900px) {
  .journey-inner {
    grid-template-columns: 1fr;
  }
  .journey-vision {
    order: 2;
  }
}

.journey-track {
  position: relative;
  padding: 18px 0 18px 120px;
}
.journey-track::before {
  content: "";
  position: absolute;
  left: 84px;
  top: 8px;
  bottom: 8px;
  width: 4px;
  background: linear-gradient(
    180deg,
    var(--color-action),
    var(--color-brand-bright)
  );
  border-radius: 4px;
  box-shadow: 0 6px 20px oklch(from var(--color-action) l c h / 0.06);
}

.journey-item {
  position: relative;
  margin-bottom: 28px;
  padding-top: 6px;
  padding-bottom: 6px;
}

.journey-dot {
  position: absolute;
  left: 84px;
  top: 18px;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--color-action), var(--color-brand));
  border: 3px solid var(--surface-white);
  box-shadow: var(--shadow-sm);
  transform: translateX(-50%);
  z-index: 3;
}

.journey-card {
  margin-left: 140px;
  background: var(--surface-white);
  border-radius: 12px;
  padding: 16px 18px;
  border: 1px solid var(--surface-border);
  box-shadow: var(--shadow-sm);
  transition:
    transform var(--duration-base) var(--ease-overshoot),
    box-shadow var(--duration-base);
}
.journey-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
}

.journey-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 6px;
}
.j-icon {
  font-size: 20px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: oklch(98% 0.02 152);
  box-shadow: 0 6px 16px oklch(10% 0.02 152 / 0.06);
}
.j-meta {
  font-size: 13px;
  color: var(--text-ink3);
}
.j-date {
  font-weight: 700;
  color: var(--text-ink2);
}
.j-year {
  font-size: 12px;
  color: var(--text-ink4);
}

.j-title {
  font-size: 18px;
  margin: 6px 0;
  font-weight: 700;
  color: var(--text-ink);
}
.j-body {
  color: var(--text-ink3);
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 700px) {
  .journey-track {
    padding-left: 20px;
  }
  .journey-track::before {
    left: 24px;
  }
  .journey-dot {
    left: 24px;
    transform: translateX(-50%);
  }
  .journey-card {
    margin-left: 48px;
    padding: 14px;
    border-radius: 12px;
  }
  .journey-inner {
    grid-template-columns: 1fr;
  }
  .journey-vision {
    margin-top: 18px;
  }
}

/* ════════════════════════════════════════════════════════════════
   8. ANIMATIONS
   ════════════════════════════════════════════════════════════════ */
@layer animations {
  /* ── Scroll-driven reveal keyframes ── */
  @keyframes revealUp {
    from {
      opacity: 0;
      translate: 0 32px;
    }
    to {
      opacity: 1;
      translate: 0 0;
    }
  }
  @keyframes revealLeft {
    from {
      opacity: 0;
      translate: -30px 0;
    }
    to {
      opacity: 1;
      translate: 0 0;
    }
  }
  @keyframes revealRight {
    from {
      opacity: 0;
      translate: 30px 0;
    }
    to {
      opacity: 1;
      translate: 0 0;
    }
  }

  /* ── Motion ── */
  @keyframes pulse {
    0%,
    100% {
      box-shadow: 0 0 0 0 oklch(from var(--color-gold) l c h / 0.7);
    }
    70% {
      box-shadow: 0 0 0 10px oklch(from var(--color-gold) l c h / 0);
    }
  }
  @keyframes beacon {
    0% {
      box-shadow: 0 0 0 0 oklch(from var(--color-gold) l c h / 0.8);
    }
    70% {
      box-shadow: 0 0 0 14px oklch(from var(--color-gold) l c h / 0);
    }
    100% {
      box-shadow: 0 0 0 0 oklch(from var(--color-gold) l c h / 0);
    }
  }
  @keyframes floatY {
    0%,
    100% {
      translate: 0 0;
    }
    50% {
      translate: 0 -12px;
    }
  }
  @keyframes ripple {
    0% {
      scale: 0.7;
      opacity: 1;
    }
    100% {
      scale: 1.5;
      opacity: 0;
    }
  }
  @keyframes shimmerSweep {
    0% {
      left: -100%;
    }
    100% {
      left: 150%;
    }
  }
  @keyframes tagBob {
    0%,
    100% {
      translate: 0 0;
      rotate: -1deg;
    }
    50% {
      translate: 0 -6px;
      rotate: 1deg;
    }
  }
  @keyframes tlPulse {
    0%,
    100% {
      box-shadow: 0 0 0 0 oklch(from var(--color-action) l c h / 0.6);
    }
    70% {
      box-shadow: 0 0 0 10px oklch(from var(--color-action) l c h / 0);
    }
  }
  @keyframes quoteBob {
    0%,
    100% {
      translate: 0 0;
    }
    50% {
      translate: 0 -5px;
    }
  }
  @keyframes tickerScroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50%);
    }
  }
  @keyframes partnerScroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50%);
    }
  }
  @keyframes bgDrift {
    0%,
    100% {
      background-position: 0% 50%;
    }
    50% {
      background-position: 100% 50%;
    }
  }
  @keyframes fillBar {
    from {
      width: 0;
    }
    to {
      width: var(--fill-w, 100%);
    }
  }
  @keyframes certShimmer {
    0%,
    100% {
      background-position: 0% 50%;
    }
    50% {
      background-position: 100% 50%;
    }
  }
  @keyframes wxPulse {
    0%,
    100% {
      border-color: oklch(from var(--color-action) l c h / 0.3);
    }
    50% {
      border-color: oklch(from var(--color-action) l c h / 0.6);
    }
  }
  @keyframes dividerGlow {
    0%,
    100% {
      opacity: 0.4;
    }
    50% {
      opacity: 1;
    }
  }
  @keyframes focusRing {
    0% {
      box-shadow: 0 0 0 0 oklch(from var(--color-action) l c h / 0.4);
    }
    100% {
      box-shadow: 0 0 0 6px oklch(from var(--color-action) l c h / 0);
    }
  }
  @keyframes menuItemIn {
    from {
      opacity: 0;
      translate: -16px 0;
    }
    to {
      opacity: 1;
      translate: 0 0;
    }
  }
  @keyframes drawA {
    to {
      stroke-dashoffset: 0;
    }
  }
  @keyframes fillA {
    to {
      opacity: 1;
    }
  }
  @keyframes showGrid {
    to {
      opacity: 1;
    }
  }
  @keyframes leafIn {
    from {
      translate: 0 5px;
      opacity: 0;
    }
    to {
      translate: 0 0;
      opacity: 1;
    }
  }
  @keyframes rippleAnim {
    to {
      scale: 4;
      opacity: 0;
    }
  }

  @keyframes lbIn {
    from {
      opacity: 0;
      scale: 0.95;
    }
    to {
      opacity: 1;
      scale: 1;
    }
  }
  #lightbox.open {
    animation: lbIn var(--duration-base) var(--ease-spring);
  }
}

/* ════════════════════════════════════════════════════════════════
   8. ANIMATIONS & EFFECTS — liquid, blobs, shimmer
   ════════════════════════════════════════════════════════════════ */
@layer animations {
  /* Global water / liquid overlay usable on .hero and large sections */
  .water-layer {
    position: absolute;
    inset: 0;
    z-index: 8;
    pointer-events: none;
    opacity: var(--water-opacity, 0.12);
    mix-blend-mode: screen;
    filter: blur(var(--water-blur, 44px)) saturate(130%);
    background-image:
      radial-gradient(
        42% 28% at 10% 20%,
        color-mix(
            in srgb,
            var(--water-color-1, var(--color-action)) 45%,
            transparent
          )
          0%,
        transparent 40%
      ),
      radial-gradient(
        38% 26% at 80% 40%,
        color-mix(
            in srgb,
            var(--water-color-2, var(--color-brand-bright)) 45%,
            transparent
          )
          0%,
        transparent 42%
      ),
      radial-gradient(
        32% 22% at 50% 80%,
        color-mix(
            in srgb,
            var(--water-color-3, var(--color-gold)) 40%,
            transparent
          )
          0%,
        transparent 38%
      );
    background-repeat: no-repeat;
    background-size:
      180% 160%,
      180% 160%,
      200% 180%;
    animation: waterDrift var(--water-duration, 20s) ease-in-out infinite;
    will-change: transform;
  }

  @keyframes waterDrift {
    0% {
      transform: translate3d(-6%, -2%, 0) scale(1);
      background-position:
        0% 0%,
        100% 20%,
        50% 100%;
    }
    50% {
      transform: translate3d(6%, 4%, 0) scale(var(--water-scale, 1.06));
      background-position:
        60% 30%,
        40% 80%,
        10% 40%;
    }
    100% {
      transform: translate3d(-6%, -2%, 0) scale(1);
      background-position:
        0% 0%,
        100% 20%,
        50% 100%;
    }
  }

  /* Soft floating blob for subtle accents */
  .liquid-blob {
    position: absolute;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(
      circle at 30% 30%,
      color-mix(in srgb, var(--color-action) 50%, transparent) 0%,
      transparent 35%
    );
    filter: blur(30px) saturate(140%);
    opacity: 0.12;
    pointer-events: none;
    animation: float 7s ease-in-out infinite;
    will-change: transform, opacity;
  }

  @keyframes float {
    0% {
      transform: translateY(0) scale(0.98);
    }
    50% {
      transform: translateY(-12px) scale(1.03);
    }
    100% {
      transform: translateY(0) scale(0.98);
    }
  }

  /* Liquid shimmer for buttons and CTAs */
  .btn-liquid {
    position: relative;
    overflow: hidden;
    --px: 50%;
    --py: 50%;
    transition:
      transform 220ms var(--ease-out),
      box-shadow 220ms var(--ease-out);
  }
  .btn-liquid:hover {
    transform: translateY(-3px) scale(1.02);
  }
  .btn-liquid::after {
    content: "";
    position: absolute;
    inset: -30% -30%;
    /* Use CSS variables so JS can drive the highlight position */
    background:
      radial-gradient(
        closest-side at var(--px) var(--py),
        color-mix(in srgb, var(--color-action) 60%, rgba(255, 255, 255, 0.18))
          0%,
        transparent 36%
      ),
      linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.06),
        rgba(255, 255, 255, 0.02)
      );
    background-repeat: no-repeat;
    background-position: var(--px) var(--py);
    mix-blend-mode: screen;
    opacity: 0.7;
    transform: translate3d(0, 0, 0);
    animation: shimmerSlow 5s linear infinite;
    pointer-events: none;
    will-change: transform, background-position;
  }
  @keyframes shimmerSlow {
    0% {
      transform: translateX(-40%) translateY(0) rotate(0deg);
    }
    50% {
      transform: translateX(40%) translateY(-6%) rotate(2deg);
    }
    100% {
      transform: translateX(-40%) translateY(0) rotate(0deg);
    }
  }

  /* Hero particle base styles (script injects particles) */
  .hero-particle {
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    opacity: 0.9;
    transform: translate(-50%, -50%);
    animation: heroParticle var(--dur, 6s) ease-in-out infinite;
    animation-delay: var(--delay, 0s);
    will-change: transform, opacity;
  }

  @keyframes heroParticle {
    0% {
      transform: translate(-50%, -50%) translateY(0) scale(1);
      opacity: 0.95;
    }
    50% {
      transform: translate(-50%, -50%) translateY(-14px) scale(1.12);
      opacity: 0.55;
    }
    100% {
      transform: translate(-50%, -50%) translateY(0) scale(1);
      opacity: 0.95;
    }
  }

  /* Pointer follower for hero (single element for performance) */
  .hero-pointer {
    position: absolute;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    pointer-events: none;
    background: radial-gradient(
      circle at 40% 40%,
      rgba(255, 255, 255, 0.9) 0%,
      rgba(255, 255, 255, 0.15) 30%,
      transparent 60%
    );
    transform: translate(-50%, -50%) scale(0.6);
    transition:
      transform 120ms ease,
      opacity 200ms ease;
    mix-blend-mode: screen;
    z-index: 60;
    opacity: 0;
  }

  /* Button ripple base (created by JS) */
  .btn-ripple {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    transform: translate(-50%, -50%) scale(0);
    background: rgba(255, 255, 255, 0.12);
    width: 10px;
    height: 10px;
    opacity: 0.9;
    will-change: transform, opacity;
    transition:
      transform 600ms cubic-bezier(0.2, 0.8, 0.2, 1),
      opacity 600ms ease;
  }

  /* Respect reduced motion */
  @media (prefers-reduced-motion: reduce) {
    .water-layer,
    .liquid-blob,
    .btn-liquid::after {
      animation: none !important;
      transition: none !important;
    }
  }
}

/* ════════════════════════════════════════════════════════════════
   9. UTILITIES — highest specificity via @layer order
   ════════════════════════════════════════════════════════════════ */
@layer utilities {
  .hidden {
    display: none !important;
  }
  .pager-hidden {
    display: none !important;
  }
  .pager-focus {
    outline: 3px solid rgba(30, 136, 229, 0.18);
    outline-offset: 4px;
    box-shadow: 0 8px 18px rgba(30, 136, 229, 0.06);
    transition:
      box-shadow 220ms ease,
      outline 220ms ease;
  }

  /* SDG icon helper */
  .sdg-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    & svg {
      width: 48px;
      height: 48px;
    }
    & img {
      display: inline-block;
      width: 48px;
      height: 48px;
      border-radius: 50%;
      object-fit: cover;
    }
    & .emoji {
      display: inline-flex;
      width: 48px;
      height: 48px;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: rgba(61, 220, 132, 0.06);
      color: var(--color-brand-bright);
      font-size: 24px;
      line-height: 1;
    }
  }

  /* Blog/see-all */
  .blog-modal-img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 10px;
    margin-bottom: 18px;
    display: block;
  }
  .blog-modal-cat {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-action);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .blog-modal-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 22px;
    font-weight: 800;
    color: var(--text-ink);
    line-height: 1.3;
    margin-bottom: 14px;
  }
  .blog-modal-body {
    font-size: 15px;
    line-height: 1.8;
    color: var(--text-ink2);
    & p {
      margin-bottom: 14px;
    }
  }
  /* Small utility set: container, flex/stack, gaps, buttons, focus, skip-link */
  .container {
    max-width: var(--wrap-max);
    margin: 0 auto;
    padding-inline: var(--wrap-pad);
  }
  .center {
    text-align: center;
  }
  .flex {
    display: flex;
    gap: var(--gap-md);
  }
  .stack {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }
  .gap-sm {
    gap: var(--gap-sm);
  }
  .gap-md {
    gap: var(--gap-md);
  }
  .gap-lg {
    gap: var(--gap-lg);
  }
  .u-mt-1 {
    margin-top: var(--gap-sm);
  }
  .u-mt-2 {
    margin-top: var(--gap-md);
  }
  .u-mt-3 {
    margin-top: var(--gap-lg);
  }

  .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--radius-pill);
    font-weight: 700;
    cursor: pointer;
    border: none;
    background: linear-gradient(
      var(--gradient-angle),
      var(--color-action),
      var(--color-action-light)
    );
    color: #fff;
  }
  .btn-ghost {
    background: transparent;
    color: var(--color-action);
    border: 1px solid oklch(from var(--color-action) l c h / 0.12);
  }

  .focus-ring {
    outline: none;
    box-shadow: 0 0 0 var(--focus-ring-size)
      oklch(from var(--focus-ring-color) l c h / 0.12);
    border-radius: 6px;
  }

  .skip-link {
    position: absolute;
    left: -999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    z-index: 10000;
  }
  .skip-link:focus,
  .skip-link:active {
    left: 12px;
    top: 12px;
    width: auto;
    height: auto;
    padding: 10px 14px;
    background: var(--surface-white);
    color: var(--text-ink);
    border-radius: 6px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.12);
    z-index: 10000;
  }

  /* Responsive helpers (small) */
  @media (max-width: 900px) {
    .hide-md {
      display: none !important;
    }
    .show-md {
      display: block !important;
    }
  }
}

/* ════════════════════════════════════════════════════════════════
   10. OVERRIDES — last resort, scoped
   ════════════════════════════════════════════════════════════════ */
@layer overrides {
  /* Leaflet popup theming */
  .leaflet-popup-content-wrapper {
    border-radius: 12px !important;
    border: 1px solid var(--surface-border);
  }
  .map-popup-type {
    font-family: "JetBrains Mono", monospace;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-action);
    margin-bottom: 4px;
  }
  .map-popup-name {
    font-size: 15px;
    font-weight: 800;
    color: var(--text-ink);
    margin-bottom: 3px;
  }
  .map-popup-addr {
    font-size: 12px;
    color: var(--text-ink3);
    line-height: 1.5;
  }
  .map-popup-coords {
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    color: var(--text-ink4);
    margin-top: 6px;
  }
}

/* Mobile-specific tweaks: improve small-screen layout and pagination spacing */
@media (max-width: 900px) {
  .mobile-menu {
    top: 68px; /* align mobile menu under the nav */
  }
  .hero {
    min-height: 70vh; /* less aggressive on small screens */
    padding-top: 86px;
  }
  .hero-inner {
    padding: 100px var(--wrap-pad) 40px;
    gap: 28px;
  }
  .hero-title {
    font-size: clamp(28px, 7vw, 48px);
  }
  .hero-desc {
    max-width: 420px;
  }
  .nav-name {
    font-size: 16px;
  }
  .nav-sub {
    display: none;
  }
}

@media (max-width: 600px) {
  .hero {
    min-height: 60vh;
    padding-top: 78px;
  }
  .hero-inner {
    padding: 80px var(--wrap-pad) 30px;
  }
  .hero-title {
    font-size: clamp(22px, 7vw, 36px);
  }
  .hero-eyebrow {
    margin-bottom: 12px;
    font-size: 10px;
  }
  .mv-img {
    height: 140px;
  }
}

@layer overrides {
  .m-overlay {
    background:
      radial-gradient(
        circle at 18% 15%,
        oklch(from var(--color-gold) l c h / 0.12),
        transparent 26%
      ),
      radial-gradient(
        circle at 80% 10%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.86);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .m-overlay::before,
  .m-overlay::after {
    opacity: 0.28;
    filter: blur(34px);
  }

  .m-overlay::before {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.24),
      transparent 70%
    );
  }

  .m-overlay::after {
    background: radial-gradient(
      circle,
      oklch(from var(--color-brand-mid) l c h / 0.18),
      transparent 72%
    );
  }

  .m-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.4% 0.004 72 / 0.97)
      ),
      var(--surface-white);
    box-shadow:
      0 34px 110px oklch(6% 0.02 240 / 0.3),
      0 10px 24px oklch(8% 0.02 220 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .m-box::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.46),
      transparent
    );
  }

  .m-body,
  .m-form-body {
    background: linear-gradient(
      180deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.015)
    );
  }

  #exitPopup {
    background:
      radial-gradient(
        circle at 18% 15%,
        oklch(from var(--color-gold) l c h / 0.11),
        transparent 26%
      ),
      radial-gradient(
        circle at 80% 10%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.86);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .ep-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.5% 0.004 76 / 0.965)
      ),
      var(--surface-white);
    box-shadow:
      0 46px 128px oklch(6% 0.02 240 / 0.34),
      0 14px 36px oklch(8% 0.02 210 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .ep-box::before {
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.06),
        transparent 36%
      ),
      linear-gradient(
        -135deg,
        oklch(from var(--color-action) l c h / 0.035),
        transparent 42%
      );
  }

  .ep-ambient {
    opacity: 0.4;
    filter: blur(16px);
  }

  .ep-ambient-a {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.18),
      transparent 72%
    );
  }

  .ep-ambient-b {
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.1),
      transparent 74%
    );
  }

  .ep-top {
    padding: 38px 40px 24px;
    background:
      linear-gradient(
        145deg,
        oklch(16% 0.03 245),
        oklch(22% 0.04 210) 56%,
        oklch(23% 0.035 160)
      ),
      linear-gradient(135deg, var(--surface-hero), var(--surface-dark));
  }

  .ep-top::before {
    background:
      linear-gradient(oklch(100% 0 0 / 0.04) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.04) 1px, transparent 1px);
    background-size: 32px 32px;
  }

  .ep-top::after {
    content: "";
    position: absolute;
    left: 40px;
    right: 40px;
    bottom: 0;
    height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.45),
      transparent
    );
    pointer-events: none;
  }

  .ep-close {
    background: oklch(100% 0 0 / 0.09);
    border-color: oklch(100% 0 0 / 0.12);
  }

  .ep-close:hover,
  .ep-close:focus-visible {
    background: oklch(100% 0 0 / 0.16);
    border-color: oklch(from var(--color-gold) l c h / 0.28);
    transform: translateY(-1px);
  }

  .ep-emoji {
    background:
      linear-gradient(160deg, oklch(100% 0 0 / 0.12), oklch(100% 0 0 / 0.04)),
      oklch(100% 0 0 / 0.04);
    border-color: oklch(from var(--color-gold) l c h / 0.16);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.18),
      0 10px 24px oklch(0% 0 0 / 0.14);
  }

  .ep-title {
    letter-spacing: -0.036em;
    max-width: 13ch;
  }

  .ep-sub {
    color: oklch(100% 0 0 / 0.72);
  }

  .ep-proof-card {
    padding: 15px 17px;
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.11),
      oklch(100% 0 0 / 0.07)
    );
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.08);
  }

  .ep-proof-card strong {
    color: oklch(from var(--color-gold) l c h / 0.96);
  }

  .ep-proof-card span {
    color: oklch(100% 0 0 / 0.64);
  }

  .ep-body {
    gap: 18px;
    padding: 30px 40px 36px;
  }

  .ep-perk {
    min-height: 112px;
    border-radius: 18px;
    border-color: oklch(from var(--color-gold) l c h / 0.1);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.96),
      oklch(from var(--color-gold) l c h / 0.035)
    );
    box-shadow:
      0 16px 36px oklch(8% 0.02 230 / 0.07),
      inset 0 1px 0 oklch(100% 0 0 / 0.7);
  }

  .ep-perk-icon {
    background: linear-gradient(
      145deg,
      oklch(from var(--color-gold) l c h / 0.28),
      oklch(100% 0 0 / 0.92)
    );
    color: oklch(38% 0.08 72);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.84),
      0 8px 18px oklch(from var(--color-gold) l c h / 0.12);
  }

  .ep-form-intro {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.75);
  }

  .ep-form-intro strong {
    letter-spacing: -0.02em;
  }

  .ep-input {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background: oklch(100% 0 0 / 0.98);
    box-shadow:
      0 12px 26px oklch(8% 0.02 230 / 0.05),
      inset 0 1px 0 oklch(100% 0 0 / 0.88);
  }

  .ep-input:focus {
    border-color: oklch(from var(--color-gold) l c h / 0.35);
    box-shadow:
      0 0 0 5px oklch(from var(--color-gold) l c h / 0.1),
      0 12px 26px oklch(8% 0.02 230 / 0.06);
  }

  .ep-submit {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background: linear-gradient(
      135deg,
      oklch(18% 0.03 238),
      oklch(24% 0.04 175)
    );
    box-shadow:
      0 18px 40px oklch(8% 0.02 210 / 0.22),
      inset 0 1px 0 oklch(100% 0 0 / 0.16);
  }

  .ep-submit::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.16),
      transparent
    );
    animation-duration: 3.8s;
    opacity: 0.78;
  }

  .ep-submit:hover,
  .ep-submit:focus-visible,
  .ep-submit.btn-liquid:hover {
    transform: translateY(-2px) scale(1.006);
    box-shadow:
      0 20px 44px oklch(8% 0.02 210 / 0.26),
      inset 0 1px 0 oklch(100% 0 0 / 0.2);
  }

  .ep-mini-note {
    letter-spacing: 0.08em;
    color: oklch(58% 0.03 75);
  }

  .ep-dismiss {
    color: var(--text-ink3);
  }

  .ep-dismiss:hover {
    border-color: oklch(from var(--color-gold) l c h / 0.24);
    transform: none;
  }

  .ep-success-panel {
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow:
      0 18px 40px oklch(8% 0.02 230 / 0.06),
      inset 0 1px 0 oklch(100% 0 0 / 0.76);
  }

  .ep-success-icon {
    background: linear-gradient(145deg, oklch(30% 0.05 80), oklch(38% 0.08 72));
    box-shadow: 0 18px 40px oklch(from var(--color-gold) l c h / 0.2);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ) {
    transition:
      transform 180ms var(--ease-out),
      box-shadow 180ms var(--ease-out),
      border-color 180ms var(--ease-out),
      background-color 180ms var(--ease-out),
      filter 180ms var(--ease-out);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ):hover {
    filter: saturate(1.01) brightness(1.01);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    )
    > svg {
    transition: transform 180ms var(--ease-out);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    ):hover
    > svg {
    transform: translateX(2px) scale(1.03);
  }

  .btn-liquid {
    box-shadow: 0 10px 24px oklch(8% 0.02 220 / 0.08);
  }

  .btn-liquid::after {
    opacity: 0.42;
    mix-blend-mode: soft-light;
    animation-duration: 6.5s;
  }

  .btn-liquid:hover {
    box-shadow: 0 16px 30px oklch(8% 0.02 220 / 0.12);
  }

  .btn-spark {
    width: 7px;
    height: 7px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.92) 0 32%,
      oklch(100% 0 0 / 0.28) 52%,
      transparent 76%
    );
    box-shadow: 0 0 10px oklch(from var(--color-gold) l c h / 0.25);
    animation-duration: 620ms;
  }

  .sb-btn {
    box-shadow: 0 16px 32px oklch(8% 0.02 220 / 0.18);
  }

  .sb-btn::before {
    background: linear-gradient(
      115deg,
      oklch(100% 0 0 / 0.18),
      transparent 46%,
      transparent
    );
  }

  .sb-btn:hover,
  .sb-btn:focus-visible {
    transform: translateX(-5px) scale(1.02);
    box-shadow: 0 20px 36px oklch(8% 0.02 220 / 0.22);
    filter: saturate(1.03);
  }

  .sb-btn:hover svg,
  .sb-btn:focus-visible svg {
    transform: scale(1.06);
  }

  .sb-btn:hover .sb-label,
  .sb-btn:focus-visible .sb-label {
    transform: translateX(-4px);
  }

  @media (max-width: 760px) {
    .ep-top {
      padding: 28px 24px 20px;
    }

    .ep-top::after {
      left: 24px;
      right: 24px;
    }

    .ep-body {
      padding: 24px 24px 28px;
    }
  }

  @media (max-width: 700px) {
    .sb-btn:hover,
    .sb-btn:focus-visible {
      transform: translateY(-3px) scale(1.01);
    }
  }
}

/* Absolute final SDG correction: keep this section bright and readable */
.sdg-sec {
  position: relative;
  overflow: hidden;
  color: #071725;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(244, 250, 248, 0.96)
    ),
    radial-gradient(
      circle at 18% 8%,
      rgba(44, 106, 163, 0.08),
      transparent 40%
    ),
    radial-gradient(circle at 86% 18%, rgba(23, 109, 32, 0.08), transparent 42%) !important;
}

.sdg-sec::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 13%,
    #000 88%,
    transparent
  );
}

.sdg-sec::after {
  content: "";
  position: absolute;
  inset: auto 8% -170px 8%;
  z-index: 0;
  width: auto;
  height: 340px;
  pointer-events: none;
  border-radius: 50%;
  background:
    radial-gradient(
      ellipse at 50% 50%,
      rgba(44, 106, 163, 0.13),
      transparent 62%
    ),
    radial-gradient(
      ellipse at 38% 48%,
      rgba(94, 211, 155, 0.13),
      transparent 60%
    );
  translate: none;
}

.sdg-sec .wrap {
  position: relative;
  z-index: 1;
}

.sdg-sec .sec-header .eyebrow {
  color: #176d20;
  border-color: rgba(23, 109, 32, 0.14);
  background: rgba(255, 255, 255, 0.84);
}

.sdg-sec .sec-header .h2 {
  color: #071725 !important;
}

.sdg-sec .sec-header .lead {
  color: #26343b !important;
  opacity: 1;
}

.sdg-sec .sdg-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 22px);
  max-width: 1040px;
  margin: 0 auto;
}

.sdg-sec .sdg-grid .sgc {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  justify-items: center;
  align-content: start;
  min-height: 258px;
  padding: 26px 22px 28px;
  color: #071725;
  text-align: center;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      #fff 70%,
      #fbfdff 100%
    ),
    #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.92) inset;
  overflow: hidden;
  isolation: isolate;
}

.sdg-sec .sdg-grid .sgc::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 62px;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--sdg-color) 22%, #fff),
      rgba(255, 255, 255, 0.78)
    ),
    linear-gradient(135deg, rgba(255, 255, 255, 0.48), transparent);
  transform: none;
  opacity: 1;
}

.sdg-sec .sdg-grid .sgc::after {
  content: "";
  position: absolute;
  inset: auto -28px -44px auto;
  z-index: -1;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--sdg-color) 22%, transparent),
    transparent 68%
  );
  opacity: 0.42;
  mix-blend-mode: normal;
  transform: none;
}

.sdg-sec .sdg-grid .sdg-icon {
  position: relative;
  z-index: 1;
  display: grid;
  width: 58px;
  height: 58px;
  place-items: center;
  margin: -2px 0 18px;
  border: 3px solid #fff;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.35),
      transparent 32%
    ),
    linear-gradient(
      145deg,
      var(--sdg-color),
      color-mix(in srgb, var(--sdg-color) 64%, #071725)
    );
  box-shadow:
    0 16px 28px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.55) inset;
}

.sdg-sec .sdg-grid .sdg-icon img,
.sdg-sec .sdg-grid .sdg-icon svg,
.sdg-sec .sdg-grid .sdg-icon .emoji {
  width: 100%;
  height: 100%;
  border-radius: 12px;
  background: transparent;
  color: inherit;
  object-fit: cover;
  display: block;
}

.sdg-sec .sdg-grid .sgn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 34px;
  margin: 0 0 10px;
  padding: 0 12px;
  color: var(--sdg-color);
  font-family: "JetBrains Mono", monospace;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  text-shadow: none;
  border: 1px solid color-mix(in srgb, var(--sdg-color) 26%, #fff);
  border-radius: 999px;
  background: color-mix(in srgb, var(--sdg-color) 8%, #fff);
}

.sdg-sec .sdg-grid .sgt {
  max-width: 14rem;
  margin: 0 0 10px;
  color: #071725;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 850;
  line-height: 1.28;
  text-wrap: balance;
}

.sdg-sec .sdg-grid .sgd {
  max-width: 18rem;
  max-height: none;
  margin: 0;
  color: #26343b;
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1.58;
  overflow: visible;
}

.sdg-sec .sdg-grid .sgc:hover,
.sdg-sec .sdg-grid .sgc:focus-visible,
.sdg-sec .sdg-grid .sgc.expanded {
  transform: translateY(-10px);
  border-color: color-mix(in srgb, var(--sdg-color) 40%, rgba(7, 17, 24, 0.08));
  box-shadow:
    0 30px 78px rgba(7, 17, 24, 0.15),
    0 0 0 1px color-mix(in srgb, var(--sdg-color) 18%, transparent) inset;
}

.sdg-sec .sdg-grid .sgc:hover .sdg-icon,
.sdg-sec .sdg-grid .sgc:focus-visible .sdg-icon,
.sdg-sec .sdg-grid .sgc.expanded .sdg-icon {
  transform: translateY(-4px) rotate(-4deg) scale(1.05);
}

.sdg-sec .sdg-grid .sgc:hover .sgn,
.sdg-sec .sdg-grid .sgc:focus-visible .sgn,
.sdg-sec .sdg-grid .sgc.expanded .sgn {
  color: #fff;
  background: linear-gradient(
    135deg,
    var(--sdg-color),
    color-mix(in srgb, var(--sdg-color) 62%, #071725)
  );
  border-color: transparent;
}

.sdg-sec .sdg-grid .sgc:hover .sgt,
.sdg-sec .sdg-grid .sgc:focus-visible .sgt,
.sdg-sec .sdg-grid .sgc.expanded .sgt {
  color: color-mix(in srgb, var(--sdg-color) 72%, #071725);
}

.sdg-sec .sdg-grid .sgc:hover .sgd,
.sdg-sec .sdg-grid .sgc:focus-visible .sgd,
.sdg-sec .sdg-grid .sgc.expanded .sgd {
  color: #26343b;
}

@media (max-width: 960px) {
  .sdg-sec .sdg-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .sdg-sec .sdg-grid {
    grid-template-columns: 1fr;
  }

  .sdg-sec .sdg-grid .sgc {
    min-height: 230px;
  }
}

/* Final visual consistency lock for the public sections */
main
  > section:not(.hero):not(.intel-sec):not(.core-focus-showcase):not(
    #services
  ) {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(246, 251, 249, 0.95)
    ),
    radial-gradient(circle at 50% 0, rgba(23, 109, 32, 0.055), transparent 45%);
}

main
  > section:nth-of-type(even):not(.hero):not(.intel-sec):not(
    .core-focus-showcase
  ):not(#services) {
  background:
    linear-gradient(
      180deg,
      rgba(247, 252, 250, 0.98),
      rgba(255, 255, 255, 0.98)
    ),
    radial-gradient(
      circle at 16% 8%,
      rgba(44, 106, 163, 0.055),
      transparent 43%
    );
}

.sec-header {
  max-width: 940px;
  margin-inline: auto;
  margin-bottom: clamp(30px, 4vw, 44px);
  text-align: center;
}

.sec-header .eyebrow,
.intern-intro .eyebrow,
.proj-sub-label,
.ts-label,
.intern-cards-title span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 32px;
  margin-inline: auto;
  padding: 6px 13px;
  color: #176d20;
  border: 1px solid rgba(23, 109, 32, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 10px 24px rgba(7, 17, 24, 0.04);
}

.sec-header .eyebrow::before,
.intern-intro .eyebrow::before {
  content: "";
  width: 18px;
  height: 10px;
  border-radius: 999px 0 999px 0;
  background: linear-gradient(135deg, #2f8a2c, #74b83b);
  transform: rotate(28deg);
}

.sec-header .eyebrow::after,
.intern-intro .eyebrow::after,
.proj-sub-label::after,
.ts-label::after,
.intern-cards-title span::after {
  display: none;
}

.sec-header .h2 {
  color: #071725;
  letter-spacing: 0;
  text-wrap: balance;
}

.sec-header .h2::after {
  content: "";
  display: block;
  width: 154px;
  height: 4px;
  margin: 16px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #176d20 0 48%, #2c6aa3 52% 100%);
}

.sec-header .h2 em,
.intern-intro .h2 em,
.cta-title em,
.qt em {
  color: #176d20;
  background: linear-gradient(90deg, #176d20, #2c6aa3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

:is(
  .sc:not(.focus-card),
  .cc,
  .pjc,
  .sic,
  .journey-card,
  .vmc,
  .sgc,
  .partner-card,
  .tmc,
  .blc,
  .tec,
  .invc,
  .locc,
  .cii,
  .form-wrap,
  .intern-cta-card,
  .ist-card,
  .ictc-card,
  .quote-wrap,
  .services-showcase
) {
  border-color: rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      #fff 72%,
      #fbfdff 100%
    ),
    #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

:is(
  .sc:not(.focus-card),
  .cc,
  .pjc,
  .sic,
  .journey-card,
  .vmc,
  .sgc,
  .partner-card,
  .tmc,
  .blc,
  .tec,
  .invc,
  .locc,
  .cii,
  .form-wrap,
  .intern-cta-card,
  .ist-card,
  .ictc-card,
  .quote-wrap
):hover {
  transform: translateY(-8px);
  border-color: rgba(44, 106, 163, 0.2);
  box-shadow:
    0 28px 74px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(23, 109, 32, 0.07) inset;
}

.blc {
  height: auto;
  min-height: 390px;
}

.blc-top {
  position: relative;
  height: 190px;
  min-height: 190px;
  overflow: hidden;
  border-radius: 8px 8px 0 0;
  background-size: cover !important;
  background-position: center !important;
}

.pj-vis {
  height: 220px;
  border-radius: 8px 8px 0 0;
}

.pj-vis::after,
.blc-top::after {
  content: "";
  position: absolute;
  left: -5%;
  right: -5%;
  bottom: -1px;
  height: 50px;
  background: #fff;
  clip-path: polygon(
    0 62%,
    18% 70%,
    38% 72%,
    60% 68%,
    80% 59%,
    100% 50%,
    100% 100%,
    0 100%
  );
  pointer-events: none;
}

.sic {
  overflow: hidden;
  padding: 0;
  contain: layout style paint;
  display: flex;
  flex-direction: column;
}

.sic-img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  border-radius: 8px 8px 0 0;
}

.sic-body {
  padding: 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.sc-emoji,
.inv-ic,
.j-icon,
.loc-pin,
.cii-ic,
.tm-av,
.te-av,
.ist-card .ist-num,
.ictc-icon {
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.3),
      transparent 30%
    ),
    linear-gradient(145deg, #0b7c7d, #176d20);
  color: #fff;
  box-shadow:
    0 16px 30px rgba(7, 17, 24, 0.13),
    0 0 0 3px #fff;
}

.quote-sec,
.cta-banner {
  background:
    linear-gradient(135deg, rgba(7, 23, 37, 0.98), rgba(13, 61, 42, 0.96)),
    #071725;
}

.quote-wrap {
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 252, 250, 0.96)
    ),
    #fff;
}

.cta-inner {
  max-width: 980px;
  margin-inline: auto;
  padding: clamp(30px, 5vw, 54px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.1),
      rgba(255, 255, 255, 0.035)
    ),
    rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(12px);
}

@media (max-width: 700px) {
  .sec-header .h2::after {
    width: 118px;
  }

  :is(
    .sc:not(.focus-card),
    .cc,
    .pjc,
    .sic,
    .journey-card,
    .vmc,
    .sgc,
    .partner-card,
    .tmc,
    .blc,
    .tec,
    .invc,
    .locc,
    .cii,
    .form-wrap,
    .intern-cta-card,
    .ist-card,
    .ictc-card,
    .quote-wrap
  ):hover {
    transform: none;
  }
}

/* SDG section rescue: bright, readable, official-color cards */
.sdg-sec {
  position: relative;
  overflow: hidden;
  color: #071725;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(244, 250, 248, 0.96)
    ),
    radial-gradient(
      circle at 18% 8%,
      rgba(44, 106, 163, 0.08),
      transparent 40%
    ),
    radial-gradient(circle at 86% 18%, rgba(23, 109, 32, 0.08), transparent 42%) !important;
}

.sdg-sec::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 13%,
    #000 88%,
    transparent
  );
}

.sdg-sec::after {
  content: "";
  position: absolute;
  inset: auto 8% -170px 8%;
  z-index: 0;
  height: 340px;
  pointer-events: none;
  border-radius: 50%;
  background:
    radial-gradient(
      ellipse at 50% 50%,
      rgba(44, 106, 163, 0.13),
      transparent 62%
    ),
    radial-gradient(
      ellipse at 38% 48%,
      rgba(94, 211, 155, 0.13),
      transparent 60%
    );
}

.sdg-sec .wrap {
  position: relative;
  z-index: 1;
}

.sdg-sec .sec-header .eyebrow {
  color: #176d20;
  border-color: rgba(23, 109, 32, 0.14);
  background: rgba(255, 255, 255, 0.84);
}

.sdg-sec .sec-header .h2 {
  color: #071725 !important;
}

.sdg-sec .sec-header .lead {
  color: #26343b !important;
  opacity: 1;
}

.sdg-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 22px);
  max-width: 1040px;
  margin: 0 auto;
}

.sdg-grid .sgc {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  justify-items: center;
  align-content: start;
  min-height: 258px;
  padding: 26px 22px 28px;
  color: #071725;
  text-align: center;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      #fff 70%,
      #fbfdff 100%
    ),
    #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.92) inset;
  overflow: hidden;
  isolation: isolate;
}

.sdg-grid .sgc::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 62px;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--sdg-color) 22%, #fff),
      rgba(255, 255, 255, 0.78)
    ),
    linear-gradient(135deg, rgba(255, 255, 255, 0.48), transparent);
  transform: none;
  opacity: 1;
}

.sdg-grid .sgc::after {
  content: "";
  position: absolute;
  inset: auto -28px -44px auto;
  z-index: -1;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--sdg-color) 22%, transparent),
    transparent 68%
  );
  opacity: 0.42;
  mix-blend-mode: normal;
  transform: none;
}

.sdg-grid .sdg-icon {
  position: relative;
  z-index: 1;
  display: grid;
  width: 72px;
  height: 72px;
  place-items: center;
  margin: -2px 0 18px;
  border: none;
  border-radius: 12px;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.sdg-grid .sdg-icon img,
.sdg-grid .sdg-icon svg,
.sdg-grid .sdg-icon .emoji {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: transparent;
  color: #fff;
  object-fit: contain;
}

.sdg-grid .sdg-icon .emoji {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.sdg-grid .sgn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 34px;
  margin: 0 0 10px;
  padding: 0 12px;
  color: var(--sdg-color);
  font-family: "JetBrains Mono", monospace;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  text-shadow: none;
  border: 1px solid color-mix(in srgb, var(--sdg-color) 26%, #fff);
  border-radius: 999px;
  background: color-mix(in srgb, var(--sdg-color) 8%, #fff);
}

.sdg-grid .sgt {
  max-width: 14rem;
  margin: 0 0 10px;
  color: #071725;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 850;
  line-height: 1.28;
  text-wrap: balance;
}

.sdg-grid .sgd {
  max-width: 18rem;
  max-height: none;
  margin: 0;
  color: #26343b;
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1.58;
  overflow: visible;
}

.sdg-grid .sgc:hover,
.sdg-grid .sgc:focus-visible,
.sdg-grid .sgc.expanded {
  transform: translateY(-10px);
  border-color: color-mix(in srgb, var(--sdg-color) 40%, rgba(7, 17, 24, 0.08));
  box-shadow:
    0 30px 78px rgba(7, 17, 24, 0.15),
    0 0 0 1px color-mix(in srgb, var(--sdg-color) 18%, transparent) inset;
}

.sdg-grid .sgc:hover::before,
.sdg-grid .sgc:focus-visible::before,
.sdg-grid .sgc.expanded::before {
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--sdg-color) 34%, #fff),
      rgba(255, 255, 255, 0.82)
    ),
    linear-gradient(135deg, rgba(255, 255, 255, 0.48), transparent);
}

.sdg-grid .sgc:hover .sdg-icon,
.sdg-grid .sgc:focus-visible .sdg-icon,
.sdg-grid .sgc.expanded .sdg-icon {
  transform: translateY(-4px) rotate(-4deg) scale(1.05);
}

.sdg-grid .sgc:hover .sgn,
.sdg-grid .sgc:focus-visible .sgn,
.sdg-grid .sgc.expanded .sgn {
  color: #fff;
  background: linear-gradient(
    135deg,
    var(--sdg-color),
    color-mix(in srgb, var(--sdg-color) 62%, #071725)
  );
  border-color: transparent;
}

.sdg-grid .sgc:hover .sgt,
.sdg-grid .sgc:focus-visible .sgt,
.sdg-grid .sgc.expanded .sgt {
  color: color-mix(in srgb, var(--sdg-color) 72%, #071725);
}

.sdg-grid .sgc:hover .sgd,
.sdg-grid .sgc:focus-visible .sgd,
.sdg-grid .sgc.expanded .sgd {
  color: #26343b;
}

@media (max-width: 960px) {
  .sdg-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .sdg-grid {
    grid-template-columns: 1fr;
  }

  .sdg-grid .sgc {
    min-height: 230px;
  }
}

/* Core focus reference rebuild and services visual refresh */
.core-focus-showcase {
  position: relative;
  overflow: hidden;
  padding-block: clamp(72px, 8vw, 112px);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(245, 250, 248, 0.96)
    ),
    radial-gradient(circle at 50% 0, rgba(47, 125, 29, 0.08), transparent 42%);
}

.core-focus-showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.03) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 18%,
    #000 88%,
    transparent
  );
}

.core-focus-showcase .wrap {
  position: relative;
  z-index: 1;
}

.focus-showcase-head {
  max-width: 980px;
  margin: 0 auto clamp(30px, 4vw, 42px);
  text-align: center;
}

.focus-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 10px;
  color: #176d20;
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(14px, 1.6vw, 22px);
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.focus-kicker span {
  position: relative;
  width: 38px;
  height: 18px;
}

.focus-kicker span::before,
.focus-kicker span::after {
  content: "";
  position: absolute;
  top: 4px;
  width: 19px;
  height: 10px;
  border-radius: 999px 0 999px 0;
  background: linear-gradient(135deg, #2f8a2c, #74b83b);
  box-shadow: 0 5px 12px rgba(23, 109, 32, 0.16);
}

.focus-kicker span::before {
  left: 2px;
  transform: rotate(32deg);
}

.focus-kicker span::after {
  right: 1px;
  transform: rotate(-148deg);
}

.focus-showcase-title {
  max-width: 1120px;
  margin: 0 auto;
  color: #071725;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(34px, 5.4vw, 58px);
  font-weight: 850;
  line-height: 1.08;
  letter-spacing: 0;
  text-wrap: balance;
}

.focus-showcase-title span {
  color: #176d20;
}

.focus-title-line {
  width: 178px;
  height: 4px;
  margin: 16px auto 22px;
  border-radius: 999px;
  background: linear-gradient(90deg, #176d20 0 48%, #2c6aa3 52% 100%);
  transform-origin: center;
}

.core-focus-showcase.is-awake .focus-title-line {
  animation: focusLineGrow 760ms var(--ease-spring, ease) both;
}

.focus-showcase-lead {
  max-width: 880px;
  margin: 0 auto;
  color: #26343b;
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.72;
}

.focus-showcase-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(20px, 2.6vw, 28px);
}

.focus-card {
  --focus-accent: #0b7c7d;
  --focus-accent-dark: #064f67;
  display: flex;
  flex-direction: column;
  min-height: 616px;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background: linear-gradient(180deg, #fff 0%, #fff 74%, #fbfdff 100%), #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
  isolation: isolate;
}

.focus-card::before {
  content: none;
}

.focus-card-teal {
  --focus-accent: #0b7c7d;
  --focus-accent-dark: #074f63;
}

.focus-card-green {
  --focus-accent: #2f7d1d;
  --focus-accent-dark: #176d20;
}

.focus-card-blue {
  --focus-accent: #083b83;
  --focus-accent-dark: #062e67;
}

.focus-card-media {
  position: relative;
  min-height: clamp(194px, 17vw, 238px);
  overflow: hidden;
  background-image: url("assets/core-focus-reference.jpeg");
  background-repeat: no-repeat;
  background-size: 315% auto;
  background-position: var(--focus-media-x, 50%) var(--focus-media-y, 34%);
  transform-origin: center;
}

.focus-card-media::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      105deg,
      transparent 0 34%,
      rgba(255, 255, 255, 0.28) 48%,
      transparent 64%
    ),
    linear-gradient(180deg, transparent 58%, rgba(255, 255, 255, 0.12));
  transform: translateX(-130%);
  mix-blend-mode: screen;
}

.focus-card-media::after {
  content: "";
  position: absolute;
  left: -4%;
  right: -4%;
  bottom: -1px;
  height: 62px;
  background: #fff;
  clip-path: polygon(
    0 64%,
    16% 70%,
    36% 72%,
    58% 69%,
    78% 61%,
    100% 52%,
    100% 100%,
    0 100%
  );
}

.focus-card:hover .focus-card-media::before,
.focus-card:focus-within .focus-card-media::before {
  animation: focusPhotoSheen 920ms var(--ease-out, ease) both;
}

.focus-card-body {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  padding: 0 clamp(22px, 2.4vw, 32px) 28px;
}

.focus-card-icon {
  position: relative;
  z-index: 2;
  width: 90px;
  height: 90px;
  margin: -52px 0 18px;
  border: 3px solid #fff;
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.28),
      transparent 30%
    ),
    linear-gradient(145deg, var(--focus-accent), var(--focus-accent-dark));
  box-shadow:
    0 18px 34px rgba(7, 17, 24, 0.16),
    0 0 0 1px rgba(255, 255, 255, 0.5) inset;
}

.focus-card-icon svg {
  width: 54px;
  height: 54px;
}

.focus-card:hover .focus-card-icon,
.focus-card:focus-within .focus-card-icon {
  transform: translateY(-5px) rotate(-4deg) scale(1.04);
}

.focus-card-title {
  max-width: 96%;
  margin: 0 0 12px;
  color: var(--focus-accent-dark);
  font-size: clamp(20px, 2.05vw, 26px);
  font-weight: 850;
  line-height: 1.24;
  letter-spacing: 0;
  text-wrap: balance;
}

.focus-card-rule {
  width: 68px;
  height: 4px;
  margin-bottom: 14px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    var(--focus-accent),
    rgba(44, 106, 163, 0.82)
  );
}

.focus-card-desc {
  margin-bottom: 20px;
  color: #26343b;
  font-size: 15px;
  line-height: 1.64;
}

.focus-feature-list {
  display: grid;
  gap: 12px;
  margin: 0 0 24px;
}

.focus-feature-list li {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  gap: 10px;
  color: #26343b;
  font-size: 13.5px;
  font-weight: 650;
  line-height: 1.35;
}

.focus-feature-list span {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  color: var(--focus-accent);
  border-radius: 7px;
  background: color-mix(in srgb, var(--focus-accent) 10%, #fff);
}

.focus-feature-list svg {
  width: 15px;
  height: 15px;
  stroke-width: 5;
}

.focus-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: fit-content;
  min-height: 40px;
  margin-top: auto;
  padding: 9px 24px;
  color: var(--focus-accent-dark);
  font-size: 14px;
  font-weight: 800;
  border: 1.5px solid color-mix(in srgb, var(--focus-accent) 58%, #fff);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(7, 17, 24, 0.05);
}

.focus-card-link svg {
  transition: transform 220ms var(--ease-out, ease);
}

.focus-card-link:hover,
.focus-card-link:focus-visible {
  color: #fff;
  border-color: var(--focus-accent);
  background: linear-gradient(
    135deg,
    var(--focus-accent),
    var(--focus-accent-dark)
  );
}

.focus-card-link:hover svg,
.focus-card-link:focus-visible svg {
  transform: translateX(5px);
}

.focus-card:hover,
.focus-card:focus-within {
  transform: translateY(-10px);
  border-color: color-mix(in srgb, var(--focus-accent) 28%, transparent);
  box-shadow:
    0 28px 74px rgba(7, 17, 24, 0.14),
    0 0 0 1px color-mix(in srgb, var(--focus-accent) 12%, transparent) inset;
}

#services {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, #fff 0%, rgba(244, 250, 248, 0.96) 100%),
    linear-gradient(90deg, rgba(44, 106, 163, 0.04), rgba(23, 109, 32, 0.04));
}

.services-showcase {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: clamp(22px, 4vw, 54px);
  align-items: center;
  margin: 0 0 clamp(28px, 4vw, 46px);
  padding: clamp(20px, 3.2vw, 34px);
  overflow: hidden;
  border: 1px solid rgba(18, 104, 74, 0.12);
  border-radius: 24px;
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.94),
      rgba(247, 252, 250, 0.9)
    ),
    linear-gradient(135deg, rgba(44, 106, 163, 0.08), rgba(47, 125, 29, 0.08));
  box-shadow:
    0 24px 70px rgba(7, 17, 24, 0.1),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
  transform: perspective(1000px) rotateX(var(--tilt-y)) rotateY(var(--tilt-x));
  transition:
    transform 240ms var(--ease-out, ease),
    box-shadow 240ms var(--ease-out, ease),
    border-color 240ms var(--ease-out, ease);
}

.services-showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent, rgba(44, 106, 163, 0.06), transparent),
    repeating-linear-gradient(
      90deg,
      transparent 0 38px,
      rgba(18, 104, 74, 0.035) 39px 40px
    );
  opacity: 0.62;
}

.services-showcase:hover,
.services-showcase:focus-within {
  border-color: rgba(44, 106, 163, 0.2);
  box-shadow:
    0 32px 86px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(255, 214, 106, 0.11) inset;
}

.services-orbit-art,
.services-showcase-copy {
  position: relative;
  z-index: 1;
}

.services-orbit-art {
  display: grid;
  min-height: clamp(330px, 34vw, 476px);
  place-items: center;
  isolation: isolate;
}

.services-orbit-art img {
  position: relative;
  z-index: 2;
  width: min(720px, 100%);
  border-radius: 12px;
  filter: drop-shadow(0 26px 34px rgba(7, 17, 24, 0.16));
  animation: serviceImageFloat 7s ease-in-out infinite;
}

.services-orbit-ring {
  position: absolute;
  z-index: 0;
  border: 1.5px solid rgba(44, 106, 163, 0.18);
  border-radius: 50%;
  box-shadow: 0 0 34px rgba(47, 125, 29, 0.08) inset;
}

.services-orbit-ring-one {
  width: min(92%, 560px);
  aspect-ratio: 1;
  animation: servicesOrbit 18s linear infinite;
}

.services-orbit-ring-two {
  width: min(72%, 430px);
  aspect-ratio: 1;
  border-color: rgba(255, 214, 106, 0.32);
  animation: servicesOrbit 13s linear infinite reverse;
}

.services-orbit-ring::before,
.services-orbit-ring::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(
    135deg,
    var(--color-action),
    var(--color-brand-bright)
  );
  box-shadow: 0 0 22px rgba(44, 106, 163, 0.38);
}

.services-orbit-ring::before {
  top: 9%;
  left: 17%;
}

.services-orbit-ring::after {
  right: 12%;
  bottom: 20%;
  background: linear-gradient(
    135deg,
    var(--color-gold),
    var(--color-brand-bright)
  );
}

.services-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  margin-bottom: 14px;
  padding: 7px 13px;
  color: #176d20;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid rgba(23, 109, 32, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
}

.services-showcase-copy h3 {
  margin: 0 0 14px;
  color: #071725;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(26px, 3.2vw, 42px);
  font-weight: 850;
  line-height: 1.1;
  letter-spacing: 0;
  text-wrap: balance;
}

.services-showcase-copy p {
  max-width: 560px;
  color: #26343b;
  font-size: 16px;
  line-height: 1.72;
}

.services-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 24px;
}

.services-mini-grid div {
  min-height: 96px;
  padding: 16px 14px;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.services-mini-grid strong,
.services-mini-grid span {
  display: block;
}

.services-mini-grid strong {
  margin-bottom: 10px;
  color: #2c6aa3;
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  font-weight: 900;
}

.services-mini-grid span {
  color: #071725;
  font-size: 15px;
  font-weight: 800;
}

.svc-grid {
  position: relative;
  z-index: 1;
}

.h2,
.sec-header .lead {
  text-wrap: balance;
}

#prog {
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--color-brand),
    var(--color-action),
    var(--color-gold)
  );
  box-shadow: 0 0 18px rgba(44, 106, 163, 0.28);
}

.hero-bg-img,
.mv-img,
.services-orbit-art img {
  image-rendering: auto;
}

@keyframes focusLineGrow {
  from {
    transform: scaleX(0.34);
    opacity: 0.4;
  }
  to {
    transform: scaleX(1);
    opacity: 1;
  }
}

@keyframes focusPhotoSheen {
  from {
    transform: translateX(-130%);
  }
  to {
    transform: translateX(130%);
  }
}

@keyframes serviceImageFloat {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-12px) scale(1.01);
  }
}

@keyframes servicesOrbit {
  to {
    transform: rotate(1turn);
  }
}

@media (max-width: 1080px) {
  .focus-showcase-grid {
    grid-template-columns: 1fr;
  }

  .focus-card {
    min-height: auto;
  }

  .focus-card-media {
    min-height: clamp(220px, 42vw, 320px);
    background-size: 315% auto;
  }

  .services-showcase {
    grid-template-columns: 1fr;
  }

  .services-showcase-copy {
    order: -1;
  }
}

@media (max-width: 700px) {
  .core-focus-showcase {
    padding-block: 62px;
  }

  .focus-kicker {
    gap: 8px;
    font-size: 12px;
    letter-spacing: 0.12em;
  }

  .focus-kicker span {
    width: 28px;
  }

  .focus-showcase-title {
    font-size: clamp(31px, 10vw, 43px);
  }

  .focus-showcase-lead {
    font-size: 15px;
  }

  .focus-card-media {
    min-height: 220px;
  }

  .focus-card-body {
    padding-inline: 22px;
  }

  .focus-card-icon {
    width: 78px;
    height: 78px;
    margin-top: -46px;
  }

  .focus-card-icon svg {
    width: 46px;
    height: 46px;
  }

  .focus-feature-list li {
    font-size: 13px;
  }

  .services-showcase {
    padding: 18px;
    border-radius: 18px;
  }

  .services-orbit-art {
    min-height: 270px;
  }

  .services-mini-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .core-focus-showcase.is-awake .focus-title-line,
  .focus-card:hover .focus-card-media::before,
  .focus-card:focus-within .focus-card-media::before,
  .services-orbit-art img,
  .services-orbit-ring {
    animation: none !important;
  }

  .services-showcase {
    transform: none !important;
  }
}

/* Site-wide harmony pass: make every section feel related to the focus cards */
main > section:not(.hero):not(.intel-sec):not(.core-focus-showcase),
.quote-sec,
.cta-banner {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

main
  > section:not(.hero):not(.intel-sec):not(.core-focus-showcase):not(
    #services
  ) {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(245, 250, 248, 0.94)
    ),
    radial-gradient(circle at 50% 0, rgba(23, 109, 32, 0.06), transparent 46%);
}

main > section:not(.hero):not(.intel-sec):not(.core-focus-showcase)::before,
.quote-sec::before,
.cta-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.028) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 15%,
    #000 86%,
    transparent
  );
}

main
  > section:nth-of-type(even):not(.hero):not(.intel-sec):not(
    .core-focus-showcase
  ):not(#services) {
  background:
    linear-gradient(
      180deg,
      rgba(247, 252, 250, 0.97),
      rgba(255, 255, 255, 0.98)
    ),
    radial-gradient(
      circle at 18% 10%,
      rgba(44, 106, 163, 0.06),
      transparent 44%
    );
}

.sec-header {
  max-width: 940px;
  margin-inline: auto;
  margin-bottom: clamp(30px, 4vw, 44px);
  text-align: center;
}

.sec-header .eyebrow,
.intern-intro .eyebrow,
.ts-label,
.proj-sub-label,
.intern-cards-title span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 32px;
  margin-inline: auto;
  padding: 6px 13px;
  color: #176d20;
  border: 1px solid rgba(23, 109, 32, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 10px 24px rgba(7, 17, 24, 0.04);
}

.sec-header .eyebrow::before,
.intern-intro .eyebrow::before {
  content: "";
  width: 18px;
  height: 10px;
  border-radius: 999px 0 999px 0;
  background: linear-gradient(135deg, #2f8a2c, #74b83b);
  transform: rotate(28deg);
}

.sec-header .eyebrow::after,
.intern-intro .eyebrow::after,
.proj-sub-label::after,
.ts-label::after,
.intern-cards-title span::after {
  display: none;
}

.sec-header .h2 {
  color: #071725;
  letter-spacing: 0;
  text-wrap: balance;
}

.sec-header .h2 em,
.intern-intro .h2 em,
.cta-title em,
.qt em {
  color: #176d20;
  background: linear-gradient(90deg, #176d20, #2c6aa3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.sec-header .h2::after {
  content: "";
  display: block;
  width: 154px;
  height: 4px;
  margin: 16px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #176d20 0 48%, #2c6aa3 52% 100%);
}

.sec-header .lead,
.intern-intro .lead,
.partners-lead {
  margin-inline: auto;
  color: #26343b;
}

.sc:not(.focus-card),
.cc,
.pjc,
.sic,
.journey-card,
.vmc,
.sgc,
.partner-card,
.tmc,
.blc,
.tec,
.invc,
.locc,
.cii,
.form-wrap,
.intern-cta-card,
.ist-card,
.ictc-card,
.quote-wrap,
.services-showcase {
  border-color: rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      #fff 72%,
      #fbfdff 100%
    ),
    #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.sc:not(.focus-card):hover,
.cc:hover,
.pjc:hover,
.sic:hover,
.journey-card:hover,
.vmc:hover,
.sgc:hover,
.partner-card:hover,
.tmc:hover,
.blc:hover,
.tec:hover,
.invc:hover,
.locc:hover,
.cii:hover,
.form-wrap:hover,
.intern-cta-card:hover,
.ist-card:hover,
.ictc-card:hover,
.quote-wrap:hover {
  transform: translateY(-8px);
  border-color: rgba(44, 106, 163, 0.2);
  box-shadow:
    0 28px 74px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(23, 109, 32, 0.07) inset;
}

.sc:not(.focus-card),
.cc,
.pjc,
.sic,
.journey-card,
.vmc,
.sgc,
.partner-card,
.tmc,
.blc,
.tec,
.invc,
.locc,
.cii,
.form-wrap,
.intern-cta-card,
.ist-card,
.ictc-card,
.quote-wrap {
  transition:
    transform 260ms var(--ease-out, ease),
    border-color 260ms var(--ease-out, ease),
    box-shadow 260ms var(--ease-out, ease),
    background-color 260ms var(--ease-out, ease);
}

.sc:not(.focus-card)::before,
.tmc::before,
.tec::before {
  border-radius: 999px;
  background: linear-gradient(180deg, #2c6aa3, #f2b705, #5ed39b);
}

.sc-emoji,
.inv-ic,
.j-icon,
.loc-pin,
.cii-ic,
.tm-av,
.te-av,
.ist-card .ist-num,
.ictc-icon {
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.3),
      transparent 30%
    ),
    linear-gradient(145deg, #0b7c7d, #176d20);
  color: #fff;
  box-shadow:
    0 16px 30px rgba(7, 17, 24, 0.13),
    0 0 0 3px #fff;
}

.sc:not(.focus-card):hover .sc-emoji,
.invc:hover .inv-ic,
.journey-card:hover .j-icon,
.locc:hover .loc-pin,
.cii:hover .cii-ic,
.tmc:hover .tm-av,
.tec:hover .te-av,
.ist-card:hover .ist-num,
.intern-cta-card:hover .ictc-icon {
  transform: translateY(-5px) rotate(-4deg) scale(1.04);
}

.filter-bar {
  justify-content: center;
  padding: 10px;
  border: 1px solid rgba(7, 17, 24, 0.06);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 34px rgba(7, 17, 24, 0.05);
}

.filter-pill,
.cd-pill,
.cc-tag,
.pj-tag,
.bl-cat,
.partner-badge,
.loc-type,
.course-count {
  border-color: rgba(23, 109, 32, 0.14);
  color: #176d20;
  background: rgba(255, 255, 255, 0.72);
}

.ct,
.st,
.pj-title,
.sic-name,
.j-title,
.sgt,
.tm-name,
.bl-title,
.te-name,
.inv-t,
.loc-name,
.ictc-title,
.vmc-h {
  color: #071725;
  letter-spacing: 0;
}

.cx,
.sd,
.pj-desc,
.sic-quote,
.j-body,
.sgd,
.tm-role,
.tm-tagline,
.bl-exc,
.te-text,
.inv-d,
.loc-addr,
.ictc-desc,
.vmc-t,
.cii-val {
  color: #26343b;
}

.cl,
.sl,
.pj-link,
.bl-link,
.inv-btn,
.loc-link,
.btn-see-all {
  color: #074f63;
}

.cl:hover,
.sl:hover,
.pj-link:hover,
.bl-link:hover,
.loc-link:hover {
  color: #176d20;
}

.pj-vis,
.blc-top,
.sic-img,
.partner-logo-frame,
.partner-name-card,
.map-embed-shell {
  border-radius: 8px 8px 0 0;
}

.pj-vis::after,
.blc-top::after {
  content: "";
  position: absolute;
  left: -5%;
  right: -5%;
  bottom: -1px;
  height: 50px;
  background: #fff;
  clip-path: polygon(
    0 62%,
    18% 70%,
    38% 72%,
    60% 68%,
    80% 59%,
    100% 50%,
    100% 100%,
    0 100%
  );
  pointer-events: none;
}

.pj-vis {
  height: 220px;
  border-radius: 8px 8px 0 0;
}

.pjc:hover .pj-vis,
.blc:hover .blc-top,
.sic:hover .sic-img {
  transform: scale(1.045);
  filter: saturate(1.08);
}

.blc {
  height: auto;
  min-height: 390px;
}

.blc-top {
  position: relative;
  height: 190px;
  min-height: 190px;
  overflow: hidden;
  background-size: cover !important;
  background-position: center !important;
  transition:
    transform 420ms var(--ease-out, ease),
    filter 420ms var(--ease-out, ease);
}

.blc-body {
  position: relative;
  z-index: 1;
  padding-top: 4px;
}

.sic {
  overflow: hidden;
  padding: 0;
  contain: layout style paint;
  display: flex;
  flex-direction: column;
}

.sic-img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  transition:
    transform 420ms var(--ease-out, ease),
    filter 420ms var(--ease-out, ease);
  contain: layout;
}

.sic-body {
  padding: 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.journey-track::before {
  background: linear-gradient(180deg, #176d20, #2c6aa3, #f2b705);
}

.journey-dot {
  background: linear-gradient(135deg, #176d20, #2c6aa3);
  box-shadow:
    0 0 0 5px rgba(23, 109, 32, 0.12),
    0 12px 24px rgba(7, 17, 24, 0.12);
}

.sdg-sec,
.partners-sec,
#team,
.blog,
#testimonials,
.involved,
.map-sec,
#contact,
.courses,
#projects,
.internship-sec,
.journey {
  padding-block: clamp(76px, 8vw, 112px);
}

.sgc {
  min-height: 310px;
  overflow: hidden;
}

.sdg-icon,
.partner-logo-frame,
.partner-name-card {
  background:
    radial-gradient(
      circle at 30% 24%,
      rgba(255, 255, 255, 0.82),
      transparent 30%
    ),
    linear-gradient(
      145deg,
      rgba(247, 252, 250, 0.98),
      rgba(238, 248, 244, 0.95)
    );
}

.partner-track-outer {
  background: transparent;
}

.team,
#team {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 252, 250, 0.96)
    ),
    radial-gradient(circle at 80% 8%, rgba(44, 106, 163, 0.06), transparent 42%);
}

.ts-label,
.proj-sub-label,
.intern-cards-title {
  margin-inline: auto;
  text-align: center;
  border-left: 0;
  padding-left: 0;
}

.proj-sub-label {
  margin-top: 46px;
}

.quote-sec {
  background:
    linear-gradient(135deg, rgba(7, 23, 37, 0.98), rgba(13, 61, 42, 0.96)),
    #071725;
}

.quote-wrap {
  border: 1px solid rgba(255, 255, 255, 0.18);
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 252, 250, 0.96)
    ),
    #fff;
}

.qa {
  color: #176d20;
}

.map-embed-shell,
#ahsisGoogleMap {
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(7, 17, 24, 0.08);
  box-shadow: 0 18px 44px rgba(7, 17, 24, 0.08);
}

.form-wrap,
.contact-panel {
  position: relative;
  overflow: hidden;
}

.form-wrap::before,
.contact-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(
      105deg,
      transparent 0 36%,
      rgba(44, 106, 163, 0.08) 48%,
      transparent 63%
    ),
    radial-gradient(circle at 90% 8%, rgba(94, 211, 155, 0.14), transparent 30%);
  transform: translateX(-36%);
  opacity: 0.7;
}

.form-wrap > *,
.contact-panel > * {
  position: relative;
  z-index: 1;
}

.form-btn,
.btn-glow,
.btn-see-all:hover,
.inv-btn:hover,
.focus-card-link:hover,
.focus-card-link:focus-visible {
  background: linear-gradient(135deg, #176d20, #2c6aa3);
}

.cta-banner {
  background:
    linear-gradient(135deg, rgba(7, 23, 37, 0.98), rgba(13, 61, 42, 0.96)),
    #071725;
}

.cta-inner {
  max-width: 980px;
  margin-inline: auto;
  padding: clamp(30px, 5vw, 54px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background:
    linear-gradient(
      145deg,
      rgba(255, 255, 255, 0.1),
      rgba(255, 255, 255, 0.035)
    ),
    rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(12px);
}

@media (max-width: 900px) {
  .sec-header {
    margin-bottom: 28px;
  }

  .filter-bar {
    justify-content: flex-start;
    border-radius: 14px;
  }

  .course-count {
    width: 100%;
    margin-left: 0;
    text-align: center;
  }

  .blc-top,
  .sic-img {
    height: 210px;
    min-height: 210px;
  }
}

@media (max-width: 700px) {
  .sec-header .eyebrow,
  .intern-intro .eyebrow,
  .ts-label,
  .proj-sub-label,
  .intern-cards-title span {
    font-size: 10px;
    letter-spacing: 0.1em;
  }

  .sec-header .h2::after {
    width: 118px;
  }

  .sc:not(.focus-card):hover,
  .cc:hover,
  .pjc:hover,
  .sic:hover,
  .journey-card:hover,
  .vmc:hover,
  .sgc:hover,
  .partner-card:hover,
  .tmc:hover,
  .blc:hover,
  .tec:hover,
  .invc:hover,
  .locc:hover,
  .cii:hover,
  .form-wrap:hover,
  .intern-cta-card:hover,
  .ist-card:hover,
  .ictc-card:hover,
  .quote-wrap:hover {
    transform: none;
  }
}

/* Final mobile responsiveness pass */
html,
body {
  max-width: 100%;
  overflow-x: clip;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden;
  }
}

img,
video,
iframe {
  max-width: 100%;
}

section[id] {
  scroll-margin-top: 124px;
}

@media (max-width: 899px) {
  :root {
    --wrap-pad: clamp(16px, 4.5vw, 22px);
  }

  body {
    padding-top: 0 !important;
  }

  #nav {
    position: fixed;
    inset: 0 0 auto 0;
    width: 100%;
    max-width: none;
    padding: 0;
    border-radius: 0;
    transform: none !important;
    z-index: 700;
    background: rgba(255, 255, 255, 0.98);
    border-bottom: 1px solid rgba(7, 17, 24, 0.08);
    box-shadow: 0 8px 28px rgba(7, 17, 24, 0.08);
  }

  #nav.nav-loaded {
    transform: none !important;
  }

  #nav .nav-wrap {
    min-height: 64px;
    height: auto;
    padding: 8px 14px;
    gap: 10px;
  }

  #nav .nav-brand {
    flex: 1 1 auto;
    min-width: 0;
    gap: 10px;
  }

  #nav .logo {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-width: 2px;
    border-radius: 12px;
  }

  #nav .logo-svg {
    width: 32px;
    height: 32px;
  }

  #nav .nav-name {
    display: block;
    font-size: 16px;
    line-height: 1;
  }

  #nav .nav-sub {
    display: none;
  }

  #nav .nav-links,
  #nav .nav-cta {
    display: none !important;
  }

  #nav .nav-right {
    flex: 0 0 auto;
    gap: 8px;
  }

  #nav .ham {
    display: inline-flex !important;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid rgba(7, 17, 24, 0.12);
    border-radius: 12px;
    background: rgba(7, 17, 24, 0.04);
  }

  #nav .ham span {
    background: var(--text-ink);
    transition:
      transform 180ms var(--ease-out),
      opacity 180ms var(--ease-out);
  }

  .news-ticker-wrap {
    top: 64px !important;
    height: 40px;
    min-height: 40px;
    z-index: 680 !important;
    padding-inline: 8px;
  }

  .ticker-track-outer {
    margin-left: 0;
    mask-image: linear-gradient(
      90deg,
      #000 0,
      #000 calc(100% - 28px),
      transparent 100%
    );
    -webkit-mask-image: linear-gradient(
      90deg,
      #000 0,
      #000 calc(100% - 28px),
      transparent 100%
    );
  }

  .ticker-item {
    gap: 7px;
    padding: 0 12px;
    font-size: 12.5px;
    line-height: 1.2;
  }

  /* ===== Partner carousel & visual fixes overrides ===== */
  /* Remove the large decorative band and use a neutral background */
  .partners-sec::after {
    display: none !important;
    background: none !important;
    height: 0 !important;
  }
  .partners-sec {
    background: var(--surface-white) !important;
  }

  /* Carousel controls (inserted by JS) */
  .partners-sec .partner-prev,
  .partners-sec .partner-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    background: var(--surface-white);
    border: 1px solid var(--surface-border);
    color: var(--text-ink2);
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
  }
  .partners-sec .partner-prev {
    left: 8px;
  }
  .partners-sec .partner-next {
    right: 8px;
  }
  .partners-sec .partner-prev svg,
  .partners-sec .partner-next svg {
    stroke: var(--text-ink2);
    width: 16px;
    height: 16px;
  }

  /* Disable the CSS marquee when carousel is active */
  .partners-sec .partner-track.carousel-enabled {
    animation: none !important;
    transition: transform 420ms cubic-bezier(0.2, 0.9, 0.2, 1);
    will-change: transform;
  }

  @media (max-width: 900px) {
    /* hide controls on small screens (touch swipe supported) */
    .partners-sec .partner-prev,
    .partners-sec .partner-next {
      display: none;
    }
  }

  .ticker-controls {
    margin-left: 6px;
  }

  .ticker-controls .ticker-btn {
    width: 34px;
    height: 30px;
    justify-content: center;
    padding: 0;
    border-radius: 8px;
  }

  .mobile-menu {
    top: 104px !important;
    z-index: 670;
    max-height: calc(100svh - 104px);
    padding: 0;
    background: rgba(255, 255, 255, 0.98);
    border-top: 1px solid rgba(7, 17, 24, 0.08);
    border-bottom: 1px solid rgba(7, 17, 24, 0.08);
    box-shadow: 0 22px 44px rgba(7, 17, 24, 0.14);
  }

  .mobile-menu ul {
    padding: 12px var(--wrap-pad) calc(16px + env(safe-area-inset-bottom));
    gap: 4px;
  }

  .mobile-menu a {
    color: var(--text-ink);
    padding: 13px 12px;
    border: 0;
    border-radius: 10px;
  }

  .mobile-menu a:hover,
  .mobile-menu a:focus-visible {
    color: var(--text-ink);
    background: var(--surface-soft);
    padding-left: 12px;
  }

  .mobile-menu-cta {
    margin-top: 6px;
    color: #fff !important;
    text-align: center;
    background: linear-gradient(90deg, var(--color-brand), var(--color-action));
  }

  .hero {
    min-height: 100svh;
    padding-top: 104px;
    justify-content: flex-start;
  }

  .hero-inner {
    display: block;
    width: 100%;
    padding: 34px var(--wrap-pad) 92px;
  }

  .hero-inner > div:first-child::before {
    inset: -18px;
    background: radial-gradient(
      ellipse at 28% 46%,
      rgba(6, 12, 18, 0.82) 0%,
      rgba(6, 12, 18, 0.52) 46%,
      rgba(6, 12, 18, 0) 78%
    );
  }

  .hero-eyebrow {
    max-width: 100%;
    margin-bottom: 12px;
    font-size: 9.5px;
    letter-spacing: 0.13em;
    line-height: 1.5;
    white-space: normal;
  }

  .hero-title {
    font-size: clamp(34px, 12vw, 52px);
    line-height: 0.98;
    letter-spacing: 0;
  }

  .hero-desc {
    max-width: none;
    margin-top: 14px;
    font-size: 14.5px;
    line-height: 1.62;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 22px;
  }

  .hero .btn-glow,
  .hero .btn-ghost-dark {
    width: 100%;
    min-height: 52px;
    justify-content: center;
    text-align: center;
  }

  .hero-signal-strip {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 18px;
  }

  .hero-signal-strip span {
    min-height: 42px;
    justify-content: space-between;
    padding: 10px 14px;
    font-size: 13px;
  }

  section {
    padding-block: clamp(48px, 12vw, 72px);
  }

  .h2 {
    font-size: clamp(28px, 9vw, 40px);
    line-height: 1.12;
    letter-spacing: 0;
  }

  .lead {
    max-width: none;
    font-size: 15px;
    line-height: 1.65;
  }

  .grid2,
  .ct-grid,
  .loc-grid,
  .inv-grid,
  .footer-grid,
  .m-grid2 {
    grid-template-columns: 1fr !important;
  }

  .stats-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-inline: var(--wrap-pad);
    padding: 16px;
    gap: 12px;
  }

  .si {
    min-width: 0;
    padding: 12px 8px;
  }

  .si-num {
    font-size: clamp(24px, 9vw, 38px);
  }

  .si-lbl {
    font-size: 11px;
    line-height: 1.35;
  }

  #weatherWidget {
    left: 12px;
    right: auto;
    bottom: calc(66px + env(safe-area-inset-bottom));
    width: min(244px, calc(100vw - 24px));
    min-width: 0;
    max-height: none;
    overflow: auto;
    padding: 10px 12px;
    border-radius: 14px;
  }

  #weatherWidget.hidden {
    transform: translateY(12px);
  }

  .wx-tabs {
    overflow-x: auto;
    gap: 4px;
    margin-bottom: 7px;
    padding-bottom: 2px;
  }

  .wx-tab {
    flex: 0 0 auto;
    padding: 5px 7px;
    font-size: 8px;
  }

  .wx-header {
    margin-bottom: 6px;
  }

  .wx-body {
    gap: 10px;
  }

  .wx-icon {
    width: 40px;
    height: 40px;
    font-size: 24px;
  }

  .wx-temp {
    font-size: 28px;
  }

  .wx-desc {
    font-size: 11px;
  }

  .wx-meta {
    display: none;
  }

  #toast {
    bottom: calc(72px + env(safe-area-inset-bottom));
  }
}

@media (max-width: 700px) {
  #stickyBar {
    height: calc(58px + env(safe-area-inset-bottom));
    z-index: 690;
    padding-bottom: env(safe-area-inset-bottom);
  }

  .sb-btn {
    min-width: 0;
    height: 58px;
  }

  .sb-label {
    display: none;
  }
}

@media (max-width: 430px) {
  #nav .nav-wrap {
    min-height: 62px;
    padding-inline: 10px;
  }

  #nav .logo {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
  }

  #nav .nav-name {
    font-size: 15px;
  }

  .news-ticker-wrap {
    top: 62px !important;
  }

  .mobile-menu {
    top: 102px !important;
    max-height: calc(100svh - 102px);
  }

  .hero {
    padding-top: 102px;
  }

  .hero-inner {
    padding-top: 28px;
    padding-bottom: 92px;
  }

  .hero-title {
    font-size: clamp(32px, 12vw, 46px);
  }

  #weatherWidget {
    width: min(232px, calc(100vw - 24px));
  }

  #weatherWidget .wx-tabs {
    display: none;
  }
}

@media (min-width: 900px) and (max-width: 1140px) {
  #nav {
    width: calc(100% - 32px);
  }

  #nav .nav-wrap {
    gap: 12px;
  }

  #nav .nav-links a {
    padding-inline: 8px;
    font-size: 12.5px;
  }

  #nav .nav-cta {
    padding-inline: 12px;
    font-size: 12px;
  }
}

/* Partner marquee refresh: full-visibility logos and polished text fallbacks */
.partners-sec {
  --partner-card-w: 276px;
  --partner-logo-h: 94px;
  background:
    repeating-linear-gradient(
      90deg,
      oklch(100% 0 0 / 0.04) 0 1px,
      transparent 1px 92px
    ),
    linear-gradient(
      115deg,
      oklch(9% 0.045 152),
      oklch(13% 0.045 205) 54%,
      oklch(10% 0.035 152)
    );
  padding-block: clamp(68px, 8vw, 104px);
}

.partners-sec::before,
section.partners-sec.alive-section:not(.hero):not(.intel-sec)::before,
section.partners-sec.alive-section.is-awake:not(.hero):not(.intel-sec)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-action) l c h / 0.12),
      transparent
    ),
    repeating-linear-gradient(
      135deg,
      transparent 0 58px,
      oklch(100% 0 0 / 0.035) 58px 59px,
      transparent 59px 122px
    );
  opacity: 0.5;
  transform: none;
  animation: none;
}

.partners-sec::after,
section.partners-sec.alive-section:not(.hero):not(.intel-sec)::after,
section.partners-sec.alive-section.is-awake:not(.hero):not(.intel-sec)::after {
  content: "";
  position: absolute;
  left: max(20px, calc((100vw - var(--wrap-max, 1240px)) / 2));
  right: max(20px, calc((100vw - var(--wrap-max, 1240px)) / 2));
  top: 0;
  z-index: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent,
    var(--color-gold),
    var(--color-action),
    transparent
  );
  opacity: 0.55;
  transform: none;
}

.partners-sec > .wrap,
.partners-sec .partner-track-outer {
  position: relative;
  z-index: 1;
}

.partners-sec .sec-header {
  margin-bottom: 26px;
}

.partners-sec .partners-lead {
  color: oklch(100% 0 0 / 0.76);
}

.partners-sec .partner-track-outer {
  padding-block: 18px 24px;
  margin-top: 8px;
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 7%,
    #000 93%,
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 7%,
    #000 93%,
    transparent 100%
  );
}

.partners-sec .partner-track {
  gap: 20px;
  padding-inline: 24px;
  animation-duration: 52s;
}

.partners-sec .partner-track:hover,
.partners-sec .partner-track:focus-within {
  animation-play-state: paused;
}

.partners-sec .partner-track-outer.is-static {
  mask-image: none;
  -webkit-mask-image: none;
}

.partners-sec .partner-track.is-static {
  width: min(100% - 32px, 980px);
  margin-inline: auto;
  padding-inline: 0;
  justify-content: center;
  flex-wrap: wrap;
  animation: none;
}

.partners-sec .partner-card {
  width: var(--partner-card-w);
  min-width: var(--partner-card-w);
  min-height: 152px;
  height: auto;
  margin: 0;
  padding: 12px;
  border-radius: 8px;
  border: 1px solid oklch(100% 0 0 / 0.16);
  background:
    linear-gradient(180deg, oklch(100% 0 0 / 0.12), oklch(100% 0 0 / 0.055)),
    oklch(100% 0 0 / 0.02);
  box-shadow:
    0 20px 52px oklch(3% 0.02 152 / 0.28),
    inset 0 1px 0 oklch(100% 0 0 / 0.14);
  isolation: isolate;
}

.partners-sec .partner-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  height: auto;
  border-radius: inherit;
  background: linear-gradient(
    135deg,
    oklch(from var(--color-gold) l c h / 0.2),
    transparent 42%,
    oklch(from var(--color-action) l c h / 0.16)
  );
  opacity: 0;
  transform: none;
  transition: opacity 260ms var(--ease-out, ease);
}

.partners-sec .partner-card:hover,
.partners-sec .partner-card:focus-within,
.partners-sec .partner-card.alive-card:hover {
  transform: translateY(-7px) scale(1.018);
  border-color: oklch(from var(--color-gold) l c h / 0.48);
  box-shadow:
    0 28px 70px oklch(3% 0.02 152 / 0.34),
    0 0 0 1px oklch(from var(--color-gold) l c h / 0.1) inset;
}

.partners-sec .partner-card:hover::before,
.partners-sec .partner-card:focus-within::before {
  opacity: 1;
}

.partners-sec .partner-link {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 128px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 10px;
  text-align: center;
}

.partners-sec .partner-link:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 5px;
  box-shadow: none;
}

.partners-sec .partner-logo-frame,
.partners-sec .partner-name-card {
  position: relative;
  width: 100%;
  height: var(--partner-logo-h);
  border-radius: 8px;
  overflow: hidden;
}

.partners-sec .partner-logo-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  background:
    linear-gradient(180deg, oklch(100% 0 0), oklch(96% 0.008 85)), #fff;
  border: 1px solid oklch(100% 0 0 / 0.74);
  box-shadow:
    0 14px 30px oklch(4% 0.02 152 / 0.18),
    inset 0 1px 0 oklch(100% 0 0 / 0.86);
  animation: partnerBayBreath 6.5s ease-in-out infinite;
}

.partners-sec .partner-logo-frame::after,
.partners-sec .partner-name-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 0 38%,
    oklch(100% 0 0 / 0.5) 48%,
    transparent 60%
  );
  transform: translateX(-120%);
  transition: transform 620ms var(--ease-out, ease);
}

.partners-sec .partner-card:hover .partner-logo-frame::after,
.partners-sec .partner-card:focus-within .partner-logo-frame::after,
.partners-sec .partner-card:hover .partner-name-card::after,
.partners-sec .partner-card:focus-within .partner-name-card::after {
  transform: translateX(120%);
}

.partners-sec .partner-logo-img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  filter: none;
  opacity: 1;
  transform: none;
  transition:
    transform 240ms var(--ease-spring, ease),
    filter 240ms var(--ease-out, ease);
}

.partners-sec .partner-card:hover .partner-logo-img,
.partners-sec .partner-card:focus-within .partner-logo-img {
  transform: scale(1.04);
  filter: saturate(1.08) contrast(1.03);
}

.partners-sec .partner-name-card {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 18px 18px 74px;
  border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.24);
  background:
    linear-gradient(
      135deg,
      oklch(from var(--color-brand-bright) l c h / 0.22),
      transparent 46%
    ),
    linear-gradient(180deg, oklch(100% 0 0 / 0.16), oklch(100% 0 0 / 0.07));
  box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.2);
  animation: partnerBayBreath 7.2s ease-in-out infinite;
}

.partners-sec .partner-name-card::before {
  content: attr(data-initial);
  position: absolute;
  left: 16px;
  top: 50%;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  transform: translateY(-50%);
  color: oklch(12% 0.035 152);
  background: linear-gradient(
    135deg,
    var(--color-gold),
    var(--color-brand-bright)
  );
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 20px;
  font-weight: 900;
  box-shadow: 0 10px 24px oklch(from var(--color-gold) l c h / 0.22);
}

.partners-sec .partner-logo-text {
  display: block;
  width: 100%;
  color: #fff;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 850;
  line-height: 1.22;
  letter-spacing: 0;
  text-wrap: balance;
  overflow-wrap: anywhere;
  filter: none;
  text-shadow: 0 8px 26px oklch(0% 0 0 / 0.24);
}

/* ===== Fix: Internship showcase images should not be cropped ===== */
/* High-specificity, last-resort override to ensure full images are visible */
#grid-interns .sic-img,
.internship-sec #grid-interns .sic-img,
.sic-grid .sic-img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  border-radius: 8px 8px 0 0 !important;
  background-color: var(--surface-off) !important;
}

/* Prevent the card hover scaling from cropping the image in this grid */
#grid-interns .sic:hover .sic-img,
#grid-interns .sic:focus-within .sic-img {
  transform: none !important;
}

.partners-sec .partner-badge {
  align-self: center;
  max-width: 100%;
  margin-top: 0;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid oklch(from var(--color-gold) l c h / 0.26);
  background: oklch(from var(--color-gold) l c h / 0.12);
  color: oklch(96% 0.025 78);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: uppercase;
  white-space: normal;
  opacity: 1;
}

.partners-sec .partner-card:hover .partner-badge,
.partners-sec .partner-card:focus-within .partner-badge {
  transform: translateY(-1px);
  border-color: oklch(from var(--color-gold) l c h / 0.44);
  color: #fff;
}

.partners-sec .partner-card:nth-child(2n) .partner-logo-frame,
.partners-sec .partner-card:nth-child(2n) .partner-name-card {
  animation-delay: -2.1s;
}

.partners-sec .partner-card:nth-child(3n) .partner-logo-frame,
.partners-sec .partner-card:nth-child(3n) .partner-name-card {
  animation-delay: -3.4s;
}

@keyframes partnerBayBreath {
  0%,
  100% {
    box-shadow:
      0 14px 30px oklch(4% 0.02 152 / 0.18),
      inset 0 1px 0 oklch(100% 0 0 / 0.86);
  }
  50% {
    box-shadow:
      0 18px 38px oklch(from var(--color-gold) l c h / 0.18),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }
}

@media (max-width: 900px) {
  .partners-sec {
    --partner-card-w: 222px;
    --partner-logo-h: 78px;
  }

  .partners-sec .partner-track {
    gap: 14px;
    padding-inline: 16px;
    animation-duration: 40s;
  }

  .partners-sec .partner-card {
    min-height: 132px;
    padding: 10px;
  }

  .partners-sec .partner-link {
    min-height: 112px;
  }

  .partners-sec .partner-logo-frame {
    padding: 12px 14px;
  }

  .partners-sec .partner-name-card {
    padding: 14px 14px 14px 60px;
  }

  .partners-sec .partner-name-card::before {
    left: 12px;
    width: 36px;
    height: 36px;
    font-size: 17px;
  }

  .partners-sec .partner-logo-text {
    font-size: 14px;
  }
}

@media (max-width: 520px) {
  .partners-sec {
    --partner-card-w: 196px;
    --partner-logo-h: 72px;
    padding-block: 58px;
  }

  .partners-sec .partner-track-outer {
    mask-image: linear-gradient(
      90deg,
      transparent 0,
      #000 24px,
      #000 calc(100% - 24px),
      transparent 100%
    );
    -webkit-mask-image: linear-gradient(
      90deg,
      transparent 0,
      #000 24px,
      #000 calc(100% - 24px),
      transparent 100%
    );
  }

  .partners-sec .partner-badge {
    font-size: 9px;
    padding: 5px 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .partners-sec .partner-logo-frame,
  .partners-sec .partner-name-card {
    animation: none !important;
  }
}

/* Full-site alive pass: section atmospheres, card energy, richer interactions */
section.alive-section,
.quote-sec.alive-section,
.cta-banner.alive-section {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

section.alive-section > .wrap,
.quote-sec.alive-section > .wrap,
.cta-banner.alive-section > .wrap {
  position: relative;
  z-index: 1;
}

section.alive-section:not(.hero):not(.intel-sec)::before,
.quote-sec.alive-section::before,
.cta-banner.alive-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(
      100deg,
      transparent 0 54px,
      rgba(14, 165, 233, 0.045) 54px 55px,
      transparent 55px 120px
    ),
    linear-gradient(
      90deg,
      transparent,
      rgba(255, 214, 106, 0.06) calc(var(--alive-progress, 0) * 100%),
      transparent
    );
  background-size:
    190px 190px,
    100% 100%;
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  transition:
    opacity 700ms var(--ease-out, ease),
    transform 700ms var(--ease-out, ease);
}

section.alive-section:not(.hero):not(.intel-sec).is-awake::before,
.quote-sec.alive-section.is-awake::before,
.cta-banner.alive-section.is-awake::before {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  animation: aliveSurfaceDrift 18s linear infinite;
}

section.alive-section:not(.hero):not(.intel-sec)::after {
  content: "";
  position: absolute;
  left: max(20px, calc((100vw - var(--wrap-max, 1240px)) / 2));
  right: max(20px, calc((100vw - var(--wrap-max, 1240px)) / 2));
  top: 0;
  z-index: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(14, 165, 233, 0.28),
    rgba(255, 214, 106, 0.34),
    rgba(94, 211, 155, 0.25),
    transparent
  );
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 900ms var(--ease-spring, ease);
}

section.alive-section.is-awake:not(.hero):not(.intel-sec)::after {
  transform: scaleX(1);
}

.alive-card {
  --card-delay: 0ms;
  --mx: 50%;
  --my: 50%;
  position: relative;
  isolation: isolate;
  transform-style: preserve-3d;
  transition:
    transform 240ms var(--ease-out, ease),
    border-color 240ms var(--ease-out, ease),
    box-shadow 240ms var(--ease-out, ease),
    filter 240ms var(--ease-out, ease);
}

.alive-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(
      115deg,
      transparent 0 36%,
      rgba(255, 255, 255, 0.28) 48%,
      transparent 62%
    ),
    radial-gradient(
      circle at var(--mx) var(--my),
      rgba(255, 214, 106, 0.12),
      transparent 34%
    );
  opacity: 0;
  transform: translateX(-24%);
  transition:
    opacity 220ms var(--ease-out, ease),
    transform 520ms var(--ease-out, ease);
  mix-blend-mode: soft-light;
}

.alive-card.is-awake {
  animation: cardWake 680ms var(--ease-spring, ease) both;
  animation-delay: var(--card-delay);
}

.alive-card:hover,
.alive-card:focus-within {
  filter: saturate(1.04);
}

.alive-card:hover::after,
.alive-card:focus-within::after {
  opacity: 1;
  transform: translateX(18%);
}

.fc.alive-card:hover,
.sc.alive-card:hover,
.cc.alive-card:hover,
.pjc.alive-card:hover,
.sic.alive-card:hover,
.tmc.alive-card:hover,
.blc.alive-card:hover,
.tec.alive-card:hover,
.invc.alive-card:hover,
.locc.alive-card:hover,
.journey-card.alive-card:hover,
.sgc.alive-card:hover {
  box-shadow:
    0 30px 86px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(14, 165, 233, 0.08) inset;
}

.sc.alive-card .sc-emoji,
.fc.alive-card .fc-icon,
.inv-ic,
.j-icon,
.te-av,
.tm-av,
.loc-pin {
  transition:
    transform 300ms var(--ease-spring, ease),
    box-shadow 300ms var(--ease-out, ease),
    filter 300ms var(--ease-out, ease);
}

.sc.alive-card:hover .sc-emoji,
.fc.alive-card:hover .fc-icon,
.invc.alive-card:hover .inv-ic,
.journey-card.alive-card:hover .j-icon,
.tec.alive-card:hover .te-av,
.tmc.alive-card:hover .tm-av,
.locc.alive-card:hover .loc-pin {
  transform: translateY(-4px) rotate(-3deg) scale(1.05);
  filter: saturate(1.08);
}

.pjc.alive-card:hover .pj-vis-grid {
  animation: aliveGridSlide 6s linear infinite;
}

.pjc.alive-card:hover .pj-link svg,
.blc.alive-card:hover .bl-link svg,
.cc.alive-card:hover .cl svg,
.sc.alive-card:hover .sl svg {
  transform: translateX(7px);
}

.stats-bar,
.quote-wrap,
.cta-inner,
.contact-panel,
.map-embed-shell,
.crop-table-wrap,
.mission-visual,
.intel-stage {
  transition:
    transform 300ms var(--ease-out, ease),
    box-shadow 300ms var(--ease-out, ease),
    border-color 300ms var(--ease-out, ease);
}

.stats-bar:hover,
.quote-wrap:hover,
.cta-inner:hover,
.contact-panel:hover,
.map-embed-shell:hover,
.crop-table-wrap:hover,
.mission-visual:hover {
  transform: translateY(-4px);
  box-shadow:
    0 30px 86px rgba(7, 17, 24, 0.12),
    0 0 0 1px rgba(255, 214, 106, 0.08) inset;
}

.si,
.ist-card,
.contact-panel-stat,
.crop-leg,
.bp,
.mp,
.cd-pill,
.partner-badge,
.cc-tag,
.pj-tag,
.bl-cat,
.loc-type {
  transition:
    transform 220ms var(--ease-out, ease),
    background-color 220ms var(--ease-out, ease),
    border-color 220ms var(--ease-out, ease),
    color 220ms var(--ease-out, ease);
}

.si:hover,
.ist-card:hover,
.contact-panel-stat:hover,
.crop-leg:hover,
.bp:hover,
.mp:hover,
.cd-pill:hover {
  transform: translateY(-2px);
}

.sec-header .eyebrow,
.eyebrow,
.proj-sub-label,
.ts-label,
.intern-cards-title span {
  position: relative;
}

.sec-header .eyebrow::after,
.eyebrow::after,
.proj-sub-label::after,
.ts-label::after,
.intern-cards-title span::after {
  content: "";
  position: absolute;
  left: 0;
  right: auto;
  bottom: -8px;
  width: 36px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    var(--color-action),
    var(--color-gold),
    var(--color-brand-bright)
  );
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 700ms var(--ease-spring, ease);
}

.is-awake .sec-header .eyebrow::after,
.is-awake .eyebrow::after,
.is-awake .proj-sub-label::after,
.is-awake .ts-label::after,
.is-awake .intern-cards-title span::after {
  transform: scaleX(1);
}

.partner-card.alive-card {
  overflow: hidden;
}

.partner-card.alive-card:hover {
  transform: translateY(-5px) scale(1.015);
  border-color: rgba(14, 165, 233, 0.2);
}

.sdg-grid .sgc.alive-card {
  overflow: hidden;
}

.sdg-grid .sgc.alive-card:hover {
  transform: translateY(-7px) scale(1.018);
}

.tec.alive-card {
  overflow: hidden;
}

.tec.alive-card .te-q-mark {
  transition:
    transform 300ms var(--ease-spring, ease),
    opacity 300ms ease;
}

.tec.alive-card:hover .te-q-mark {
  transform: translateY(-8px) rotate(-5deg) scale(1.08);
  opacity: 0.88;
}

.cta-inner {
  overflow: hidden;
}

.cta-inner::before {
  content: "";
  position: absolute;
  inset: -10% -35%;
  pointer-events: none;
  background: linear-gradient(
    110deg,
    transparent 0 42%,
    rgba(255, 255, 255, 0.18) 50%,
    transparent 60%
  );
  mix-blend-mode: screen;
  opacity: 0.72;
  animation: ctaEnergySweep 7s ease-in-out infinite;
}

@keyframes aliveSurfaceDrift {
  from {
    background-position:
      0 0,
      0 0;
  }
  to {
    background-position:
      190px 190px,
      0 0;
  }
}

@keyframes cardWake {
  from {
    opacity: 0.72;
    transform: translateY(18px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes aliveGridSlide {
  from {
    background-position:
      0 0,
      0 0;
  }
  to {
    background-position:
      24px 24px,
      24px 24px;
  }
}

@keyframes ctaEnergySweep {
  0%,
  45% {
    transform: translateX(-120%);
  }
  70%,
  100% {
    transform: translateX(120%);
  }
}

@media (max-width: 760px) {
  .alive-card:hover,
  .alive-card:focus-within,
  .stats-bar:hover,
  .quote-wrap:hover,
  .cta-inner:hover,
  .contact-panel:hover,
  .map-embed-shell:hover,
  .crop-table-wrap:hover,
  .mission-visual:hover {
    transform: none;
  }

  .alive-card::after {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  section.alive-section:not(.hero):not(.intel-sec).is-awake::before,
  .quote-sec.alive-section.is-awake::before,
  .cta-banner.alive-section.is-awake::before,
  .alive-card.is-awake,
  .pjc.alive-card:hover .pj-vis-grid,
  .cta-inner::before {
    animation: none !important;
  }

  .alive-card,
  .stats-bar,
  .quote-wrap,
  .cta-inner,
  .contact-panel,
  .map-embed-shell,
  .crop-table-wrap,
  .mission-visual {
    transition: none !important;
    transform: none !important;
  }
}

/* Frontend premium visual pass: hero signals + intelligence stack */
.hero-signal-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
  max-width: 680px;
}

.hero-signal-strip span {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-pill, 999px);
  color: rgba(255, 255, 255, 0.9);
  background:
    linear-gradient(
      120deg,
      rgba(255, 255, 255, 0.12),
      rgba(255, 255, 255, 0.035)
    ),
    rgba(4, 14, 22, 0.24);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(16px);
  overflow: hidden;
}

.hero-signal-strip span::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    transparent 0%,
    rgba(255, 255, 255, 0.24) 48%,
    transparent 74%
  );
  transform: translateX(-120%);
  animation: signalSheen 5.6s ease-in-out infinite;
}

.hero-signal-strip span:nth-child(2)::after {
  animation-delay: 0.7s;
}

.hero-signal-strip span:nth-child(3)::after {
  animation-delay: 1.4s;
}

.hero-signal-strip strong {
  color: var(--color-gold);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.72rem;
  letter-spacing: 0;
}

.intel-sec {
  position: relative;
  overflow: hidden;
  padding: clamp(76px, 8vw, 116px) 0;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(7, 17, 24, 0.96), rgba(11, 37, 32, 0.98)),
    var(--surface-hero);
  isolation: isolate;
}

.intel-sec::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 14%,
    #000 82%,
    transparent
  );
  animation: intelGridDrift 18s linear infinite;
}

.intel-sec::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 214, 106, 0.45),
    rgba(94, 211, 155, 0.42),
    transparent
  );
}

.intel-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  align-items: center;
  gap: 54px;
}

.intel-copy .eyebrow {
  color: var(--color-gold);
}

.intel-copy .h2,
.intel-copy .lead {
  color: #fff;
}

.intel-copy .lead {
  max-width: 620px;
  color: rgba(255, 255, 255, 0.78);
}

.intel-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 28px;
}

.intel-proof {
  position: relative;
  min-height: 172px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  background:
    linear-gradient(
      160deg,
      rgba(255, 255, 255, 0.105),
      rgba(255, 255, 255, 0.035)
    ),
    rgba(255, 255, 255, 0.035);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14);
  overflow: hidden;
}

.intel-proof::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--color-action-light),
    var(--color-gold),
    var(--color-brand-bright)
  );
  transform: scaleX(0.34);
  transform-origin: left;
  transition: transform 260ms var(--ease-out, ease);
}

.intel-proof:hover::before {
  transform: scaleX(1);
}

.intel-proof span {
  display: inline-flex;
  margin-bottom: 16px;
  color: var(--color-gold);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0;
}

.intel-proof strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.05rem;
  font-weight: 850;
}

.intel-proof p {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.92rem;
  line-height: 1.65;
}

.intel-stage {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  position: relative;
  min-height: 560px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(8, 24, 34, 0.92), rgba(11, 44, 38, 0.9)),
    rgba(8, 24, 34, 0.94);
  box-shadow:
    0 34px 90px rgba(0, 0, 0, 0.36),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  overflow: hidden;
  transform: perspective(900px) rotateX(var(--tilt-y)) rotateY(var(--tilt-x));
  transition:
    transform 240ms var(--ease-out, ease),
    border-color 240ms ease;
}

.intel-stage:hover {
  border-color: rgba(255, 214, 106, 0.28);
}

.intel-grid-lines {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, 0.065) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px),
    linear-gradient(
      135deg,
      transparent 0 48%,
      rgba(94, 211, 155, 0.12) 49% 51%,
      transparent 52%
    );
  background-size:
    38px 38px,
    38px 38px,
    160px 160px;
  opacity: 0.72;
}

.intel-sweep {
  position: absolute;
  inset: -35%;
  background: conic-gradient(
    from 0deg,
    transparent 0 64%,
    rgba(139, 198, 255, 0.16),
    rgba(255, 214, 106, 0.18),
    transparent 80% 100%
  );
  animation: intelSweep 9s linear infinite;
  mix-blend-mode: screen;
}

.intel-core {
  position: absolute;
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  width: 190px;
  height: 190px;
  padding: 24px;
  border: 1px solid rgba(255, 214, 106, 0.34);
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 50% 18%,
      rgba(255, 214, 106, 0.18),
      transparent 44%
    ),
    linear-gradient(180deg, rgba(8, 20, 27, 0.92), rgba(13, 56, 44, 0.92));
  box-shadow:
    0 0 0 18px rgba(255, 255, 255, 0.035),
    0 0 0 56px rgba(94, 211, 155, 0.035),
    0 20px 60px rgba(0, 0, 0, 0.34);
  text-align: center;
  transform: translate(-50%, -50%);
  animation: intelCorePulse 4.6s ease-in-out infinite;
}

.intel-core-kicker,
.intel-core small,
.intel-node span,
.intel-readout span {
  color: rgba(255, 255, 255, 0.58);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.66rem;
  font-weight: 750;
  letter-spacing: 0;
  text-transform: uppercase;
}

.intel-core strong {
  color: #fff;
  font-size: 1.36rem;
  line-height: 1.05;
}

.intel-node {
  position: absolute;
  display: grid;
  gap: 5px;
  min-width: 156px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 14px;
  background:
    linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.13),
      rgba(255, 255, 255, 0.045)
    ),
    rgba(8, 18, 25, 0.62);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(12px);
  animation: intelNodeFloat 6.2s ease-in-out infinite;
}

.intel-node::before {
  content: "";
  position: absolute;
  inset: 9px auto auto 9px;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--color-brand-bright);
  box-shadow: 0 0 18px rgba(94, 211, 155, 0.6);
}

.intel-node strong {
  color: #fff;
  font-size: 0.96rem;
}

.intel-node-a {
  top: 70px;
  left: 52px;
}

.intel-node-b {
  top: 84px;
  right: 58px;
  animation-delay: -1.2s;
}

.intel-node-c {
  bottom: 122px;
  left: 42px;
  animation-delay: -2.1s;
}

.intel-node-d {
  right: 48px;
  bottom: 104px;
  animation-delay: -3.2s;
}

.intel-readout {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 18px;
  background: rgba(3, 13, 20, 0.58);
  backdrop-filter: blur(16px);
}

.intel-readout div {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
}

.intel-readout strong {
  color: #fff;
  font-size: 0.96rem;
}

@keyframes signalSheen {
  0%,
  46% {
    transform: translateX(-120%);
  }
  62%,
  100% {
    transform: translateX(140%);
  }
}

@keyframes intelGridDrift {
  from {
    background-position:
      0 0,
      0 0;
  }
  to {
    background-position:
      56px 56px,
      56px 56px;
  }
}

@keyframes intelSweep {
  to {
    transform: rotate(1turn);
  }
}

@keyframes intelCorePulse {
  0%,
  100% {
    box-shadow:
      0 0 0 18px rgba(255, 255, 255, 0.035),
      0 0 0 56px rgba(94, 211, 155, 0.035),
      0 20px 60px rgba(0, 0, 0, 0.34);
  }
  50% {
    box-shadow:
      0 0 0 24px rgba(255, 214, 106, 0.045),
      0 0 0 66px rgba(139, 198, 255, 0.045),
      0 24px 72px rgba(0, 0, 0, 0.4);
  }
}

@keyframes intelNodeFloat {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

@media (max-width: 1100px) {
  .intel-layout {
    grid-template-columns: 1fr;
  }

  .intel-stage {
    min-height: 520px;
  }
}

@media (max-width: 760px) {
  .hero-signal-strip {
    gap: 8px;
  }

  .hero-signal-strip span {
    width: 100%;
    justify-content: space-between;
  }

  .intel-sec {
    padding: 72px 0;
  }

  .intel-proof-grid {
    grid-template-columns: 1fr;
  }

  .intel-stage {
    min-height: 760px;
    border-radius: 20px;
  }

  .intel-core {
    top: 42%;
    width: 166px;
    height: 166px;
  }

  .intel-node {
    left: 18px;
    right: 18px;
    min-width: 0;
  }

  .intel-node-a {
    top: 28px;
  }

  .intel-node-b {
    top: 128px;
  }

  .intel-node-c {
    bottom: 250px;
  }

  .intel-node-d {
    bottom: 154px;
  }

  .intel-readout {
    grid-template-columns: 1fr;
    left: 18px;
    right: 18px;
    bottom: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-signal-strip span::after,
  .intel-sec::before,
  .intel-sweep,
  .intel-core,
  .intel-node {
    animation: none !important;
  }

  .intel-stage {
    transform: none !important;
  }
}

/* Contrast fixes for content cards that were appearing washed out */
.journey-card {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border-color: oklch(from var(--color-brand-bright) l c h / 0.14);
  box-shadow: 0 14px 34px oklch(8% 0.02 230 / 0.07);
}

.journey-card:hover {
  box-shadow: 0 22px 48px oklch(8% 0.02 230 / 0.1);
}

.j-icon {
  background: linear-gradient(
    145deg,
    oklch(98% 0.025 152),
    oklch(96% 0.018 210)
  );
  border: 1px solid oklch(from var(--color-action) l c h / 0.08);
}

.j-meta {
  color: var(--text-ink2);
}

.j-date {
  color: var(--text-ink);
  font-weight: 800;
}

.j-year {
  color: var(--text-ink3);
  font-weight: 600;
}

.j-title {
  color: var(--text-ink);
  font-weight: 800;
  line-height: 1.28;
}

.j-body {
  color: var(--text-ink2);
  font-size: 15px;
  line-height: 1.72;
}

.journey-dot {
  box-shadow:
    0 0 0 5px oklch(from var(--color-action) l c h / 0.12),
    var(--shadow-sm);
}

.vmc {
  background: linear-gradient(180deg, var(--surface-white), var(--surface-off));
  border-color: oklch(from var(--color-brand-bright) l c h / 0.14);
  box-shadow: 0 16px 36px oklch(8% 0.02 230 / 0.07);
}

.vmc-h {
  color: var(--text-ink);
  line-height: 1.18;
}

.vmc-t {
  color: var(--text-ink2);
  font-size: 15px;
  line-height: 1.82;
}

@layer overrides {
  body.menu-open {
    overflow: hidden;
  }

  .eyebrow-center {
    justify-content: center;
  }

  .eyebrow-gold {
    color: var(--color-gold);
  }

  .eyebrow-gold::before {
    background: var(--color-gold);
  }

  .partners-sec .sec-header {
    max-width: 760px;
    margin-inline: auto;
    text-align: center;
  }

  .partners-heading {
    color: #fff;
  }

  .partners-heading em {
    background: linear-gradient(
      135deg,
      var(--color-brand-bright),
      var(--color-gold)
    );
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-style: normal;
  }

  .partners-lead {
    color: oklch(100% 0 0 / 0.78);
    max-width: 720px;
    margin-inline: auto;
  }

  .partner-track-outer {
    padding-block: 16px 10px;
  }

  .partner-card {
    min-height: 116px;
    height: auto;
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.08),
      oklch(100% 0 0 / 0.05)
    );
    border-color: oklch(from var(--color-brand-bright) l c h / 0.14);
    box-shadow: 0 16px 36px oklch(4% 0.02 152 / 0.18);
  }

  .partner-link {
    min-height: 100%;
    justify-content: center;
    gap: 10px;
    text-align: center;
  }

  .partner-logo-img {
    max-width: 150px;
    filter: grayscale(0.18) brightness(1.04) contrast(1.03);
    opacity: 0.96;
  }

  .partner-logo-text {
    color: oklch(100% 0 0 / 0.82);
    filter: none;
  }

  .partner-badge {
    color: oklch(100% 0 0 / 0.68);
  }

  .partner-card:hover .partner-logo-img,
  .partner-card:focus-within .partner-logo-img {
    filter: grayscale(0) brightness(1.08) contrast(1.04);
  }

  @media (max-width: 900px) {
    .partner-card {
      min-height: 96px;
      padding: 14px 18px;
    }
  }

  .tm-av {
    overflow: hidden;
  }

  .tm-av img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
  }

  .tm-tagline {
    font-size: 13px;
    line-height: 1.65;
    color: var(--text-ink4);
    font-style: italic;
    margin-top: 8px;
  }

  .mobile-menu {
    border-bottom-color: oklch(100% 0 0 / 0.12);
    box-shadow: 0 24px 60px oklch(4% 0.02 152 / 0.34);
  }

  .mobile-menu a {
    color: oklch(100% 0 0 / 0.88);
    padding: 12px 0;
  }

  .mobile-menu a:hover,
  .mobile-menu a:focus-visible {
    color: #fff;
    padding-left: 4px;
  }

  .mobile-menu-cta {
    color: var(--color-gold);
    font-weight: 800;
  }

  .contact-panel {
    position: relative;
    overflow: hidden;
  }

  .contact-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      radial-gradient(
        circle at top right,
        oklch(from var(--color-action) l c h / 0.12),
        transparent 36%
      ),
      linear-gradient(
        180deg,
        oklch(from var(--color-brand-bright) l c h / 0.05),
        transparent 54%
      );
    pointer-events: none;
  }

  .contact-panel-copy,
  .contact-panel-meta,
  .contact-panel .form-btn {
    position: relative;
    z-index: 1;
  }

  .contact-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    font-family: "JetBrains Mono", monospace;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-action);
    background: var(--color-action-surface);
    border: 1px solid var(--color-action-border);
  }

  .contact-panel-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--text-ink);
    margin-top: 18px;
  }

  .contact-panel-desc {
    font-size: 15px;
    line-height: 1.78;
    color: var(--text-ink3);
    margin-top: 12px;
    max-width: 44ch;
  }

  .contact-panel-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 24px;
  }

  .contact-panel-stat {
    padding: 16px;
    border-radius: 16px;
    background: oklch(100% 0 0 / 0.7);
    border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.12);
    box-shadow: 0 14px 28px oklch(8% 0.02 230 / 0.06);
  }

  .contact-panel-stat strong {
    display: block;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 800;
    color: var(--text-ink);
  }

  .contact-panel-stat span {
    display: block;
    font-size: 12.5px;
    color: var(--text-ink4);
    margin-top: 4px;
  }

  .contact-panel .form-btn {
    margin-top: 24px;
  }

  @media (max-width: 640px) {
    .contact-panel-meta {
      grid-template-columns: 1fr;
    }
  }

  .cii-val a {
    color: inherit;
    text-decoration: none;
  }

  .cii-val a:hover {
    color: var(--color-action);
    text-decoration: underline;
  }

  .ft-sub,
  .ft-contact,
  .ft-links a,
  .ft-copy,
  .ft-visitors {
    color: oklch(100% 0 0 / 0.84);
  }

  .ft-news-sub,
  .ft-cins {
    color: oklch(100% 0 0 / 0.72);
  }

  .ft-ct {
    opacity: 0.92;
  }
}

@layer overrides {
  .m-overlay {
    background:
      radial-gradient(
        circle at 18% 14%,
        oklch(from var(--color-gold) l c h / 0.12),
        transparent 26%
      ),
      radial-gradient(
        circle at 82% 12%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.84);
    backdrop-filter: blur(20px) saturate(118%);
  }

  .m-overlay::before,
  .m-overlay::after {
    opacity: 0.28;
    filter: blur(34px);
  }

  .m-overlay::before {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.24),
      transparent 70%
    );
  }

  .m-overlay::after {
    background: radial-gradient(
      circle,
      oklch(from var(--color-brand-mid) l c h / 0.18),
      transparent 72%
    );
  }

  .m-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.4% 0.004 72 / 0.97)
      ),
      var(--surface-white);
    box-shadow:
      0 34px 110px oklch(6% 0.02 240 / 0.3),
      0 10px 24px oklch(8% 0.02 220 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .m-box::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.46),
      transparent
    );
  }

  .m-body,
  .m-form-body {
    background: linear-gradient(
      180deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.015)
    );
  }

  #exitPopup {
    background:
      radial-gradient(
        circle at 18% 15%,
        oklch(from var(--color-gold) l c h / 0.11),
        transparent 26%
      ),
      radial-gradient(
        circle at 80% 10%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.86);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .ep-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.5% 0.004 76 / 0.965)
      ),
      var(--surface-white);
    box-shadow:
      0 46px 128px oklch(6% 0.02 240 / 0.34),
      0 14px 36px oklch(8% 0.02 210 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .ep-box::before {
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.06),
        transparent 36%
      ),
      linear-gradient(
        -135deg,
        oklch(from var(--color-action) l c h / 0.035),
        transparent 42%
      );
  }

  .ep-ambient {
    opacity: 0.4;
    filter: blur(16px);
  }

  .ep-ambient-a {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.18),
      transparent 72%
    );
  }

  .ep-ambient-b {
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.1),
      transparent 74%
    );
  }

  .ep-top {
    padding: 38px 40px 24px;
    background:
      linear-gradient(
        145deg,
        oklch(16% 0.03 245),
        oklch(22% 0.04 210) 56%,
        oklch(23% 0.035 160)
      ),
      linear-gradient(135deg, var(--surface-hero), var(--surface-dark));
  }

  .ep-top::before {
    background:
      linear-gradient(oklch(100% 0 0 / 0.04) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.04) 1px, transparent 1px);
    background-size: 32px 32px;
  }

  .ep-top::after {
    content: "";
    position: absolute;
    left: 40px;
    right: 40px;
    bottom: 0;
    height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.45),
      transparent
    );
    pointer-events: none;
  }

  .ep-close {
    background: oklch(100% 0 0 / 0.09);
    border-color: oklch(100% 0 0 / 0.12);
  }

  .ep-close:hover,
  .ep-close:focus-visible {
    background: oklch(100% 0 0 / 0.16);
    border-color: oklch(from var(--color-gold) l c h / 0.28);
    transform: translateY(-1px);
  }

  .ep-emoji {
    background:
      linear-gradient(160deg, oklch(100% 0 0 / 0.12), oklch(100% 0 0 / 0.04)),
      oklch(100% 0 0 / 0.04);
    border-color: oklch(from var(--color-gold) l c h / 0.16);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.18),
      0 10px 24px oklch(0% 0 0 / 0.14);
  }

  .ep-title {
    letter-spacing: -0.036em;
    max-width: 13ch;
  }

  .ep-sub {
    color: oklch(100% 0 0 / 0.72);
  }

  .ep-proof-card {
    padding: 15px 17px;
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.11),
      oklch(100% 0 0 / 0.07)
    );
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.08);
  }

  .ep-proof-card strong {
    color: oklch(from var(--color-gold) l c h / 0.96);
  }

  .ep-proof-card span {
    color: oklch(100% 0 0 / 0.64);
  }

  .ep-body {
    gap: 18px;
    padding: 30px 40px 36px;
  }

  .ep-perk {
    min-height: 112px;
    border-radius: 18px;
    border-color: oklch(from var(--color-gold) l c h / 0.1);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.96),
      oklch(from var(--color-gold) l c h / 0.035)
    );
    box-shadow:
      0 16px 36px oklch(8% 0.02 230 / 0.07),
      inset 0 1px 0 oklch(100% 0 0 / 0.7);
  }

  .ep-perk-icon {
    background: linear-gradient(
      145deg,
      oklch(from var(--color-gold) l c h / 0.28),
      oklch(100% 0 0 / 0.92)
    );
    color: oklch(38% 0.08 72);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.84),
      0 8px 18px oklch(from var(--color-gold) l c h / 0.12);
  }

  .ep-form-intro {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.75);
  }

  .ep-form-intro strong {
    letter-spacing: -0.02em;
  }

  .ep-input {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background: oklch(100% 0 0 / 0.98);
    box-shadow:
      0 12px 26px oklch(8% 0.02 230 / 0.05),
      inset 0 1px 0 oklch(100% 0 0 / 0.88);
  }

  .ep-input:focus {
    border-color: oklch(from var(--color-gold) l c h / 0.35);
    box-shadow:
      0 0 0 5px oklch(from var(--color-gold) l c h / 0.1),
      0 12px 26px oklch(8% 0.02 230 / 0.06);
  }

  .ep-submit {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background: linear-gradient(
      135deg,
      oklch(18% 0.03 238),
      oklch(24% 0.04 175)
    );
    box-shadow:
      0 18px 40px oklch(8% 0.02 210 / 0.22),
      inset 0 1px 0 oklch(100% 0 0 / 0.16);
  }

  .ep-submit::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.16),
      transparent
    );
    animation-duration: 3.8s;
    opacity: 0.78;
  }

  .ep-submit:hover,
  .ep-submit:focus-visible,
  .ep-submit.btn-liquid:hover {
    transform: translateY(-2px) scale(1.006);
    box-shadow:
      0 20px 44px oklch(8% 0.02 210 / 0.26),
      inset 0 1px 0 oklch(100% 0 0 / 0.2);
  }

  .ep-mini-note {
    letter-spacing: 0.08em;
    color: oklch(58% 0.03 75);
  }

  .ep-dismiss {
    color: var(--text-ink3);
  }

  .ep-dismiss:hover {
    border-color: oklch(from var(--color-gold) l c h / 0.24);
    transform: none;
  }

  .ep-success-panel {
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow:
      0 18px 40px oklch(8% 0.02 230 / 0.06),
      inset 0 1px 0 oklch(100% 0 0 / 0.76);
  }

  .ep-success-icon {
    background: linear-gradient(145deg, oklch(30% 0.05 80), oklch(38% 0.08 72));
    box-shadow: 0 18px 40px oklch(from var(--color-gold) l c h / 0.2);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ) {
    transition:
      transform 180ms var(--ease-out),
      box-shadow 180ms var(--ease-out),
      border-color 180ms var(--ease-out),
      background-color 180ms var(--ease-out),
      filter 180ms var(--ease-out);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ):hover {
    filter: saturate(1.01) brightness(1.01);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    )
    > svg {
    transition: transform 180ms var(--ease-out);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    ):hover
    > svg {
    transform: translateX(2px) scale(1.03);
  }

  .btn-liquid {
    box-shadow: 0 10px 24px oklch(8% 0.02 220 / 0.08);
  }

  .btn-liquid::after {
    opacity: 0.42;
    mix-blend-mode: soft-light;
    animation-duration: 6.5s;
  }

  .btn-liquid:hover {
    box-shadow: 0 16px 30px oklch(8% 0.02 220 / 0.12);
  }

  .btn-spark {
    width: 7px;
    height: 7px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.92) 0 32%,
      oklch(100% 0 0 / 0.28) 52%,
      transparent 76%
    );
    box-shadow: 0 0 10px oklch(from var(--color-gold) l c h / 0.25);
    animation-duration: 620ms;
  }

  .sb-btn {
    box-shadow: 0 16px 32px oklch(8% 0.02 220 / 0.18);
  }

  .sb-btn::before {
    background: linear-gradient(
      115deg,
      oklch(100% 0 0 / 0.18),
      transparent 46%,
      transparent
    );
  }

  .sb-btn:hover,
  .sb-btn:focus-visible {
    transform: translateX(-5px) scale(1.02);
    box-shadow: 0 20px 36px oklch(8% 0.02 220 / 0.22);
    filter: saturate(1.03);
  }

  .sb-btn:hover svg,
  .sb-btn:focus-visible svg {
    transform: scale(1.06);
  }

  .sb-btn:hover .sb-label,
  .sb-btn:focus-visible .sb-label {
    transform: translateX(-4px);
  }

  @media (max-width: 760px) {
    .ep-top {
      padding: 28px 24px 20px;
    }

    .ep-top::after {
      left: 24px;
      right: 24px;
    }

    .ep-body {
      padding: 24px 24px 28px;
    }
  }

  @media (max-width: 700px) {
    .sb-btn:hover,
    .sb-btn:focus-visible {
      transform: translateY(-3px) scale(1.01);
    }
  }
}

@layer overrides {
  @keyframes epAmbientFloat {
    0% {
      transform: translate3d(0, 0, 0) scale(1);
    }
    50% {
      transform: translate3d(18px, -22px, 0) scale(1.08);
    }
    100% {
      transform: translate3d(0, 0, 0) scale(1);
    }
  }

  @keyframes modalAuraShift {
    0% {
      transform: translate3d(0, 0, 0) scale(1);
      opacity: 0.42;
    }
    50% {
      transform: translate3d(22px, -18px, 0) scale(1.12);
      opacity: 0.62;
    }
    100% {
      transform: translate3d(0, 0, 0) scale(1);
      opacity: 0.42;
    }
  }

  @keyframes buttonSpark {
    0% {
      transform: translate(-50%, -50%) scale(0.2);
      opacity: 0;
    }
    18% {
      opacity: 1;
    }
    100% {
      transform: translate(
          calc(-50% + var(--dx, 0px)),
          calc(-50% + var(--dy, -18px))
        )
        scale(1);
      opacity: 0;
    }
  }

  @keyframes buttonSweep {
    0% {
      transform: translateX(-120%) skewX(-18deg);
      opacity: 0;
    }
    30% {
      opacity: 0.5;
    }
    100% {
      transform: translateX(220%) skewX(-18deg);
      opacity: 0;
    }
  }

  .m-overlay {
    background:
      radial-gradient(
        circle at 18% 20%,
        oklch(from var(--color-action) l c h / 0.2),
        transparent 32%
      ),
      radial-gradient(
        circle at 82% 12%,
        oklch(from var(--color-brand-bright) l c h / 0.16),
        transparent 30%
      ),
      rgba(4, 10, 18, 0.78);
    backdrop-filter: blur(18px) saturate(130%);
    overflow: hidden;
  }

  .m-overlay::before,
  .m-overlay::after {
    content: "";
    position: absolute;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(24px);
    opacity: 0.46;
    animation: modalAuraShift 8s ease-in-out infinite;
  }

  .m-overlay::before {
    top: -80px;
    left: -40px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.34),
      transparent 68%
    );
  }

  .m-overlay::after {
    right: -70px;
    bottom: -110px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-brand-mid) l c h / 0.28),
      transparent 70%
    );
    animation-delay: -4s;
  }

  .m-box {
    border: 1px solid oklch(100% 0 0 / 0.52);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.98),
        oklch(98% 0.005 210 / 0.96)
      ),
      var(--surface-white);
    box-shadow:
      0 26px 90px oklch(10% 0.02 152 / 0.24),
      inset 0 1px 0 oklch(100% 0 0 / 0.8);
    translate: 0 30px;
    scale: 0.965;
    isolation: isolate;
  }

  .m-box::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-action) l c h / 0.55),
      transparent
    );
    pointer-events: none;
    z-index: 2;
  }

  .m-overlay.open .m-box {
    translate: 0 0;
    scale: 1;
  }
  /* Added: Extra modern interactions & slide-in utilities */
  @layer utilities {
    /* Slide-in utilities for quick reveals */
    .slide-in-up {
      opacity: 0;
      transform: translateY(18px);
      animation: slideInUp 640ms var(--ease-overshoot) both;
    }
    .slide-in-left {
      opacity: 0;
      transform: translateX(-18px);
      animation: slideInLeft 640ms var(--ease-overshoot) both;
    }
    .slide-in-right {
      opacity: 0;
      transform: translateX(18px);
      animation: slideInRight 640ms var(--ease-overshoot) both;
    }
    .reveal-delay-1 {
      animation-delay: 0.08s;
    }
    .reveal-delay-2 {
      animation-delay: 0.16s;
    }
    .reveal-delay-3 {
      animation-delay: 0.28s;
    }

    /* Hover tilt micro-interaction */
    .hover-tilt {
      transform-style: preserve-3d;
      perspective: 900px;
      transition: transform 320ms var(--ease-out);
      will-change: transform;
    }
    .hover-tilt:hover {
      transform: rotateX(6deg) rotateY(-6deg) translateY(-6px) scale(1.02);
      box-shadow: 0 22px 60px rgba(2, 8, 23, 0.12);
    }

    .btn-swish:hover {
      animation: btnSwish 420ms var(--ease-overshoot);
    }

    /* Apply a subtle slide-in to the mission visual (stat card) */
    .mission-visual {
      animation:
        slideInRight 820ms var(--ease-overshoot) both,
        floatY 5.5s ease-in-out infinite;
      will-change: transform, opacity;
    }

    /* Keyframes for these utilities */
    @keyframes slideInUp {
      from {
        opacity: 0;
        transform: translateY(18px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    @keyframes slideInLeft {
      from {
        opacity: 0;
        transform: translateX(-18px);
      }
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    @keyframes slideInRight {
      from {
        opacity: 0;
        transform: translateX(18px);
      }
      to {
        opacity: 1;
        transform: translateX(0);
      }
    }
    @keyframes btnSwish {
      0% {
        transform: translateY(0) scale(1);
      }
      50% {
        transform: translateY(-6px) scale(1.03) rotate(-0.5deg);
      }
      100% {
        transform: translateY(0) scale(1);
      }
    }
  }

  .m-header,
  .m-form-header {
    position: relative;
    isolation: isolate;
    overflow: hidden;
  }

  .m-header::after,
  .m-form-header::after {
    content: "";
    position: absolute;
    inset: auto -15% -45% auto;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(
      circle,
      oklch(100% 0 0 / 0.14),
      transparent 68%
    );
    pointer-events: none;
  }

  .m-body,
  .m-form-body {
    position: relative;
    background: linear-gradient(
      180deg,
      transparent,
      oklch(from var(--color-action) l c h / 0.018)
    );
  }

  #exitPopup {
    padding: 24px;
    background:
      radial-gradient(
        circle at 20% 18%,
        oklch(from var(--color-brand-mid) l c h / 0.2),
        transparent 28%
      ),
      radial-gradient(
        circle at 78% 10%,
        oklch(from var(--color-action) l c h / 0.22),
        transparent 30%
      ),
      rgba(4, 10, 18, 0.78);
    backdrop-filter: blur(18px) saturate(135%);
  }

  #exitPopup.open .ep-box {
    translate: 0 0;
    scale: 1;
    opacity: 1;
  }

  .ep-box {
    width: min(920px, 100%);
    max-width: 920px;
    padding: 0;
    border-radius: 28px;
    border: 1px solid oklch(100% 0 0 / 0.56);
    background:
      linear-gradient(
        160deg,
        oklch(100% 0 0 / 0.98),
        oklch(98% 0.008 210 / 0.95)
      ),
      var(--surface-white);
    box-shadow:
      0 38px 110px oklch(10% 0.02 152 / 0.28),
      inset 0 1px 0 oklch(100% 0 0 / 0.85);
    overflow: hidden;
    isolation: isolate;
    translate: 0 26px;
    scale: 0.94;
    opacity: 0;
    transition:
      translate var(--duration-slow) var(--ease-spring),
      scale var(--duration-slow) var(--ease-spring),
      opacity var(--duration-base) var(--ease-out);
  }

  .ep-box::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-action) l c h / 0.06),
        transparent 35%
      ),
      linear-gradient(
        -135deg,
        oklch(from var(--color-brand-mid) l c h / 0.05),
        transparent 38%
      );
    pointer-events: none;
  }

  .ep-ambient {
    position: absolute;
    border-radius: 50%;
    filter: blur(10px);
    pointer-events: none;
    opacity: 0.7;
    animation: epAmbientFloat 8s ease-in-out infinite;
  }

  .ep-ambient-a {
    top: -40px;
    right: -24px;
    width: 170px;
    height: 170px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.28),
      transparent 70%
    );
  }

  .ep-ambient-b {
    left: -55px;
    bottom: 34px;
    width: 220px;
    height: 220px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-brand-mid) l c h / 0.2),
      transparent 72%
    );
    animation-delay: -3s;
  }

  .ep-top {
    position: relative;
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 14px 18px;
    padding: 34px 36px 22px;
    background:
      linear-gradient(145deg, oklch(22% 0.08 220), oklch(36% 0.14 190)),
      linear-gradient(135deg, var(--surface-hero), var(--surface-dark));
    color: #fff;
  }

  .ep-top::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(oklch(100% 0 0 / 0.06) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.06) 1px, transparent 1px);
    background-size: 26px 26px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.85), transparent);
    pointer-events: none;
  }

  .ep-close {
    top: 18px;
    right: 18px;
    width: 38px;
    height: 38px;
    border: 1px solid oklch(100% 0 0 / 0.18);
    background: oklch(100% 0 0 / 0.12);
    color: #fff;
    backdrop-filter: blur(10px);
    transition:
      transform var(--duration-fast) var(--ease-out),
      background-color var(--duration-fast) var(--ease-out),
      border-color var(--duration-fast) var(--ease-out);
  }

  .ep-close:hover,
  .ep-close:focus-visible {
    background: oklch(100% 0 0 / 0.22);
    border-color: oklch(100% 0 0 / 0.36);
    transform: translateY(-2px) scale(1.04);
    outline: none;
  }

  .ep-emoji {
    grid-row: 1 / span 2;
    align-self: start;
    width: 88px;
    height: 88px;
    border-radius: 24px;
    display: grid;
    place-items: center;
    background:
      linear-gradient(160deg, oklch(100% 0 0 / 0.18), oklch(100% 0 0 / 0.08)),
      oklch(100% 0 0 / 0.06);
    border: 1px solid oklch(100% 0 0 / 0.16);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.22);
    font-size: 44px;
    position: relative;
    z-index: 1;
  }

  .ep-title,
  .ep-sub,
  .ep-proof-row {
    position: relative;
    z-index: 1;
  }

  .ep-title {
    font-size: clamp(28px, 3vw, 38px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    max-width: 12ch;
    margin-top: 10px;
  }

  .ep-sub {
    color: oklch(100% 0 0 / 0.78);
    font-size: 14px;
    max-width: 52ch;
  }

  .ep-proof-row {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 10px;
  }

  .ep-proof-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 18px;
    background: oklch(100% 0 0 / 0.09);
    border: 1px solid oklch(100% 0 0 / 0.14);
    backdrop-filter: blur(14px);
  }

  .ep-proof-card strong {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 20px;
    font-weight: 800;
    color: #fff;
  }

  .ep-proof-card span {
    font-size: 12px;
    color: oklch(100% 0 0 / 0.72);
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }

  .ep-body {
    padding: 28px 36px 34px;
    display: grid;
    gap: 16px;
  }

  .ep-perks {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 0;
  }

  .ep-perk {
    min-height: 120px;
    padding: 16px 16px 16px 14px;
    border-radius: 20px;
    border: 1px solid oklch(from var(--color-action) l c h / 0.08);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.94),
      oklch(from var(--color-action) l c h / 0.04)
    );
    box-shadow: 0 18px 40px oklch(10% 0.02 152 / 0.08);
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    line-height: 1.6;
  }

  .ep-perk-icon {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    background: linear-gradient(
      145deg,
      oklch(from var(--color-action) l c h / 0.18),
      oklch(from var(--color-brand-mid) l c h / 0.22)
    );
    color: var(--text-ink2);
    font-family: "JetBrains Mono", monospace;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.5);
  }

  .ep-form-intro {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid oklch(from var(--color-brand-mid) l c h / 0.12);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-brand-mid) l c h / 0.08),
        transparent 60%
      ),
      oklch(99% 0.004 220);
  }

  .ep-form-intro strong {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 800;
    color: var(--text-ink);
  }

  .ep-form-intro span {
    max-width: 40ch;
    color: var(--text-ink3);
    font-size: 13.5px;
    line-height: 1.6;
  }

  .ep-input-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    margin: 0;
  }

  .ep-input {
    min-height: 58px;
    border-radius: 16px;
    border: 1.5px solid oklch(from var(--color-action) l c h / 0.14);
    background: oklch(100% 0 0 / 0.96);
    box-shadow:
      0 12px 28px oklch(10% 0.02 152 / 0.06),
      inset 0 1px 0 oklch(100% 0 0 / 0.75);
    padding: 0 18px;
    transition:
      border-color var(--duration-fast) var(--ease-out),
      box-shadow var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out);
  }

  .ep-input:focus {
    border-color: oklch(from var(--color-action) l c h / 0.42);
    box-shadow:
      0 0 0 5px oklch(from var(--color-action) l c h / 0.12),
      0 12px 28px oklch(10% 0.02 152 / 0.08);
    transform: translateY(-1px);
  }

  .ep-submit {
    min-width: 184px;
    min-height: 58px;
    padding: 0 26px;
    border-radius: 16px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.01em;
    box-shadow:
      0 16px 38px oklch(from var(--color-action) l c h / 0.34),
      inset 0 1px 0 oklch(100% 0 0 / 0.3);
    background-size: 150% 150%;
  }

  .ep-submit::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(100% 0 0 / 0.18),
      transparent
    );
    animation: buttonSweep 2.6s ease-in-out infinite;
    pointer-events: none;
    mix-blend-mode: screen;
  }

  .ep-submit:hover,
  .ep-submit:focus-visible {
    transform: translateY(-3px) scale(1.01);
    box-shadow:
      0 20px 48px oklch(from var(--color-action) l c h / 0.42),
      inset 0 1px 0 oklch(100% 0 0 / 0.35);
    outline: none;
  }

  .ep-mini-note {
    padding: 0 4px;
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-ink4);
  }

  .ep-dismiss {
    justify-self: center;
    margin-top: 2px;
    padding-bottom: 2px;
    border-bottom: 1px solid transparent;
    transition:
      color var(--duration-fast) var(--ease-out),
      border-color var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out);
  }

  .ep-dismiss:hover {
    color: var(--text-ink);
    border-color: oklch(from var(--color-action) l c h / 0.24);
    transform: translateY(-1px);
  }

  .ep-success {
    padding: 30px 36px 36px;
  }

  .ep-success > :not(.ep-success-panel) {
    display: none;
  }

  .ep-success-panel {
    display: grid;
    place-items: center;
    gap: 12px;
    padding: 26px 24px;
    border-radius: 24px;
    border: 1px solid oklch(from var(--color-brand-mid) l c h / 0.14);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-brand-mid) l c h / 0.1),
        transparent 62%
      ),
      oklch(99% 0.004 220);
    text-align: center;
  }

  .ep-success-icon {
    width: 72px;
    height: 72px;
    border-radius: 24px;
    display: grid;
    place-items: center;
    background: linear-gradient(
      145deg,
      var(--color-brand-mid),
      var(--color-action)
    );
    color: #fff;
    font-family: "JetBrains Mono", monospace;
    font-size: 18px;
    font-weight: 800;
    letter-spacing: 0.08em;
    box-shadow: 0 18px 40px oklch(from var(--color-brand-mid) l c h / 0.3);
  }

  .ep-success-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 24px;
    font-weight: 800;
    color: var(--text-ink);
  }

  .ep-success-sub {
    max-width: 36ch;
    color: var(--text-ink3);
    font-size: 14px;
    line-height: 1.65;
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ) {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    transform-style: preserve-3d;
    backface-visibility: hidden;
    transition:
      transform 220ms var(--ease-out),
      box-shadow 220ms var(--ease-out),
      filter 220ms var(--ease-out);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ):hover {
    filter: saturate(1.08) brightness(1.02);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ):focus-visible {
    outline: none;
    box-shadow: 0 0 0 5px oklch(from var(--color-action) l c h / 0.14);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    )
    > svg {
    transition: transform var(--duration-fast) var(--ease-out);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    ):hover
    > svg {
    transform: translateX(4px) scale(1.08);
  }

  .btn-liquid {
    box-shadow: 0 10px 24px oklch(10% 0.02 152 / 0.08);
  }

  .btn-liquid:hover {
    box-shadow: 0 18px 38px oklch(10% 0.02 152 / 0.14);
  }

  .ep-submit.btn-liquid:hover {
    box-shadow:
      0 20px 48px oklch(from var(--color-action) l c h / 0.42),
      inset 0 1px 0 oklch(100% 0 0 / 0.35);
  }

  .btn-spark {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    pointer-events: none;
    background: radial-gradient(
      circle,
      oklch(100% 0 0 / 0.96) 0 28%,
      oklch(100% 0 0 / 0.18) 45%,
      transparent 72%
    );
    box-shadow: 0 0 12px oklch(100% 0 0 / 0.45);
    animation: buttonSpark 720ms cubic-bezier(0.18, 0.72, 0.18, 1) forwards;
    z-index: 3;
  }

  .sb-btn {
    isolation: isolate;
    box-shadow: 0 16px 34px oklch(10% 0.02 152 / 0.18);
    transition:
      width var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out),
      box-shadow var(--duration-fast) var(--ease-out),
      filter var(--duration-fast) var(--ease-out);
  }

  .sb-btn::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(
      115deg,
      oklch(100% 0 0 / 0.22),
      transparent 42%,
      transparent
    );
    opacity: 0;
    transition:
      opacity var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out);
    pointer-events: none;
    transform: translateX(-22%);
  }

  .sb-btn:hover,
  .sb-btn:focus-visible {
    transform: translateX(-8px) scale(1.05);
    box-shadow: 0 22px 40px oklch(10% 0.02 152 / 0.24);
    filter: saturate(1.08);
    outline: none;
  }

  .sb-btn:hover::before,
  .sb-btn:focus-visible::before {
    opacity: 1;
    transform: translateX(0);
  }

  .sb-btn svg {
    transition: transform var(--duration-fast) var(--ease-out);
  }

  .sb-btn:hover svg,
  .sb-btn:focus-visible svg {
    transform: scale(1.12) rotate(-7deg);
  }

  .sb-label {
    transition:
      opacity var(--duration-fast) var(--ease-out),
      transform var(--duration-fast) var(--ease-out);
    transform: translateX(4px);
  }

  .sb-btn:hover .sb-label,
  .sb-btn:focus-visible .sb-label {
    opacity: 1;
    transform: translateX(-8px);
  }

  @media (max-width: 900px) {
    .ep-perks {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 760px) {
    #exitPopup {
      padding: 14px;
      align-items: flex-start;
    }

    .ep-top {
      grid-template-columns: 1fr;
      padding: 26px 22px 18px;
    }

    .ep-emoji {
      grid-row: auto;
      width: 70px;
      height: 70px;
      border-radius: 20px;
      font-size: 34px;
    }

    .ep-title {
      max-width: none;
      margin-top: 0;
      font-size: clamp(24px, 8vw, 32px);
    }

    .ep-proof-row {
      grid-template-columns: 1fr;
    }

    .ep-body {
      padding: 22px 22px 26px;
    }

    .ep-form-intro {
      flex-direction: column;
    }

    .ep-input-row {
      grid-template-columns: 1fr;
    }

    .ep-submit {
      width: 100%;
    }

    .ep-success {
      padding: 22px 22px 28px;
    }
  }

  @media (max-width: 700px) {
    .sb-btn:hover,
    .sb-btn:focus-visible {
      transform: translateY(-5px) scale(1.02);
    }
  }
}
@layer overrides {
  .m-overlay {
    background:
      radial-gradient(
        circle at 18% 15%,
        oklch(from var(--color-gold) l c h / 0.12),
        transparent 26%
      ),
      radial-gradient(
        circle at 80% 10%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.86);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .m-overlay::before,
  .m-overlay::after {
    opacity: 0.28;
    filter: blur(34px);
  }

  .m-overlay::before {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.24),
      transparent 70%
    );
  }

  .m-overlay::after {
    background: radial-gradient(
      circle,
      oklch(from var(--color-brand-mid) l c h / 0.18),
      transparent 72%
    );
  }

  .m-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.4% 0.004 72 / 0.97)
      ),
      var(--surface-white);
    box-shadow:
      0 34px 110px oklch(6% 0.02 240 / 0.3),
      0 10px 24px oklch(8% 0.02 220 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .m-box::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.46),
      transparent
    );
  }

  .m-body,
  .m-form-body {
    background: linear-gradient(
      180deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.015)
    );
  }

  #exitPopup {
    background:
      radial-gradient(
        circle at 18% 15%,
        oklch(from var(--color-gold) l c h / 0.11),
        transparent 26%
      ),
      radial-gradient(
        circle at 80% 10%,
        oklch(from var(--color-action) l c h / 0.08),
        transparent 28%
      ),
      rgba(5, 9, 16, 0.86);
    backdrop-filter: blur(20px) saturate(120%);
  }

  .ep-box {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background:
      linear-gradient(
        180deg,
        oklch(100% 0 0 / 0.985),
        oklch(98.5% 0.004 76 / 0.965)
      ),
      var(--surface-white);
    box-shadow:
      0 46px 128px oklch(6% 0.02 240 / 0.34),
      0 14px 36px oklch(8% 0.02 210 / 0.08),
      inset 0 1px 0 oklch(100% 0 0 / 0.9);
  }

  .ep-box::before {
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.06),
        transparent 36%
      ),
      linear-gradient(
        -135deg,
        oklch(from var(--color-action) l c h / 0.035),
        transparent 42%
      );
  }

  .ep-ambient {
    opacity: 0.4;
    filter: blur(16px);
  }

  .ep-ambient-a {
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.18),
      transparent 72%
    );
  }

  .ep-ambient-b {
    background: radial-gradient(
      circle,
      oklch(from var(--color-action) l c h / 0.1),
      transparent 74%
    );
  }

  .ep-top {
    padding: 38px 40px 24px;
    background:
      linear-gradient(
        145deg,
        oklch(16% 0.03 245),
        oklch(22% 0.04 210) 56%,
        oklch(23% 0.035 160)
      ),
      linear-gradient(135deg, var(--surface-hero), var(--surface-dark));
  }

  .ep-top::before {
    background:
      linear-gradient(oklch(100% 0 0 / 0.04) 1px, transparent 1px),
      linear-gradient(90deg, oklch(100% 0 0 / 0.04) 1px, transparent 1px);
    background-size: 32px 32px;
  }

  .ep-top::after {
    content: "";
    position: absolute;
    left: 40px;
    right: 40px;
    bottom: 0;
    height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.45),
      transparent
    );
    pointer-events: none;
  }

  .ep-close {
    background: oklch(100% 0 0 / 0.09);
    border-color: oklch(100% 0 0 / 0.12);
  }

  .ep-close:hover,
  .ep-close:focus-visible {
    background: oklch(100% 0 0 / 0.16);
    border-color: oklch(from var(--color-gold) l c h / 0.28);
    transform: translateY(-1px);
  }

  .ep-emoji {
    background:
      linear-gradient(160deg, oklch(100% 0 0 / 0.12), oklch(100% 0 0 / 0.04)),
      oklch(100% 0 0 / 0.04);
    border-color: oklch(from var(--color-gold) l c h / 0.16);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.18),
      0 10px 24px oklch(0% 0 0 / 0.14);
  }

  .ep-title {
    letter-spacing: -0.036em;
    max-width: 13ch;
  }

  .ep-sub {
    color: oklch(100% 0 0 / 0.72);
  }

  .ep-proof-card {
    padding: 15px 17px;
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.11),
      oklch(100% 0 0 / 0.07)
    );
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.08);
  }

  .ep-proof-card strong {
    color: oklch(from var(--color-gold) l c h / 0.96);
  }

  .ep-proof-card span {
    color: oklch(100% 0 0 / 0.64);
  }

  .ep-body {
    gap: 18px;
    padding: 30px 40px 36px;
  }

  .ep-perk {
    min-height: 112px;
    border-radius: 18px;
    border-color: oklch(from var(--color-gold) l c h / 0.1);
    background: linear-gradient(
      180deg,
      oklch(100% 0 0 / 0.96),
      oklch(from var(--color-gold) l c h / 0.035)
    );
    box-shadow:
      0 16px 36px oklch(8% 0.02 230 / 0.07),
      inset 0 1px 0 oklch(100% 0 0 / 0.7);
  }

  .ep-perk-icon {
    background: linear-gradient(
      145deg,
      oklch(from var(--color-gold) l c h / 0.28),
      oklch(100% 0 0 / 0.92)
    );
    color: oklch(38% 0.08 72);
    box-shadow:
      inset 0 1px 0 oklch(100% 0 0 / 0.84),
      0 8px 18px oklch(from var(--color-gold) l c h / 0.12);
  }

  .ep-form-intro {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow: inset 0 1px 0 oklch(100% 0 0 / 0.75);
  }

  .ep-form-intro strong {
    letter-spacing: -0.02em;
  }

  .ep-input {
    border-color: oklch(from var(--color-gold) l c h / 0.12);
    background: oklch(100% 0 0 / 0.98);
    box-shadow:
      0 12px 26px oklch(8% 0.02 230 / 0.05),
      inset 0 1px 0 oklch(100% 0 0 / 0.88);
  }

  .ep-input:focus {
    border-color: oklch(from var(--color-gold) l c h / 0.35);
    box-shadow:
      0 0 0 5px oklch(from var(--color-gold) l c h / 0.1),
      0 12px 26px oklch(8% 0.02 230 / 0.06);
  }

  .ep-submit {
    border: 1px solid oklch(from var(--color-gold) l c h / 0.16);
    background: linear-gradient(
      135deg,
      oklch(18% 0.03 238),
      oklch(24% 0.04 175)
    );
    box-shadow:
      0 18px 40px oklch(8% 0.02 210 / 0.22),
      inset 0 1px 0 oklch(100% 0 0 / 0.16);
  }

  .ep-submit::before {
    background: linear-gradient(
      90deg,
      transparent,
      oklch(from var(--color-gold) l c h / 0.16),
      transparent
    );
    animation-duration: 3.8s;
    opacity: 0.78;
  }

  .ep-submit:hover,
  .ep-submit:focus-visible,
  .ep-submit.btn-liquid:hover {
    transform: translateY(-2px) scale(1.006);
    box-shadow:
      0 20px 44px oklch(8% 0.02 210 / 0.26),
      inset 0 1px 0 oklch(100% 0 0 / 0.2);
  }

  .ep-mini-note {
    letter-spacing: 0.08em;
    color: oklch(58% 0.03 75);
  }

  .ep-dismiss {
    color: var(--text-ink3);
  }

  .ep-dismiss:hover {
    border-color: oklch(from var(--color-gold) l c h / 0.24);
    transform: none;
  }

  .ep-success-panel {
    border-color: oklch(from var(--color-gold) l c h / 0.14);
    background:
      linear-gradient(
        135deg,
        oklch(from var(--color-gold) l c h / 0.08),
        transparent 62%
      ),
      oklch(99.2% 0.003 78);
    box-shadow:
      0 18px 40px oklch(8% 0.02 230 / 0.06),
      inset 0 1px 0 oklch(100% 0 0 / 0.76);
  }

  .ep-success-icon {
    background: linear-gradient(145deg, oklch(30% 0.05 80), oklch(38% 0.08 72));
    box-shadow: 0 18px 40px oklch(from var(--color-gold) l c h / 0.2);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ) {
    transition:
      transform 180ms var(--ease-out),
      box-shadow 180ms var(--ease-out),
      border-color 180ms var(--ease-out),
      background-color 180ms var(--ease-out),
      filter 180ms var(--ease-out);
  }

  :is(
    .nav-cta,
    .btn-glow,
    .btn-white,
    .btn-verify,
    .form-btn,
    .fm-btn,
    .btn,
    .btn-ow,
    .btn-ghost,
    .btn-ghost-dark,
    .btn-see-all,
    .inv-btn,
    .ep-submit
  ):hover {
    filter: saturate(1.01) brightness(1.01);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    )
    > svg {
    transition: transform 180ms var(--ease-out);
  }

  :is(
      .nav-cta,
      .btn-glow,
      .btn-white,
      .btn-verify,
      .form-btn,
      .fm-btn,
      .btn,
      .btn-ow,
      .btn-ghost,
      .btn-ghost-dark,
      .btn-see-all,
      .inv-btn,
      .ep-submit
    ):hover
    > svg {
    transform: translateX(2px) scale(1.03);
  }

  .btn-liquid {
    box-shadow: 0 10px 24px oklch(8% 0.02 220 / 0.08);
  }

  .btn-liquid::after {
    opacity: 0.42;
    mix-blend-mode: soft-light;
    animation-duration: 6.5s;
  }

  .btn-liquid:hover {
    box-shadow: 0 16px 30px oklch(8% 0.02 220 / 0.12);
  }

  .btn-spark {
    width: 7px;
    height: 7px;
    background: radial-gradient(
      circle,
      oklch(from var(--color-gold) l c h / 0.92) 0 32%,
      oklch(100% 0 0 / 0.28) 52%,
      transparent 76%
    );
    box-shadow: 0 0 10px oklch(from var(--color-gold) l c h / 0.25);
    animation-duration: 620ms;
  }

  .sb-btn {
    box-shadow: 0 16px 32px oklch(8% 0.02 220 / 0.18);
  }

  .sb-btn::before {
    background: linear-gradient(
      115deg,
      oklch(100% 0 0 / 0.18),
      transparent 46%,
      transparent
    );
  }

  .sb-btn:hover,
  .sb-btn:focus-visible {
    transform: translateX(-5px) scale(1.02);
    box-shadow: 0 20px 36px oklch(8% 0.02 220 / 0.22);
    filter: saturate(1.03);
  }

  .sb-btn:hover svg,
  .sb-btn:focus-visible svg {
    transform: scale(1.06);
  }

  .sb-btn:hover .sb-label,
  .sb-btn:focus-visible .sb-label {
    transform: translateX(-4px);
  }

  @media (max-width: 760px) {
    .ep-top {
      padding: 28px 24px 20px;
    }

    .ep-top::after {
      left: 24px;
      right: 24px;
    }

    .ep-body {
      padding: 24px 24px 28px;
    }
  }

  @media (max-width: 700px) {
    .sb-btn:hover,
    .sb-btn:focus-visible {
      transform: translateY(-3px) scale(1.01);
    }
  }
}

/* SDG final override */
.sdg-sec {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(244, 250, 248, 0.96)
    ),
    radial-gradient(
      circle at 18% 8%,
      rgba(44, 106, 163, 0.08),
      transparent 40%
    ),
    radial-gradient(circle at 86% 18%, rgba(23, 109, 32, 0.08), transparent 42%) !important;
  color: #071725;
}

.sdg-sec::before {
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.035) 1px, transparent 1px) !important;
  background-size: 42px 42px !important;
}

.sdg-sec .wrap {
  position: relative;
  z-index: 1;
}

.sdg-sec .sec-header .h2 {
  color: #071725 !important;
}

.sdg-sec .sec-header .lead {
  color: #26343b !important;
}

.sdg-sec .sdg-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 22px);
  max-width: 1040px;
  margin-inline: auto;
}

.sdg-sec .sdg-grid .sgc {
  min-height: 258px;
  padding: 26px 22px 28px;
  border-radius: 8px;
  color: #071725;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), #fff 70%, #fbfdff), #fff;
}

.sdg-sec .sdg-grid .sgc::before {
  height: 62px;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--sdg-color) 22%, #fff),
      rgba(255, 255, 255, 0.78)
    ),
    linear-gradient(135deg, rgba(255, 255, 255, 0.48), transparent);
  transform: none;
  opacity: 1;
}

.sdg-sec .sdg-grid .sdg-icon {
  width: 58px;
  height: 58px;
  margin: -2px 0 18px;
  border: 3px solid #fff;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.35),
      transparent 32%
    ),
    linear-gradient(
      145deg,
      var(--sdg-color),
      color-mix(in srgb, var(--sdg-color) 64%, #071725)
    );
}

.sdg-sec .sdg-grid .sgn {
  color: var(--sdg-color);
  font-family: "JetBrains Mono", monospace;
  font-size: 22px;
  font-weight: 900;
  text-shadow: none;
  border: 1px solid color-mix(in srgb, var(--sdg-color) 26%, #fff);
  border-radius: 999px;
  background: color-mix(in srgb, var(--sdg-color) 8%, #fff);
}

.sdg-sec .sdg-grid .sgt {
  color: #071725;
  font-size: 15px;
  font-weight: 850;
}

.sdg-sec .sdg-grid .sgd {
  max-height: none;
  color: #26343b;
  font-size: 13.5px;
  font-weight: 600;
  overflow: visible;
}

@media (max-width: 960px) {
  .sdg-sec .sdg-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .sdg-sec .sdg-grid {
    grid-template-columns: 1fr;
  }
}

/* Partners final override: clean bright marquee with full logo visibility */
.partners-sec {
  --partner-card-w: 286px;
  --partner-logo-h: 104px;
  position: relative;
  overflow: hidden;
  padding-block: clamp(74px, 8vw, 112px);
  color: #071725;
  background:
    linear-gradient(
      180deg,
      rgba(247, 252, 250, 0.98),
      rgba(255, 255, 255, 0.99)
    ),
    radial-gradient(
      circle at 16% 10%,
      rgba(44, 106, 163, 0.09),
      transparent 42%
    ),
    radial-gradient(circle at 88% 20%, rgba(23, 109, 32, 0.09), transparent 42%) !important;
}

.partners-sec::before,
section.partners-sec.alive-section:not(.hero):not(.intel-sec)::before,
section.partners-sec.alive-section.is-awake:not(.hero):not(.intel-sec)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  opacity: 1;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 14%,
    #000 86%,
    transparent
  );
  transform: none;
  animation: none;
}

.partners-sec::after,
section.partners-sec.alive-section:not(.hero):not(.intel-sec)::after,
section.partners-sec.alive-section.is-awake:not(.hero):not(.intel-sec)::after {
  content: "";
  position: absolute;
  inset: auto 7% -180px 7%;
  z-index: 0;
  width: auto;
  height: 360px;
}

/* Override: show real SDG images (remove circular mask) */
.sdg-grid .sdg-icon,
.sdg-sec .sdg-grid .sdg-icon,
.sdg-icon {
  width: 72px !important;
  height: 72px !important;
  border-radius: 12px !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.sdg-grid .sdg-icon img,
.sdg-grid .sdg-icon svg,
.sdg-grid .sdg-icon .emoji,
.sdg-sec .sdg-grid .sdg-icon img,
.sdg-sec .sdg-grid .sdg-icon svg,
.sdg-sec .sdg-grid .sdg-icon .emoji,
.sdg-icon img,
.sdg-icon svg {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  display: block !important;
  background: transparent !important;
}

.partners-sec > .wrap,
.partners-sec .partner-track-outer {
  position: relative;
  z-index: 1;
}

.partners-sec .sec-header {
  max-width: 960px;
  margin-bottom: clamp(28px, 4vw, 44px);
}

.partners-sec .sec-header .eyebrow {
  color: #176d20;
  border-color: rgba(23, 109, 32, 0.14);
  background: rgba(255, 255, 255, 0.84);
}

.partners-sec .partners-heading {
  color: #071725 !important;
}

.partners-sec .partners-heading em {
  color: #176d20;
  background: linear-gradient(90deg, #176d20, #2c6aa3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.partners-sec .partners-lead {
  max-width: 760px;
  color: #26343b !important;
  opacity: 1;
}

.partners-sec .partner-track-outer {
  width: min(100%, 1320px);
  margin: 0 auto;
  padding: 18px 0 28px;
  overflow: hidden;
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 5%,
    #000 95%,
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 5%,
    #000 95%,
    transparent 100%
  );
}

.partners-sec .partner-track {
  display: flex;
  align-items: stretch;
  gap: clamp(16px, 2vw, 24px);
  width: max-content;
  padding-inline: clamp(18px, 3vw, 36px);
  animation: partnerScroll 54s linear infinite;
  will-change: transform;
}

.partners-sec .partner-track:hover,
.partners-sec .partner-track:focus-within {
  animation-play-state: paused;
}

.partners-sec .partner-track-outer.is-static {
  mask-image: none;
  -webkit-mask-image: none;
}

.partners-sec .partner-track.is-static {
  width: min(100% - 32px, 1040px);
  margin-inline: auto;
  padding-inline: 0;
  justify-content: center;
  flex-wrap: wrap;
  animation: none;
}

.partners-sec .partner-card {
  width: var(--partner-card-w);
  min-width: var(--partner-card-w);
  min-height: 168px;
  height: auto;
  margin: 0;
  padding: 14px;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), #fff 72%, #fbfdff), #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.92) inset;
  isolation: isolate;
}

.partners-sec .partner-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  height: auto;
  border-radius: inherit;
  background:
    linear-gradient(
      115deg,
      transparent 0 36%,
      rgba(255, 255, 255, 0.58) 48%,
      transparent 62%
    ),
    radial-gradient(
      circle at 88% 12%,
      rgba(44, 106, 163, 0.12),
      transparent 32%
    ),
    radial-gradient(
      circle at 12% 90%,
      rgba(94, 211, 155, 0.14),
      transparent 34%
    );
  opacity: 0;
  transform: translateX(-26%);
  transition:
    opacity 240ms var(--ease-out, ease),
    transform 520ms var(--ease-out, ease);
  pointer-events: none;
}

.partners-sec .partner-card:hover,
.partners-sec .partner-card:focus-within,
.partners-sec .partner-card.alive-card:hover {
  transform: translateY(-9px) scale(1.015);
  border-color: rgba(44, 106, 163, 0.2);
  box-shadow:
    0 30px 78px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(23, 109, 32, 0.08) inset;
}

.partners-sec .partner-card:hover::before,
.partners-sec .partner-card:focus-within::before {
  opacity: 1;
  transform: translateX(22%);
}

.partners-sec .partner-link {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 140px;
  color: inherit;
  text-align: center;
}

.partners-sec .partner-link:focus-visible {
  outline: 2px solid #2c6aa3;
  outline-offset: 5px;
  box-shadow: none;
}

.partners-sec .partner-logo-frame,
.partners-sec .partner-name-card {
  position: relative;
  display: flex;
  width: 100%;
  height: var(--partner-logo-h);
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(7, 17, 24, 0.07);
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, rgba(247, 252, 250, 0.96)), #fff;
  box-shadow:
    0 12px 26px rgba(7, 17, 24, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
  animation: none;
}

.partners-sec .partner-logo-frame {
  padding: 16px 20px;
}

.partners-sec .partner-logo-frame::after,
.partners-sec .partner-name-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 0 38%,
    rgba(255, 255, 255, 0.76) 48%,
    transparent 60%
  );
  transform: translateX(-120%);
  transition: transform 620ms var(--ease-out, ease);
  pointer-events: none;
}

.partners-sec .partner-card:hover .partner-logo-frame::after,
.partners-sec .partner-card:focus-within .partner-logo-frame::after,
.partners-sec .partner-card:hover .partner-name-card::after,
.partners-sec .partner-card:focus-within .partner-name-card::after {
  transform: translateX(120%);
}

.partners-sec .partner-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
  transform: none;
  transition:
    transform 240ms var(--ease-spring, ease),
    filter 240ms var(--ease-out, ease);
}

.partners-sec .partner-card:hover .partner-logo-img,
.partners-sec .partner-card:focus-within .partner-logo-img {
  transform: scale(1.045);
  filter: saturate(1.08) contrast(1.03);
}

.partners-sec .partner-name-card {
  padding: 18px 18px 18px 76px;
  background:
    linear-gradient(135deg, rgba(94, 211, 155, 0.14), transparent 46%),
    linear-gradient(180deg, #fff, rgba(247, 252, 250, 0.96));
}

.partners-sec .partner-name-card::before {
  content: attr(data-initial);
  position: absolute;
  left: 16px;
  top: 50%;
  display: grid;
  width: 46px;
  height: 46px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.28),
      transparent 30%
    ),
    linear-gradient(145deg, #0b7c7d, #176d20);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 19px;
  font-weight: 900;
  transform: translateY(-50%);
  box-shadow: 0 14px 26px rgba(7, 17, 24, 0.13);
}

.partners-sec .partner-logo-text {
  display: block;
  width: 100%;
  color: #071725;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 850;
  line-height: 1.22;
  letter-spacing: 0;
  text-wrap: balance;
  overflow-wrap: anywhere;
  filter: none;
  text-shadow: none;
}

.partners-sec .partner-badge {
  align-self: center;
  max-width: 100%;
  margin-top: 0;
  padding: 6px 10px;
  color: #176d20;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: normal;
  border: 1px solid rgba(23, 109, 32, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  opacity: 1;
}

.partners-sec .partner-card:hover .partner-badge,
.partners-sec .partner-card:focus-within .partner-badge {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, #176d20, #2c6aa3);
  transform: translateY(-1px);
}

@media (max-width: 900px) {
  .partners-sec {
    --partner-card-w: 228px;
    --partner-logo-h: 82px;
  }

  .partners-sec .partner-track {
    gap: 14px;
    padding-inline: 16px;
    animation-duration: 42s;
  }

  .partners-sec .partner-card {
    min-height: 144px;
    padding: 11px;
  }

  .partners-sec .partner-link {
    min-height: 120px;
  }

  .partners-sec .partner-logo-frame {
    padding: 12px 14px;
  }
}

@media (max-width: 520px) {
  .partners-sec {
    --partner-card-w: 196px;
    --partner-logo-h: 72px;
    padding-block: 58px;
  }

  .partners-sec .partner-track-outer {
    mask-image: linear-gradient(
      90deg,
      transparent 0,
      #000 24px,
      #000 calc(100% - 24px),
      transparent 100%
    );
    -webkit-mask-image: linear-gradient(
      90deg,
      transparent 0,
      #000 24px,
      #000 calc(100% - 24px),
      transparent 100%
    );
  }

  .partners-sec .partner-name-card {
    padding: 14px 14px 14px 58px;
  }

  .partners-sec .partner-name-card::before {
    left: 12px;
    width: 36px;
    height: 36px;
    font-size: 16px;
  }

  .partners-sec .partner-logo-text {
    font-size: 14px;
  }
}

/* About + gallery final override: match the modern focus/service language */
#about {
  position: relative;
  overflow: hidden;
  padding-block: clamp(78px, 8vw, 116px) !important;
  color: #071725;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.99),
      rgba(244, 250, 248, 0.96)
    ),
    radial-gradient(
      circle at 14% 12%,
      rgba(44, 106, 163, 0.08),
      transparent 42%
    ),
    radial-gradient(circle at 88% 18%, rgba(23, 109, 32, 0.08), transparent 42%) !important;
  isolation: isolate;
}

#about::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(18, 104, 74, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(44, 106, 163, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(
    180deg,
    transparent,
    #000 14%,
    #000 88%,
    transparent
  );
}

#about::after {
  content: "";
  position: absolute;
  inset: auto 8% -180px 8%;
  z-index: 0;
  height: 360px;
  pointer-events: none;
  border-radius: 50%;
  background:
    radial-gradient(
      ellipse at 48% 50%,
      rgba(44, 106, 163, 0.13),
      transparent 64%
    ),
    radial-gradient(
      ellipse at 60% 42%,
      rgba(94, 211, 155, 0.12),
      transparent 60%
    );
}

#about .wrap {
  position: relative;
  z-index: 1;
}

#about .grid2 {
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
}

#about .reveal-left,
#about .reveal-right {
  position: relative;
}

#about .reveal-left {
  padding: clamp(24px, 3vw, 34px) 0;
}

#about .reveal-left::before {
  content: "";
  display: block;
  width: 86px;
  height: 86px;
  margin-bottom: 22px;
  border: 3px solid #fff;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 24%,
      rgba(255, 255, 255, 0.32),
      transparent 30%
    ),
    linear-gradient(145deg, #0b7c7d, #176d20);
  box-shadow:
    0 18px 34px rgba(7, 17, 24, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.58) inset;
}

#about .reveal-left::after {
  content: "AHSIS";
  position: absolute;
  left: 26px;
  top: clamp(48px, 3vw, 60px);
  color: #fff;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0.02em;
}

#about .eyebrow {
  color: #176d20;
  border: 1px solid rgba(23, 109, 32, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 10px 24px rgba(7, 17, 24, 0.04);
}

#about .h2 {
  max-width: 680px;
  color: #071725;
  letter-spacing: 0;
}

#about .h2::after {
  content: "";
  display: block;
  width: 154px;
  height: 4px;
  margin-top: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #176d20 0 48%, #2c6aa3 52% 100%);
}

#about .h2 em {
  color: #176d20;
  background: linear-gradient(90deg, #176d20, #2c6aa3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

#about .lead {
  max-width: 620px;
  color: #26343b;
  font-size: clamp(16px, 1.5vw, 18px);
  line-height: 1.72;
}

#about .lead + p {
  max-width: 620px !important;
  color: #26343b !important;
  font-size: 15.5px !important;
  line-height: 1.8 !important;
}

#about .badge-row {
  gap: 10px;
  margin-top: 28px;
}

#about .bp {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  color: #176d20;
  font-weight: 800;
  border: 1px solid rgba(23, 109, 32, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 10px 24px rgba(7, 17, 24, 0.04);
}

#about .bp:hover {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, #176d20, #2c6aa3);
  transform: translateY(-2px);
}

#about .reveal-right > .eyebrow {
  margin-bottom: 16px;
}

#about .mission-visual {
  position: relative;
  padding: clamp(16px, 2vw, 22px);
  overflow: hidden;
  color: #071725;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), #fff 72%, #fbfdff), #fff;
  box-shadow:
    0 24px 66px rgba(7, 17, 24, 0.12),
    0 1px 0 rgba(255, 255, 255, 0.92) inset;
  animation: aboutGalleryFloat 7s ease-in-out infinite !important;
  isolation: isolate;
}

#about .mission-visual::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 92px;
  background:
    linear-gradient(
      90deg,
      rgba(23, 109, 32, 0.14),
      rgba(44, 106, 163, 0.08),
      rgba(255, 255, 255, 0.7)
    ),
    linear-gradient(135deg, rgba(255, 255, 255, 0.48), transparent);
  opacity: 1;
}

#about .mission-visual::after {
  content: "";
  position: absolute;
  inset: auto -42px -70px auto;
  z-index: -1;
  width: 210px;
  height: 210px;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(44, 106, 163, 0.16), transparent 66%),
    radial-gradient(
      circle at 38% 38%,
      rgba(94, 211, 155, 0.18),
      transparent 55%
    );
  pointer-events: none;
}

#about .mv-carousel {
  position: relative;
  z-index: 1;
  overflow: hidden !important;
  border: 1px solid rgba(7, 17, 24, 0.07);
  border-radius: 8px;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(247, 252, 250, 0.96)
    ),
    #fff;
  box-shadow: 0 16px 34px rgba(7, 17, 24, 0.09);
}

#about .mv-track {
  position: relative;
  width: 100%;
}

#about .mv-item {
  position: relative;
  min-height: clamp(300px, 31vw, 430px);
  overflow: hidden;
  border-radius: 8px !important;
  background: #eef8f4;
}

#about .mv-item::after {
  content: "";
  position: absolute;
  left: -5%;
  right: -5%;
  bottom: -1px;
  height: 70px;
  background: #fff;
  clip-path: polygon(
    0 62%,
    18% 70%,
    38% 72%,
    60% 68%,
    80% 59%,
    100% 50%,
    100% 100%,
    0 100%
  );
  pointer-events: none;
}

#about .mv-item .mv-img {
  width: 100% !important;
  height: clamp(300px, 31vw, 430px) !important;
  margin: 0 !important;
  object-fit: cover !important;
  object-position: center !important;
  border: 0 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  background: #eef8f4 !important;
  filter: saturate(1.04) contrast(1.02);
}

#about .mv-item.active[data-gallery-index]:hover .mv-img,
#about .mv-item.active[data-gallery-index]:focus-visible .mv-img {
  transform: scale(1.045) !important;
}

#about .mv-caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 3;
  max-height: none !important;
  margin: 0 !important;
  padding: 10px 13px;
  color: #071725 !important;
  font-size: 13px !important;
  font-weight: 800;
  line-height: 1.35;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 12px 26px rgba(7, 17, 24, 0.1);
  backdrop-filter: blur(12px);
}

#about .mv-tagline {
  position: relative;
  z-index: 1;
  margin: 20px 0 10px;
  color: #071725;
  font-size: clamp(22px, 2.3vw, 30px);
  line-height: 1.16;
  letter-spacing: 0;
}

#about .mv-tagline em {
  background: linear-gradient(90deg, #176d20, #2c6aa3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

#about .mv-sub {
  position: relative;
  z-index: 1;
  max-width: none;
  margin: 0;
  color: #26343b;
  font-size: 14.5px;
  line-height: 1.74;
}

#about .mission-visual:hover {
  transform: translateY(-8px);
  border-color: rgba(44, 106, 163, 0.2);
  box-shadow:
    0 32px 84px rgba(7, 17, 24, 0.15),
    0 0 0 1px rgba(23, 109, 32, 0.08) inset;
}

@keyframes aboutGalleryFloat {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

@media (max-width: 980px) {
  #about .grid2 {
    grid-template-columns: 1fr;
  }

  #about .reveal-left {
    padding-bottom: 0;
  }

  #about .mv-item,
  #about .mv-item .mv-img {
    height: clamp(280px, 54vw, 420px) !important;
    min-height: clamp(280px, 54vw, 420px);
  }
}

@media (max-width: 560px) {
  #about {
    padding-block: 60px !important;
  }

  #about .reveal-left::before {
    width: 72px;
    height: 72px;
  }

  #about .reveal-left::after {
    left: 21px;
    top: 43px;
    font-size: 14px;
  }

  #about .mission-visual {
    padding: 12px;
  }

  #about .mv-item,
  #about .mv-item .mv-img {
    height: 252px !important;
    min-height: 252px;
  }

  #about .mv-caption {
    left: 12px;
    right: 12px;
    bottom: 12px;
    border-radius: 8px;
  }
}

/* Keep About gallery as a true one-slide carousel */
#about .mv-carousel {
  height: clamp(300px, 31vw, 430px);
}

#about .mv-track {
  position: relative;
  height: 100%;
}

#about .mv-item {
  position: absolute !important;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(18px) scale(0.985);
  transition:
    opacity 620ms var(--ease-out, ease),
    transform 620ms var(--ease-out, ease),
    visibility 0s linear 620ms;
}

#about .mv-item.active {
  position: relative !important;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(0) scale(1);
  transition-delay: 0s;
  z-index: 2;
}

#about .mv-item .mv-img,
#about .mv-item.active .mv-img {
  position: absolute !important;
  inset: 0;
  opacity: 1 !important;
  pointer-events: auto;
}

@media (max-width: 980px) {
  #about .mv-carousel {
    height: clamp(280px, 54vw, 420px);
  }
}

@media (max-width: 560px) {
  #about .mv-carousel {
    height: 252px;
  }
}

/* Stability lock: counters are metrics, not icon badges */
.intern-intro-stats {
  align-items: stretch;
}

.intern-intro-stats .ist-card {
  display: grid;
  align-content: center;
  min-height: 128px;
  padding: 24px 28px;
  overflow: hidden;
  border: 1px solid rgba(7, 17, 24, 0.08);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), #fff 72%, #fbfdff), #fff;
  box-shadow:
    0 18px 44px rgba(7, 17, 24, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.intern-intro-stats .ist-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(90deg, #176d20, #2c6aa3, #f2b705);
}

.intern-intro-stats .ist-card::after {
  content: "";
  position: absolute;
  right: -34px;
  bottom: -52px;
  width: 148px;
  height: 148px;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(44, 106, 163, 0.12), transparent 68%),
    radial-gradient(
      circle at 36% 36%,
      rgba(94, 211, 155, 0.14),
      transparent 56%
    );
  pointer-events: none;
}

.intern-intro-stats .ist-card:hover {
  transform: translateY(-6px);
}

.intern-intro-stats .ist-num,
.intern-intro-stats .ist-card:hover .ist-num {
  position: relative;
  z-index: 1;
  display: block;
  width: auto;
  height: auto;
  min-width: 0;
  margin: 0;
  padding: 0;
  color: #176d20;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(34px, 4vw, 52px);
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  line-height: 0.98;
  letter-spacing: 0;
  text-shadow: none;
  border: 0;
  border-radius: 0;
  background: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

.intern-intro-stats .ist-lbl {
  position: relative;
  z-index: 1;
  margin-top: 8px;
  color: #26343b;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.3;
}

.stats-bar .si-num,
.stats-bar .si-lbl {
  font-variant-numeric: tabular-nums;
}

@media (max-width: 600px) {
  .intern-intro-stats {
    grid-template-columns: 1fr;
  }

  .intern-intro-stats .ist-card {
    min-height: 112px;
  }
}

.nav-student-cta {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--color-brand-bright);
  background: oklch(100% 0 0 / 0.08);
  border: 1px solid oklch(from var(--color-brand-bright) l c h / 0.28);
  padding: 8px 16px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  white-space: nowrap;
}

.student-auth-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}

.student-auth-tab {
  border: 1px solid var(--surface-border);
  background: var(--surface-soft);
  color: var(--text-ink2);
  border-radius: var(--radius-pill);
  padding: 10px 12px;
  font-weight: 800;
  cursor: pointer;
}

.student-auth-tab.active {
  background: linear-gradient(var(--gradient-angle), var(--color-action), var(--color-action-light));
  color: #fff;
  border-color: transparent;
}

.student-auth-panel {
  display: none;
}

.student-auth-panel.active {
  display: block;
}

.student-inline-actions {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.student-link-btn {
  border: 0;
  background: transparent;
  color: var(--color-action);
  font-weight: 800;
  cursor: pointer;
  padding: 0;
}

.student-dashboard {
  padding: 26px;
}

.student-dashboard-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}

.student-dashboard-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 900;
  color: var(--text-ink);
}

.student-dashboard-sub {
  color: var(--text-ink3);
  margin-top: 4px;
}

.student-dashboard-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.student-dashboard-tab {
  border: 1px solid var(--surface-border);
  background: var(--surface-white);
  border-radius: var(--radius-pill);
  padding: 10px 16px;
  cursor: pointer;
  font-weight: 900;
}

.student-dashboard-tab.active {
  color: #fff;
  background: linear-gradient(var(--gradient-angle), var(--color-action), var(--color-action-light));
  border-color: transparent;
}

.student-dashboard-panel {
  display: none;
}

.student-dashboard-panel.active {
  display: block;
}

.student-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 16px;
}

.student-card {
  border: 1px solid var(--surface-border);
  border-radius: 18px;
  padding: 18px;
  background: var(--surface-white);
  box-shadow: 0 14px 36px oklch(10% 0.02 152 / 0.06);
}

.student-card-title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 900;
  color: var(--text-ink);
  margin-bottom: 8px;
}

.student-card-meta {
  color: var(--text-ink3);
  font-size: 13px;
  line-height: 1.5;
}

.student-status-pill {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-pill);
  padding: 5px 10px;
  background: var(--surface-soft);
  color: var(--text-ink2);
  font-size: 11px;
  font-weight: 900;
  margin-top: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.student-status-pill.ok {
  color: #116329;
  background: rgba(34, 197, 94, 0.12);
}

.student-payment-box {
  border: 1px dashed oklch(from var(--color-action) l c h / 0.38);
  border-radius: 18px;
  padding: 16px;
  background: oklch(from var(--color-action) l c h / 0.05);
  margin-bottom: 16px;
}

.student-payment-qr {
  max-width: 180px;
  border-radius: 14px;
  border: 1px solid var(--surface-border);
  background: #fff;
  padding: 8px;
  margin-top: 12px;
}

.student-dashboard-home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  border: 1px solid var(--surface-border);
  background: var(--surface-white);
  color: var(--text-ink);
  padding: 10px 16px;
  font-weight: 900;
  text-decoration: none;
}

.student-dashboard-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 15% 15%, oklch(from var(--color-action) l c h / 0.18), transparent 34%),
    radial-gradient(circle at 85% 10%, oklch(from var(--color-brand-bright) l c h / 0.16), transparent 30%),
    linear-gradient(135deg, #f7fbf8 0%, #eef7f1 100%);
  color: var(--text-ink);
}

.student-page-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 42px 0;
}

.student-page-hero {
  border-radius: 28px;
  padding: clamp(28px, 5vw, 56px);
  margin-bottom: 22px;
  color: #fff;
  background: linear-gradient(135deg, var(--color-brand), var(--color-action));
  box-shadow: 0 26px 70px oklch(20% 0.03 150 / 0.18);
  position: relative;
  overflow: hidden;
}

.student-page-brand {
  display: inline-flex;
  color: #fff;
  text-decoration: none;
  font-weight: 900;
  margin-bottom: 28px;
  opacity: 0.92;
}

.student-page-kicker {
  color: var(--color-action);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 12px;
}

.student-page-hero h1 {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(34px, 6vw, 72px);
  line-height: 0.95;
  margin: 10px 0 14px;
  color: var(--text-ink);
}

.student-page-hero p {
  max-width: 720px;
  color: var(--text-ink2);
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.7;
}

.student-page-card {
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.75);
  box-shadow: 0 24px 70px oklch(18% 0.03 150 / 0.12);
  backdrop-filter: blur(18px);
  overflow: hidden;
}

.student-page-modal-card {
  max-width: 780px;
  margin: 0 auto;
}

.student-dashboard-page .m-form-header {
  border-radius: 26px 26px 0 0;
}

.student-dashboard-page .student-dashboard {
  padding: clamp(20px, 4vw, 34px);
}

@media (max-width: 700px) {
  .nav-student-cta {
    display: none;
  }

  .student-auth-tabs {
    grid-template-columns: 1fr;
  }

  .student-dashboard {
    padding: 18px;
  }

  .student-dashboard-head {
    flex-direction: column;
  }
}

.student-dashboard-page {
  font-family: "Inter", sans-serif;
  background:
    radial-gradient(circle at 12% 8%, rgba(34, 197, 94, 0.22), transparent 28%),
    radial-gradient(circle at 88% 14%, rgba(20, 184, 166, 0.18), transparent 26%),
    radial-gradient(circle at 50% 100%, rgba(16, 185, 129, 0.16), transparent 32%),
    linear-gradient(135deg, #f6fbf8 0%, #edf8f1 46%, #f9fffb 100%);
  overflow-x: hidden;
}

.student-dashboard-page::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(20, 83, 45, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20, 83, 45, 0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(to bottom, black, transparent 78%);
}

.student-page-shell {
  position: relative;
  z-index: 1;
  width: min(1220px, calc(100% - 32px));
  padding: 26px 0 54px;
}

.student-page-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 24px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 50px rgba(15, 118, 70, 0.1);
}

.student-page-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text-ink);
  text-decoration: none;
  font-weight: 900;
}

.student-page-logo span {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 15px;
  color: #fff;
  background: linear-gradient(135deg, var(--color-action), var(--color-brand));
  box-shadow: 0 14px 30px rgba(22, 163, 74, 0.24);
}

.student-page-logo strong {
  font-family: "Plus Jakarta Sans", sans-serif;
  letter-spacing: 0.02em;
}

.student-page-nav-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.student-page-nav-actions a,
.student-page-actions a,
.student-page-actions button {
  border: 1px solid rgba(20, 83, 45, 0.12);
  border-radius: var(--radius-pill);
  padding: 10px 16px;
  font-weight: 900;
  color: var(--text-ink);
  background: rgba(255, 255, 255, 0.68);
  text-decoration: none;
  cursor: pointer;
}

.student-page-nav-actions a:last-child,
.student-page-actions button {
  color: #fff;
  background: linear-gradient(135deg, var(--color-action), var(--color-brand));
  border-color: transparent;
  box-shadow: 0 16px 34px rgba(22, 163, 74, 0.24);
}

.student-page-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: clamp(24px, 5vw, 54px);
  align-items: center;
  min-height: 440px;
  padding: clamp(30px, 6vw, 64px);
  background:
    radial-gradient(circle at 15% 20%, rgba(255, 255, 255, 0.22), transparent 28%),
    radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.18), transparent 24%),
    linear-gradient(135deg, #073f2a 0%, #0d7a4f 48%, #14a36f 100%);
}

.student-page-hero::after {
  content: "";
  position: absolute;
  width: 340px;
  height: 340px;
  right: -80px;
  bottom: -120px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
}

.student-page-hero-copy {
  position: relative;
  z-index: 1;
}

.student-page-hero .student-page-kicker {
  color: var(--color-action);
}

.student-page-hero h1 {
  max-width: 760px;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.student-page-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.student-page-actions a {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.12);
}

.student-page-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.student-page-trust-row span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-ink2);
  border: 1px solid rgba(20, 83, 45, 0.12);
  border-radius: var(--radius-pill);
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.9);
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 2px 6px rgba(15, 118, 70, 0.06);
}

.student-page-trust-row span::before {
  content: "✓";
  display: inline-grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  color: #064e3b;
  background: #d9f99d;
}

.student-page-hero-panel {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(18px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.student-orbit-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 12px;
  align-items: center;
  border-radius: 22px;
  padding: 18px;
  color: var(--text-ink);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(20, 83, 45, 0.1);
  box-shadow: 0 4px 12px rgba(15, 118, 70, 0.06);
}

.student-orbit-card.main {
  background: rgba(255, 255, 255, 0.96);
  transform: translateX(-14px);
  box-shadow: 0 8px 20px rgba(15, 118, 70, 0.1);
}

.student-orbit-card span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  background: rgba(22, 163, 74, 0.12);
  font-size: 24px;
}

.student-orbit-card strong {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  color: var(--text-ink);
}

.student-orbit-card small {
  color: var(--text-ink3);
}

.student-page-highlights {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 0 0 22px;
}

.student-page-highlights article {
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 22px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 20px 48px rgba(15, 118, 70, 0.08);
  backdrop-filter: blur(14px);
}

.student-page-highlights span {
  display: inline-flex;
  color: var(--color-action);
  font-weight: 900;
  margin-bottom: 12px;
}

.student-page-highlights strong {
  display: block;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  color: var(--text-ink);
  margin-bottom: 6px;
}

.student-page-highlights p {
  color: var(--text-ink3);
  line-height: 1.6;
  font-size: 13px;
}

.student-page-card {
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 30px 80px rgba(15, 118, 70, 0.13);
}

.student-dashboard-page .m-form-header {
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.16), transparent 35%),
    linear-gradient(135deg, #053b29, #0d7a4f);
}

.student-dashboard-page .m-form-body {
  background: rgba(255, 255, 255, 0.94);
}

.student-auth-tabs {
  padding: 6px;
  border-radius: 999px;
  background: rgba(20, 83, 45, 0.06);
}

.student-auth-tab {
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.student-auth-tab.active {
  box-shadow: 0 14px 28px rgba(22, 163, 74, 0.2);
}

.student-auth-tab:hover,
.student-dashboard-tab:hover,
.student-card:hover {
  transform: translateY(-2px);
}

.student-dashboard {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 253, 250, 0.96));
}

.student-dashboard-head {
  align-items: center;
  padding: clamp(18px, 3vw, 28px);
  border-radius: 26px;
  background:
    radial-gradient(circle at 10% 20%, rgba(34, 197, 94, 0.18), transparent 34%),
    linear-gradient(135deg, #ffffff, #f2fbf5);
  border: 1px solid rgba(20, 83, 45, 0.08);
  box-shadow: 0 20px 45px rgba(15, 118, 70, 0.08);
}

.student-dashboard-user {
  display: flex;
  align-items: center;
  gap: 16px;
}

.student-dashboard-avatar {
  display: inline-grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 22px;
  color: #fff;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 30px;
  font-weight: 900;
  background: linear-gradient(135deg, var(--color-action), var(--color-brand));
  box-shadow: 0 18px 38px rgba(22, 163, 74, 0.24);
}

.student-dashboard .student-page-kicker,
.student-enrollment-panel .student-page-kicker {
  color: var(--color-action);
}

.student-dashboard-title {
  letter-spacing: -0.04em;
}

.student-dashboard-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 18px 0;
}

.student-dashboard-metrics div {
  border: 1px solid rgba(20, 83, 45, 0.08);
  border-radius: 22px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 34px rgba(15, 118, 70, 0.07);
}

.student-dashboard-metrics span {
  display: block;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1;
  color: var(--color-action);
  font-weight: 900;
}

.student-dashboard-metrics strong {
  display: block;
  margin-top: 8px;
  color: var(--text-ink3);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.student-dashboard-tabs {
  padding: 8px;
  border-radius: 999px;
  background: rgba(20, 83, 45, 0.06);
}

.student-dashboard-tab {
  border: 0;
  background: transparent;
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.student-dashboard-tab.active {
  box-shadow: 0 14px 30px rgba(22, 163, 74, 0.18);
}

.student-dashboard-tab.logout {
  margin-left: auto;
  color: #b42318;
  background: rgba(254, 226, 226, 0.7);
}

.student-card-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.student-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(20, 83, 45, 0.08);
  border-radius: 24px;
  padding: 22px;
  background:
    radial-gradient(circle at 20% 0%, rgba(34, 197, 94, 0.08), transparent 32%),
    #fff;
  box-shadow: 0 18px 42px rgba(15, 118, 70, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.student-card:hover {
  box-shadow: 0 24px 58px rgba(15, 118, 70, 0.13);
}

.student-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.student-card-icon {
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  background: rgba(22, 163, 74, 0.1);
  font-size: 23px;
}

.student-card-title {
  font-size: 18px;
  letter-spacing: -0.02em;
}

.student-course-details {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0;
}

.student-course-details span {
  border-radius: var(--radius-pill);
  padding: 7px 10px;
  background: rgba(20, 83, 45, 0.06);
  color: var(--text-ink2);
  font-size: 12px;
  font-weight: 800;
}

.student-card-btn,
.student-empty-btn {
  margin-top: 8px;
}

.student-empty-state {
  display: grid;
  place-items: center;
  text-align: center;
  border: 1px dashed rgba(22, 163, 74, 0.32);
  border-radius: 28px;
  padding: clamp(30px, 6vw, 70px);
  background: rgba(255, 255, 255, 0.74);
}

.student-empty-icon {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  border-radius: 26px;
  margin-bottom: 16px;
  background: rgba(22, 163, 74, 0.1);
  font-size: 36px;
}

.student-enrollment-panel,
.student-profile-panel {
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 28px;
  padding: clamp(20px, 4vw, 30px);
  background:
    radial-gradient(circle at 94% 0%, rgba(20, 184, 166, 0.13), transparent 30%),
    rgba(255, 255, 255, 0.88);
  box-shadow: 0 20px 52px rgba(15, 118, 70, 0.1);
}

.student-enrollment-head,
.student-profile-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
}

.student-profile-intro {
  justify-content: flex-start;
}

.student-enrollment-badge {
  border-radius: var(--radius-pill);
  color: #92400e;
  background: rgba(251, 191, 36, 0.16);
  padding: 9px 13px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.student-payment-box {
  border: 1px solid rgba(22, 163, 74, 0.18);
  border-radius: 22px;
  padding: 18px;
  background: linear-gradient(135deg, rgba(22, 163, 74, 0.08), rgba(20, 184, 166, 0.06));
}

.student-payment-qr {
  max-width: 160px;
  box-shadow: 0 16px 30px rgba(15, 118, 70, 0.12);
}

.student-dashboard-page .fm-fg input,
.student-dashboard-page .fm-fg select,
.student-dashboard-page .fm-fg textarea {
  border-radius: 16px;
  border-color: rgba(20, 83, 45, 0.14);
  background: rgba(255, 255, 255, 0.86);
}

@media (max-width: 900px) {
  .student-page-hero {
    grid-template-columns: 1fr;
  }

  .student-page-hero-panel {
    max-width: 560px;
  }

  .student-dashboard-metrics,
  .student-page-highlights {
    grid-template-columns: repeat(2, 1fr);
  }

  .student-dashboard-tab.logout {
    margin-left: 0;
  }
}

@media (max-width: 640px) {
  .student-page-shell {
    width: min(100% - 20px, 1220px);
    padding-top: 12px;
  }

  .student-page-nav,
  .student-dashboard-head,
  .student-dashboard-user,
  .student-enrollment-head {
    align-items: stretch;
    flex-direction: column;
  }

  .student-page-nav-actions,
  .student-page-actions,
  .student-dashboard-tabs {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
  }

  .student-page-nav-actions a,
  .student-page-actions a,
  .student-page-actions button,
  .student-dashboard-tab {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .student-page-hero {
    min-height: auto;
    border-radius: 22px;
  }

  .student-orbit-card.main {
    transform: none;
  }

  .student-dashboard-metrics,
  .student-page-highlights {
    grid-template-columns: 1fr;
  }
}

/* Enhanced Student Dashboard Design */
.student-dashboard-page {
  background:
    radial-gradient(ellipse at 0% 0%, rgba(34, 197, 94, 0.15) 0%, transparent 50%),
    radial-gradient(ellipse at 100% 100%, rgba(20, 184, 166, 0.12) 0%, transparent 50%),
    linear-gradient(180deg, #f0fdf4 0%, #ecfdf5 100%);
}

.student-dashboard {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.95) 100%);
  border: 1px solid rgba(20, 83, 45, 0.08);
  border-radius: 32px;
  padding: clamp(24px, 4vw, 36px);
  box-shadow:
    0 4px 6px rgba(15, 118, 70, 0.04),
    0 20px 60px rgba(15, 118, 70, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.student-dashboard-head {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08) 0%, rgba(20, 184, 166, 0.06) 100%);
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 24px;
  padding: clamp(20px, 3vw, 32px);
  margin-bottom: 24px;
}

.student-live-clock {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  background: linear-gradient(135deg, rgba(14, 165, 233, 0.12) 0%, rgba(59, 130, 246, 0.1) 100%);
  color: #0f766e;
  padding: 10px 16px;
  border-radius: 12px;
  font-weight: 600;
  font-size: 0.85rem;
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.15);
  white-space: nowrap;
  border: 1px solid rgba(14, 165, 233, 0.2);
}

.student-notices-section {
  margin-bottom: 24px;
}

.student-notices-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: #0f766e;
  margin-bottom: 16px;
  display: block;
}

.student-notice-card {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 250, 249, 0.96) 100%);
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 16px;
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: 0 4px 12px rgba(15, 118, 70, 0.08);
  display: block;
}

.student-notice-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.student-notice-type {
  font-weight: 700;
  font-size: 0.9rem;
  color: #0f766e;
  background: rgba(14, 165, 233, 0.1);
  padding: 4px 12px;
  border-radius: 8px;
}

.student-notice-date {
  font-size: 0.8rem;
  color: rgba(15, 118, 70, 0.6);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.student-notice-course {
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(15, 118, 70, 0.7);
  margin-bottom: 8px;
  display: block;
}

.student-notice-title-text {
  font-size: 1.1rem;
  font-weight: 700;
  color: #0f766e;
  margin-bottom: 8px;
  display: block;
}

.student-notice-message {
  font-size: 0.95rem;
  color: rgba(15, 118, 70, 0.8);
  margin-bottom: 12px;
  line-height: 1.6;
  display: block;
}

.student-notice-link {
  display: inline-block;
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  color: #fff;
  padding: 8px 20px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(22, 163, 74, 0.3);
  transition: transform 0.2s, box-shadow 0.2s;
}

.student-notice-link:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(22, 163, 74, 0.4);
}

.student-dashboard-avatar {
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  box-shadow:
    0 8px 24px rgba(22, 163, 74, 0.3),
    inset 0 2px 0 rgba(255, 255, 255, 0.3);
  border: 3px solid rgba(255, 255, 255, 0.9);
}

.student-dashboard-metrics {
  gap: 16px;
  margin-bottom: 24px;
}

.student-dashboard-metrics div {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 250, 249, 0.96) 100%);
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 20px;
  padding: 20px 16px;
  text-align: center;
  box-shadow:
    0 4px 12px rgba(15, 118, 70, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  transition: all 0.3s ease;
}

.student-dashboard-metrics div:hover {
  transform: translateY(-3px);
  box-shadow:
    0 8px 24px rgba(15, 118, 70, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.student-dashboard-metrics span {
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 2px 4px rgba(22, 163, 74, 0.2));
}

.student-dashboard-tabs {
  background: rgba(20, 83, 45, 0.04);
  border: 1px solid rgba(20, 83, 45, 0.08);
  border-radius: 16px;
  padding: 6px;
  gap: 6px;
  margin-bottom: 24px;
  box-shadow: inset 0 2px 4px rgba(15, 118, 70, 0.04);
}

.student-dashboard-tab {
  background: transparent;
  border: none;
  border-radius: 12px;
  padding: 12px 18px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-ink2);
  transition: all 0.2s ease;
}

.student-dashboard-tab:hover {
  background: rgba(20, 83, 45, 0.06);
  color: var(--text-ink);
}

.student-dashboard-tab.active {
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  color: #fff;
  box-shadow:
    0 4px 12px rgba(22, 163, 74, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.student-dashboard-tab.logout {
  color: #dc2626;
  background: rgba(254, 226, 226, 0.8);
}

.student-dashboard-tab.logout:hover {
  background: rgba(254, 226, 226, 1);
  color: #b91c1c;
}

.student-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.95) 100%);
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 20px;
  padding: 22px;
  box-shadow:
    0 4px 12px rgba(15, 118, 70, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  transition: all 0.3s ease;
}

.student-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 12px 32px rgba(15, 118, 70, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  border-color: rgba(20, 83, 45, 0.15);
}

.student-card-icon {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(20, 184, 166, 0.12) 100%);
  box-shadow: inset 0 2px 4px rgba(255, 255, 255, 0.6);
}

.student-status-pill {
  background: rgba(20, 83, 45, 0.08);
  color: var(--text-ink2);
  border: 1px solid rgba(20, 83, 45, 0.1);
  font-weight: 700;
  font-size: 11px;
  padding: 6px 12px;
  letter-spacing: 0.06em;
}

.student-status-pill.ok {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(20, 184, 166, 0.12) 100%);
  color: #166534;
  border-color: rgba(34, 197, 94, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.student-card-btn,
.student-empty-btn {
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  border: none;
  border-radius: 12px;
  padding: 12px 20px;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  box-shadow:
    0 4px 12px rgba(22, 163, 74, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
  transition: all 0.2s ease;
}

.student-card-btn:hover,
.student-empty-btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 6px 20px rgba(22, 163, 74, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.student-empty-state {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 250, 249, 0.96) 100%);
  border: 2px dashed rgba(34, 197, 94, 0.3);
  border-radius: 24px;
  padding: clamp(40px, 8vw, 80px);
  box-shadow: inset 0 2px 8px rgba(15, 118, 70, 0.04);
}

.student-empty-icon {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.15) 0%, rgba(20, 184, 166, 0.12) 100%);
  box-shadow:
    0 8px 24px rgba(22, 163, 74, 0.2),
    inset 0 2px 4px rgba(255, 255, 255, 0.6);
}

.student-enrollment-panel,
.student-profile-panel {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.95) 100%);
  border: 1px solid rgba(20, 83, 45, 0.1);
  border-radius: 24px;
  padding: clamp(24px, 4vw, 32px);
  box-shadow:
    0 8px 24px rgba(15, 118, 70, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.student-payment-box {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.06) 0%, rgba(20, 184, 166, 0.04) 100%);
  border: 1px solid rgba(20, 83, 45, 0.12);
  border-radius: 18px;
  padding: 20px;
  box-shadow: inset 0 2px 4px rgba(15, 118, 70, 0.04);
}

.student-payment-qr {
  border-radius: 12px;
  border: 2px solid rgba(255, 255, 255, 0.8);
  box-shadow: 0 8px 20px rgba(15, 118, 70, 0.12);
}

.student-dashboard-page .fm-fg input,
.student-dashboard-page .fm-fg select,
.student-dashboard-page .fm-fg textarea {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(20, 83, 45, 0.15);
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 14px;
  transition: all 0.2s ease;
  box-shadow: inset 0 1px 3px rgba(15, 118, 70, 0.04);
}

.student-dashboard-page .fm-fg input:focus,
.student-dashboard-page .fm-fg select:focus,
.student-dashboard-page .fm-fg textarea:focus {
  border-color: rgba(34, 197, 94, 0.4);
  box-shadow:
    0 0 0 3px rgba(34, 197, 94, 0.1),
    inset 0 1px 3px rgba(15, 118, 70, 0.04);
  outline: none;
}

.student-dashboard-page .fm-btn {
  background: linear-gradient(135deg, #16a34a 0%, #14b8a6 100%);
  border: none;
  border-radius: 14px;
  padding: 14px 24px;
  font-weight: 700;
  font-size: 15px;
  color: #fff;
  box-shadow:
    0 4px 12px rgba(22, 163, 74, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
  transition: all 0.2s ease;
}

.student-dashboard-page .fm-btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 6px 20px rgba(22, 163, 74, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.student-enrollment-badge {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.2) 0%, rgba(245, 158, 11, 0.15) 100%);
  color: #92400e;
  border: 1px solid rgba(245, 158, 11, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.student-card-grid {
  gap: 18px;
}

.student-course-details {
  border-top: 1px solid rgba(20, 83, 45, 0.08);
  padding-top: 14px;
  margin-top: 14px;
}
