/*
TemplateMo 622 Clearwave
https://templatemo.com/tm-622-clearwave
Free for personal and commercial use
*/

    /* ── TOKENS ── */
    :root {
      --bg:           #E8F4F2;
      --bg-alt:       #DFF0EE;
      --surface:      #F4FAFA;
      --surface-2:    #FFFFFF;
      --accent:       #1A7A6E;
      --accent-mid:   #2A9D8F;
      --accent-light: #5BBFB5;
      --accent-ghost: rgba(26,122,110,0.08);
      --accent-border:rgba(26,122,110,0.15);
      --text-1:       #0D1E1C;
      --text-2:       #3A5C58;
      --text-3:       #6B8C88;
      --border:       rgba(13,30,28,0.08);
      --shadow-sm:    0 2px 12px rgba(13,30,28,0.06);
      --shadow-md:    0 8px 32px rgba(13,30,28,0.10);
      --shadow-lg:    0 24px 64px rgba(13,30,28,0.13);
      --silk:         cubic-bezier(0.16, 1, 0.3, 1);
      --silk-dur:     0.8s;
      --radius:       16px;
      --radius-lg:    24px;
    }

    /* ── RESET ── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; font-size: 16px; scroll-padding-top: 80px; }
    body {
      font-family: 'DM Sans', sans-serif;
      background: var(--bg);
      color: var(--text-1);
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
    }
    a { text-decoration: none; color: inherit; }
    ul { list-style: none; }
    img { display: block; max-width: 100%; }
    button { cursor: pointer; border: none; background: none; font-family: inherit; }
    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: visible;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

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

    /* ── UTILITY ── */
    .container { max-width: 1160px; margin: 0 auto; padding: 0 32px; }
    .section-label {
      display: inline-flex; align-items: center; gap: 8px;
      font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
      text-transform: uppercase; color: var(--accent);
      background: var(--accent-ghost);
      border: 1px solid var(--accent-border);
      padding: 6px 14px; border-radius: 100px;
      margin-bottom: 20px;
    }
    .section-label::before {
      content: ''; width: 6px; height: 6px;
      background: var(--accent); border-radius: 50%;
    }
    .section-title {
      font-family: 'DM Sans', sans-serif;
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 700; letter-spacing: -0.03em;
      line-height: 1.15; color: var(--text-1);
    }
    .section-title em {
      font-style: italic;
      font-family: 'Playfair Display', serif;
      color: var(--accent);
    }
    .section-sub {
      font-size: 1.0625rem; line-height: 1.75;
      color: var(--text-2); max-width: 520px; margin-top: 16px;
    }
    .page-banner {
      position: relative;
      overflow: hidden;
      padding: 156px 0 54px;
      background:
        radial-gradient(circle at 15% 18%, rgba(255, 193, 86, 0.32), transparent 26%),
        radial-gradient(circle at 82% 20%, rgba(37, 99, 235, 0.24), transparent 24%),
        radial-gradient(circle at 62% 72%, rgba(16, 185, 129, 0.22), transparent 28%),
        linear-gradient(135deg, #071c31 0%, #0c3559 38%, #11658d 100%);
      border-bottom: 1px solid rgba(255,255,255,0.12);
    }
    .page-banner::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
      background-size: 44px 44px;
      mask-image: linear-gradient(180deg, rgba(0,0,0,0.65), transparent 92%);
      pointer-events: none;
    }
    .page-banner::after {
      content: '';
      position: absolute;
      inset: auto 0 0;
      height: 120px;
      background: linear-gradient(180deg, rgba(7,28,49,0), rgba(255,255,255,0.16));
      pointer-events: none;
    }
    .page-banner-glow {
      position: absolute;
      border-radius: 999px;
      filter: blur(18px);
      opacity: 0.95;
      pointer-events: none;
    }
    .page-banner-glow-one {
      top: 86px;
      left: 7%;
      width: 220px;
      height: 220px;
      background: radial-gradient(circle, rgba(129, 140, 248, 0.52), rgba(129, 140, 248, 0));
    }
    .page-banner-glow-two {
      right: 8%;
      bottom: 12px;
      width: 260px;
      height: 260px;
      background: radial-gradient(circle, rgba(16, 185, 129, 0.34), rgba(16, 185, 129, 0));
    }
    .page-banner-inner {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) max-content;
      align-items: end;
      gap: 26px;
      padding: 34px 38px;
      border-radius: 34px;
      background:
        linear-gradient(135deg, rgba(255,255,255,0.2), rgba(255,255,255,0.08)),
        rgba(7, 28, 49, 0.38);
      border: 1px solid rgba(255,255,255,0.18);
      box-shadow:
        0 28px 70px rgba(5, 17, 30, 0.34),
        inset 0 1px 0 rgba(255,255,255,0.18);
      backdrop-filter: blur(14px);
    }
    .page-banner-copy {
      min-width: 0;
    }
    .page-banner-kicker {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 8px 16px;
      border-radius: 999px;
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.16);
      color: rgba(233, 244, 255, 0.84);
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }
    .page-banner-kicker::before {
      content: '';
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: #7dd3fc;
      box-shadow: 0 0 0 8px rgba(125, 211, 252, 0.14);
    }
    .page-banner-title {
      margin-top: 18px;
      font-family: 'DM Sans', sans-serif;
      font-size: clamp(2.25rem, 4.8vw, 4rem);
      font-weight: 700;
      letter-spacing: -0.06em;
      line-height: 0.98;
      color: #ffffff;
      text-wrap: balance;
      max-width: 12ch;
    }
    .page-banner-subtitle {
      margin-top: 16px;
      max-width: 54ch;
      color: rgba(221, 237, 248, 0.82);
      font-size: 1rem;
      line-height: 1.8;
    }
    .page-banner-breadcrumbs {
      justify-self: end;
      display: inline-flex;
      align-items: center;
      gap: 12px;
      flex-wrap: wrap;
      padding: 14px 18px;
      border-radius: 18px;
      background: rgba(255,255,255,0.14);
      border: 1px solid rgba(255,255,255,0.16);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
      font-size: 0.96rem;
      color: rgba(231, 243, 252, 0.7);
    }
    .page-banner-breadcrumbs a {
      color: #8be9d0;
      font-weight: 600;
    }
    .page-banner-breadcrumbs strong {
      color: #ffffff;
      font-weight: 700;
    }

    /* ── SCROLL REVEAL ── */
    .reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s var(--silk), transform 0.7s var(--silk); }
    .reveal.visible { opacity: 1; transform: none; }
    .reveal-delay-1 { transition-delay: 0.1s; }
    .reveal-delay-2 { transition-delay: 0.2s; }
    .reveal-delay-3 { transition-delay: 0.3s; }
    .reveal-delay-4 { transition-delay: 0.4s; }

    /* ══════════════════════════════════════════
       1. NAV
    ══════════════════════════════════════════ */
    .nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
      padding: 18px 0;
      transition: padding var(--silk-dur) var(--silk);
    }
    .nav-shell {
      max-width: 1220px;
      margin: 0 auto;
      padding: 0 28px;
    }
    .nav-inner {
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: 18px;
      padding: 14px 18px 14px 20px;
      border-radius: 28px;
      background:
        linear-gradient(180deg, rgba(255,255,255,0.82), rgba(244,250,250,0.72));
      border: 1px solid rgba(255,255,255,0.55);
      box-shadow:
        0 20px 50px rgba(13,30,28,0.10),
        inset 0 1px 0 rgba(255,255,255,0.7);
      backdrop-filter: blur(22px);
      -webkit-backdrop-filter: blur(22px);
      transition:
        transform var(--silk-dur) var(--silk),
        box-shadow var(--silk-dur) var(--silk),
        background var(--silk-dur) var(--silk);
    }
    .nav.scrolled .nav-inner {
      transform: translateY(-2px);
      box-shadow:
        0 26px 56px rgba(13,30,28,0.14),
        inset 0 1px 0 rgba(255,255,255,0.75);
      background:
        linear-gradient(180deg, rgba(255,255,255,0.90), rgba(244,250,250,0.82));
    }
    .nav-brand-wrap {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
    }
    .nav-locale-switcher,
    .mobile-locale-switcher {
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .nav-locale-switcher {
      padding: 7px;
      border-radius: 18px;
      background: rgba(255,255,255,0.62);
      border: 1px solid rgba(26,122,110,0.10);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
      flex-shrink: 0;
    }
    .locale-flag-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      min-width: 44px;
      min-height: 44px;
      padding: 0 10px;
      border-radius: 14px;
      color: var(--text-2);
      background: transparent;
      border: 1px solid transparent;
      transition:
        background 0.35s var(--silk),
        border-color 0.35s var(--silk),
        transform 0.35s var(--silk),
        box-shadow 0.35s var(--silk),
        color 0.35s var(--silk);
    }
    .locale-flag-link:hover {
      background: rgba(255,255,255,0.95);
      border-color: rgba(26,122,110,0.10);
      transform: translateY(-1px);
      box-shadow: 0 8px 18px rgba(13,30,28,0.08);
      color: var(--accent);
    }
    .locale-flag-link.active {
      background: rgba(255,255,255,0.98);
      border-color: rgba(26,122,110,0.16);
      box-shadow: 0 10px 20px rgba(13,30,28,0.08);
    }
    .flag-icon {
      width: 20px;
      height: 20px;
      border-radius: 50%;
      border: 1px solid rgba(13,30,28,0.10);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,0.25);
      flex-shrink: 0;
    }
    .flag-fr {
      background: linear-gradient(90deg, #1f4fd6 0 33.33%, #ffffff 33.33% 66.66%, #de2b2b 66.66% 100%);
    }
    .flag-en {
      background:
        linear-gradient(90deg, transparent 42%, #ffffff 42% 58%, transparent 58%),
        linear-gradient(transparent 42%, #ffffff 42% 58%, transparent 58%),
        linear-gradient(90deg, transparent 46%, #c8252c 46% 54%, transparent 54%),
        linear-gradient(transparent 46%, #c8252c 46% 54%, transparent 54%),
        #1a47b8;
    }
    .nav-logo {
      display: flex;
      align-items: center;
      gap: 12px;
      min-width: 0;
    }
    .nav-logo-mark {
      width: 58px;
      height: 58px;
      object-fit: contain;
      border-radius: 18px;
      padding: 6px;
      background: linear-gradient(135deg, rgba(255,255,255,0.88), rgba(223,240,238,0.78));
      border: 1px solid rgba(26,122,110,0.10);
      box-shadow: 0 10px 24px rgba(13,30,28,0.08);
      flex-shrink: 0;
    }
    .nav-logo-copy {
      display: flex;
      flex-direction: column;
      gap: 2px;
      min-width: 0;
    }
    .nav-logo-copy span {
      font-size: 0.66rem;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--accent);
      white-space: nowrap;
    }
    .nav-logo-copy strong {
      font-size: 1rem;
      font-weight: 700;
      letter-spacing: -0.03em;
      color: var(--text-1);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .nav-logo-copy-mobile {
      display: none;
    }
    .nav-status {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 9px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,0.62);
      border: 1px solid var(--accent-border);
      color: var(--text-2);
      font-size: 0.76rem;
      font-weight: 600;
      white-space: nowrap;
    }
    .nav-status-dot {
      width: 9px;
      height: 9px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--accent-light), var(--accent));
      box-shadow: 0 0 0 5px rgba(26,122,110,0.10);
      flex-shrink: 0;
    }
    .nav-links {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 6px;
      min-width: 0;
      border-radius: 999px;
      background: rgba(255,255,255,0.42);
      border: 1px solid rgba(26,122,110,0.08);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.55);
    }
    .nav-links a {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 40px;
      padding: 0 16px;
      font-size: 0.87rem;
      font-weight: 600;
      letter-spacing: -0.01em;
      color: var(--text-2);
      border-radius: 999px;
      transition:
        color 0.35s var(--silk),
        background 0.35s var(--silk),
        transform 0.35s var(--silk),
        box-shadow 0.35s var(--silk);
    }
    .nav-links a:hover {
      color: var(--accent);
      background: rgba(255,255,255,0.9);
      transform: translateY(-1px);
      box-shadow: 0 8px 18px rgba(13,30,28,0.08);
    }
    .nav-links a.is-active {
      color: var(--accent);
      background: rgba(255,255,255,0.94);
      box-shadow: 0 10px 22px rgba(13,30,28,0.1);
    }
    .nav-cta {
      display: flex;
      align-items: center;
      gap: 10px;
      justify-self: end;
    }
    .nav-locale {
      display: flex;
      flex-direction: column;
      gap: 1px;
      padding: 10px 14px;
      border-radius: 18px;
      background: rgba(255,255,255,0.66);
      border: 1px solid rgba(26,122,110,0.10);
      min-width: 88px;
    }
    .nav-locale span {
      font-size: 0.62rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-3);
    }
    .nav-locale strong {
      font-size: 0.84rem;
      font-weight: 700;
      color: var(--text-1);
    }
    .btn-ghost {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 44px;
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--text-2);
      padding: 0 18px;
      border-radius: 999px;
      background: rgba(255,255,255,0.54);
      border: 1px solid rgba(26,122,110,0.08);
      transition:
        color 0.35s var(--silk),
        background 0.35s var(--silk),
        transform 0.35s var(--silk),
        box-shadow 0.35s var(--silk);
    }
    .btn-ghost:hover {
      color: var(--accent);
      background: rgba(255,255,255,0.9);
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(13,30,28,0.08);
    }
    .btn-primary {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 46px;
      font-size: 0.875rem;
      font-weight: 700;
      color: #fff;
      background: linear-gradient(135deg, var(--accent) 0%, var(--accent-mid) 100%);
      padding: 0 22px;
      border-radius: 999px;
      transition:
        background var(--silk-dur) var(--silk),
        transform var(--silk-dur) var(--silk),
        box-shadow var(--silk-dur) var(--silk);
      box-shadow: 0 12px 26px rgba(26,122,110,0.26);
    }
    .btn-primary:hover {
      background: linear-gradient(135deg, var(--accent-mid) 0%, var(--accent-light) 100%);
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 16px 30px rgba(26,122,110,0.34);
    }

    .nav-hamburger {
      display: none;
      align-items: center;
      justify-content: center;
      width: 48px;
      height: 48px;
      padding: 0;
      position: relative;
      border-radius: 16px;
      background: rgba(255,255,255,0.65);
      border: 1px solid rgba(26,122,110,0.08);
      box-shadow: 0 10px 20px rgba(13,30,28,0.06);
    }
    .nav-hamburger span {
      display: block;
      width: 18px;
      height: 2px;
      background: var(--text-1);
      border-radius: 2px;
      transition: all 0.4s var(--silk);
      position: absolute;
    }
    .nav-hamburger span:nth-child(1) { transform: translateY(-6px); }
    .nav-hamburger span:nth-child(2) { transform: translateY(0); }
    .nav-hamburger span:nth-child(3) { transform: translateY(6px); }
    .nav-hamburger.open span:nth-child(1) { transform: translateY(0) rotate(45deg); }
    .nav-hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
    .nav-hamburger.open span:nth-child(3) { transform: translateY(0) rotate(-45deg); }

    .mobile-menu {
      position: fixed;
      inset: 0;
      z-index: 999;
      display: grid;
      place-items: start center;
      padding: 88px 20px 24px;
      background: rgba(232,244,242,0.72);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.35s var(--silk);
      overflow-y: auto;
    }
    .mobile-menu.open { opacity: 1; pointer-events: all; }
    .mobile-menu-panel {
      width: min(100%, 560px);
      padding: 22px;
      border-radius: 28px;
      background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(244,250,250,0.92));
      border: 1px solid rgba(255,255,255,0.7);
      box-shadow: 0 24px 56px rgba(13,30,28,0.14);
    }
    .mobile-menu-top {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 14px;
    }
    .mobile-brand {
      display: flex;
      align-items: center;
      gap: 12px;
      min-width: 0;
    }
    .mobile-brand img {
      width: 54px;
      height: 54px;
      object-fit: contain;
      border-radius: 16px;
      padding: 6px;
      background: rgba(223,240,238,0.85);
      border: 1px solid rgba(26,122,110,0.10);
      flex-shrink: 0;
    }
    .mobile-brand-copy {
      display: flex;
      flex-direction: column;
      gap: 3px;
      min-width: 0;
    }
    .mobile-brand-copy span {
      font-size: 0.66rem;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--accent);
    }
    .mobile-brand-copy strong {
      font-size: 1rem;
      font-weight: 700;
      letter-spacing: -0.03em;
      color: var(--text-1);
    }
    .mobile-menu-locale {
      display: flex;
      flex-direction: column;
      gap: 2px;
      align-items: flex-end;
      padding: 10px 12px;
      border-radius: 16px;
      background: rgba(223,240,238,0.58);
      border: 1px solid rgba(26,122,110,0.10);
      flex-shrink: 0;
    }
    .mobile-menu-locale span {
      font-size: 0.62rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--text-3);
    }
    .mobile-menu-locale strong {
      font-size: 0.85rem;
      color: var(--text-1);
    }
    .mobile-menu-summary {
      margin: 18px 0 20px;
      font-size: 0.95rem;
      line-height: 1.7;
      color: var(--text-2);
      max-width: 34ch;
    }
    .mobile-locale-switcher {
      margin-top: 16px;
      padding: 10px;
      border-radius: 18px;
      background: rgba(223,240,238,0.52);
      border: 1px solid rgba(26,122,110,0.10);
    }
    .mobile-locale-switcher .locale-flag-link {
      flex: 1;
      justify-content: center;
      min-height: 48px;
      background: rgba(255,255,255,0.62);
      border-color: rgba(26,122,110,0.08);
      font-size: 0.84rem;
      font-weight: 700;
    }
    .mobile-locale-switcher .locale-flag-link.active {
      background: rgba(255,255,255,0.98);
    }
    .mobile-menu-links {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .mobile-menu-links a {
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 56px;
      padding: 0 18px;
      border-radius: 18px;
      background: rgba(255,255,255,0.72);
      border: 1px solid rgba(26,122,110,0.08);
      font-size: 1rem;
      font-weight: 600;
      color: var(--text-1);
      opacity: 0;
      transform: translateY(16px);
      transition:
        opacity 0.45s var(--silk),
        transform 0.45s var(--silk),
        background 0.3s var(--silk),
        color 0.3s var(--silk);
    }
    .mobile-menu-links a::after {
      content: '->';
      color: var(--accent);
      font-size: 0.85rem;
      opacity: 0.8;
    }
    .mobile-menu.open .mobile-menu-links a { opacity: 1; transform: none; }
    .mobile-menu-links a:hover {
      background: rgba(223,240,238,0.92);
      color: var(--accent);
    }
    .mobile-menu-links a.is-active {
      background: rgba(223,240,238,0.98);
      color: var(--accent);
      border-color: rgba(26,122,110,0.16);
    }
    .mobile-menu-links a:nth-child(1) { transition-delay: 0.04s; }
    .mobile-menu-links a:nth-child(2) { transition-delay: 0.08s; }
    .mobile-menu-links a:nth-child(3) { transition-delay: 0.12s; }
    .mobile-menu-links a:nth-child(4) { transition-delay: 0.16s; }
    .mobile-menu-links a:nth-child(5) { transition-delay: 0.20s; }
    .mobile-menu-links a:nth-child(6) { transition-delay: 0.24s; }
    .mobile-menu-actions {
      display: flex;
      gap: 10px;
      margin-top: 18px;
    }
    .mobile-menu .mobile-secondary,
    .mobile-menu .mobile-cta {
      flex: 1;
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 0.5s var(--silk) 0.28s, transform 0.5s var(--silk) 0.28s, background 0.3s;
    }
    .mobile-menu.open .mobile-secondary,
    .mobile-menu.open .mobile-cta { opacity: 1; transform: none; }

    /* ══════════════════════════════════════════
       2. HERO
    ══════════════════════════════════════════ */
    .hero {
      min-height: 100vh;
      display: flex; align-items: center;
      padding: 120px 0 80px;
      position: relative; overflow: hidden;
    }
    /* Decorative background circles */
    .hero::before {
      content: '';
      position: absolute; top: -10%; right: -5%;
      width: 55vw; height: 55vw; max-width: 720px; max-height: 720px;
      background: radial-gradient(ellipse at center, rgba(91,191,181,0.18) 0%, rgba(42,157,143,0.06) 50%, transparent 75%);
      border-radius: 50%;
      pointer-events: none;
    }
    .hero::after {
      content: '';
      position: absolute; bottom: -15%; left: -8%;
      width: 40vw; height: 40vw; max-width: 500px; max-height: 500px;
      background: radial-gradient(ellipse at center, rgba(26,122,110,0.10) 0%, transparent 70%);
      border-radius: 50%;
      pointer-events: none;
    }
    .hero-inner {
      position: relative; z-index: 1;
      display: grid; grid-template-columns: 1fr 1fr;
      align-items: center; gap: 64px;
    }
    .hero-badge {
      display: inline-flex; align-items: center; gap: 8px;
      background: var(--surface-2); border: 1px solid var(--accent-border);
      border-radius: 100px; padding: 6px 16px 6px 8px;
      margin-bottom: 28px; box-shadow: var(--shadow-sm);
    }
    .hero-badge-dot {
      width: 24px; height: 24px; border-radius: 50%;
      background: var(--accent); display: flex; align-items: center; justify-content: center;
      font-size: 11px; color: #fff; font-weight: 700; flex-shrink: 0;
    }
    .hero-badge span { font-size: 0.8125rem; font-weight: 500; color: var(--text-2); }
    .hero-badge strong { color: var(--accent); }
    .hero-title {
      font-size: clamp(2.6rem, 5vw, 4.2rem);
      font-weight: 700; letter-spacing: -0.04em; line-height: 1.1;
      margin-bottom: 24px;
    }
    .hero-title em {
      font-style: italic;
      font-family: 'Playfair Display', serif;
      color: var(--accent);
    }
    .hero-sub {
      font-size: 1.0625rem; line-height: 1.75;
      color: var(--text-2); max-width: 480px; margin-bottom: 40px;
    }
    .hero-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
    .btn-primary-lg {
      font-size: 0.9375rem; font-weight: 600; color: #fff;
      background: var(--accent); padding: 14px 32px; border-radius: 100px;
      display: flex; align-items: center; gap: 10px;
      transition: background var(--silk-dur) var(--silk), transform var(--silk-dur) var(--silk), box-shadow var(--silk-dur) var(--silk);
      box-shadow: 0 6px 24px rgba(26,122,110,0.30);
    }
    .btn-primary-lg:hover { background: var(--accent-mid); transform: scale(1.02); box-shadow: 0 8px 32px rgba(26,122,110,0.40); }
    .btn-primary-lg .btn-arrow { transition: transform 0.4s var(--silk); }
    .btn-primary-lg:hover .btn-arrow { transform: translateX(4px); }
    .btn-outline-lg {
      font-size: 0.9375rem; font-weight: 500; color: var(--accent);
      border: 1.5px solid var(--accent-border); padding: 13px 28px; border-radius: 100px;
      display: flex; align-items: center; gap: 8px;
      transition: background 0.4s var(--silk), border-color 0.4s var(--silk), transform var(--silk-dur) var(--silk);
    }
    .btn-outline-lg:hover { background: var(--accent-ghost); border-color: var(--accent); transform: scale(1.02); }

    /* Trust badges */
    .hero-trust {
      display: flex; align-items: center; gap: 20px;
      margin-top: 48px; flex-wrap: wrap;
    }
    .trust-item {
      display: flex; align-items: center; gap: 8px;
      font-size: 0.8125rem; color: var(--text-3); font-weight: 500;
    }
    .trust-item svg { color: var(--accent); flex-shrink: 0; }
    .trust-divider { width: 1px; height: 20px; background: var(--border); }

    /* Hero visual */
    .hero-visual {
      position: relative; display: flex; justify-content: center; align-items: center;
    }
    .hero-dashboard {
      width: 100%; max-width: 520px;
      background: var(--surface-2);
      border-radius: var(--radius-lg);
      border: 1px solid var(--border);
      box-shadow: var(--shadow-lg);
      overflow: hidden;
      transition: transform var(--silk-dur) var(--silk);
    }
    .hero-dashboard:hover { transform: scale(1.01); }
    .dashboard-bar {
      background: var(--bg-alt); padding: 12px 16px;
      display: flex; align-items: center; gap: 8px;
      border-bottom: 1px solid var(--border);
    }
    .db-dot { width: 10px; height: 10px; border-radius: 50%; }
    .db-dot:nth-child(1) { background: #FF5F57; }
    .db-dot:nth-child(2) { background: #FFBD2E; }
    .db-dot:nth-child(3) { background: #28CA41; }
    .dashboard-body { padding: 24px; }
    .db-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
    .db-title { font-size: 0.875rem; font-weight: 600; color: var(--text-1); }
    .db-tag {
      font-size: 0.72rem; font-weight: 600; letter-spacing: 0.08em;
      text-transform: uppercase; color: var(--accent);
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      padding: 3px 10px; border-radius: 100px;
    }
    .db-chart {
      height: 80px; display: flex; align-items: flex-end; gap: 6px; margin-bottom: 20px;
    }
    .db-bar {
      flex: 1; border-radius: 4px 4px 0 0;
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      transition: height 1s var(--silk);
    }
    .db-bar.active { background: var(--accent); border-color: var(--accent); }
    .db-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
    .db-stat {
      background: var(--bg); border-radius: var(--radius);
      padding: 14px; border: 1px solid var(--border);
    }
    .db-stat-val { font-size: 1.25rem; font-weight: 700; color: var(--text-1); letter-spacing: -0.03em; }
    .db-stat-label { font-size: 0.72rem; color: var(--text-3); margin-top: 2px; }
    .db-stat-change { font-size: 0.72rem; font-weight: 600; color: var(--accent); margin-top: 4px; }

    /* Floating badge on hero visual */
    .hero-float-badge {
      position: absolute; bottom: -16px; left: -24px;
      background: var(--surface-2); border: 1px solid var(--border);
      border-radius: var(--radius); padding: 12px 16px;
      box-shadow: var(--shadow-md);
      display: flex; align-items: center; gap: 10px;
      animation: floatBadge 4s ease-in-out infinite;
    }
    @keyframes floatBadge {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-6px); }
    }
    .float-badge-icon {
      width: 36px; height: 36px; border-radius: 10px;
      background: var(--accent); display: flex; align-items: center; justify-content: center;
      color: #fff; font-size: 16px; flex-shrink: 0;
    }
    .float-badge-text { font-size: 0.75rem; }
    .float-badge-text strong { display: block; font-weight: 700; color: var(--text-1); }
    .float-badge-text span { color: var(--text-3); }

    .hero-float-badge-2 {
      position: absolute; top: 20px; right: -20px;
      background: var(--accent); border-radius: var(--radius);
      padding: 10px 16px; box-shadow: 0 8px 24px rgba(26,122,110,0.35);
      animation: floatBadge2 4s ease-in-out 2s infinite;
    }
    @keyframes floatBadge2 {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-5px); }
    }
    .float-badge-2-val { font-size: 1.4rem; font-weight: 700; color: #fff; letter-spacing: -0.03em; }
    .float-badge-2-label { font-size: 0.7rem; color: rgba(255,255,255,0.7); margin-top: 2px; }

    /* ══════════════════════════════════════════
       3. LOGO TICKER
    ══════════════════════════════════════════ */
    .ticker-section {
      padding: 48px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
      background: var(--surface);
      overflow: hidden; position: relative;
    }
    .ticker-label {
      text-align: center; font-size: 0.75rem; letter-spacing: 0.12em;
      text-transform: uppercase; color: var(--text-3); font-weight: 600;
      margin-bottom: 28px;
    }
    .ticker-track-wrap { overflow: hidden; }
    .ticker-track {
      display: flex; align-items: center; gap: 64px;
      width: max-content;
      animation: ticker 28s linear infinite;
    }
    .ticker-track:hover { animation-play-state: paused; }
    @keyframes ticker {
      from { transform: translateX(0); }
      to { transform: translateX(-50%); }
    }
    .ticker-item {
      display: flex; align-items: center; gap: 10px;
      font-size: 1.0625rem; font-weight: 700; letter-spacing: -0.03em;
      color: var(--text-3); white-space: nowrap; flex-shrink: 0;
      transition: color 0.3s;
    }
    .ticker-item:hover { color: var(--accent); }
    .ticker-item-icon {
      width: 32px; height: 32px; border-radius: 8px;
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      display: flex; align-items: center; justify-content: center; flex-shrink: 0;
    }
    .ticker-dot {
      width: 5px; height: 5px; border-radius: 50%;
      background: var(--accent-light); flex-shrink: 0; opacity: 0.5;
    }

    /* ══════════════════════════════════════════
       4. FEATURES
    ══════════════════════════════════════════ */
    .features-section { padding: 120px 0; }
    .features-header { text-align: center; margin-bottom: 80px; }
    .features-header .section-sub { margin: 16px auto 0; text-align: center; }

    .feature-row {
      display: grid; grid-template-columns: 1fr 1fr;
      align-items: center; gap: 80px; margin-bottom: 100px;
    }
    .feature-row:last-child { margin-bottom: 0; }
    .feature-row.reverse { direction: rtl; }
    .feature-row.reverse > * { direction: ltr; }

    .feature-content {}
    .feature-number {
      font-size: 0.75rem; font-weight: 700; letter-spacing: 0.14em;
      text-transform: uppercase; color: var(--accent-light);
      margin-bottom: 16px;
    }
    .feature-title {
      font-size: clamp(1.6rem, 3vw, 2.2rem);
      font-weight: 700; letter-spacing: -0.03em; line-height: 1.2;
      margin-bottom: 16px;
    }
    .feature-desc {
      font-size: 1rem; line-height: 1.75; color: var(--text-2); margin-bottom: 28px;
    }
    .feature-checklist { display: flex; flex-direction: column; gap: 10px; }
    .feature-check {
      display: flex; align-items: flex-start; gap: 10px;
      font-size: 0.9rem; color: var(--text-2);
    }
    .check-icon {
      width: 20px; height: 20px; border-radius: 50%;
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; margin-top: 1px;
      color: var(--accent); font-size: 11px; font-weight: 700;
    }

    .feature-visual {
      background: var(--surface);
      border-radius: var(--radius-lg);
      border: 1px solid var(--border);
      box-shadow: var(--shadow-md);
      overflow: hidden;
      aspect-ratio: 4/3;
      display: flex; align-items: center; justify-content: center;
      position: relative;
      transition: transform var(--silk-dur) var(--silk), box-shadow var(--silk-dur) var(--silk);
    }
    .feature-visual:hover { transform: scale(1.015); box-shadow: var(--shadow-lg); }
    .feature-visual-inner {
      width: 85%; display: flex; flex-direction: column; gap: 12px;
    }
    .fv-row { display: flex; gap: 12px; }
    .fv-card {
      flex: 1; background: var(--surface-2); border-radius: var(--radius);
      border: 1px solid var(--border); padding: 16px;
      box-shadow: var(--shadow-sm);
    }
    .fv-card-label { font-size: 0.72rem; color: var(--text-3); font-weight: 500; margin-bottom: 6px; }
    .fv-card-val { font-size: 1.3rem; font-weight: 700; color: var(--text-1); letter-spacing: -0.03em; }
    .fv-card-bar {
      height: 4px; border-radius: 2px; margin-top: 10px;
      background: var(--bg); overflow: hidden;
    }
    .fv-card-bar-fill { height: 100%; border-radius: 2px; background: var(--accent); }
    .fv-wide { flex: 2; }
    .fv-list { display: flex; flex-direction: column; gap: 8px; }
    .fv-list-item {
      display: flex; align-items: center; justify-content: space-between;
      padding: 8px 12px; background: var(--bg); border-radius: 8px;
      font-size: 0.8rem;
    }
    .fv-list-name { color: var(--text-2); font-weight: 500; }
    .fv-pill {
      font-size: 0.7rem; font-weight: 600; padding: 3px 10px; border-radius: 100px;
    }
    .fv-pill.green { background: rgba(26,122,110,0.12); color: var(--accent); }
    .fv-pill.blue  { background: rgba(42,157,143,0.12); color: var(--accent-mid); }
    .fv-pill.dim   { background: var(--border); color: var(--text-3); }

    /* ══════════════════════════════════════════
       5. MOBILE CAROUSEL
    ══════════════════════════════════════════ */
    .carousel-section {
      display: block;
      padding: 120px 0; background: var(--surface);
      border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
      overflow: hidden;
    }
    .carousel-header { text-align: center; margin-bottom: 0; }
    .carousel-header .section-sub { margin: 16px auto 0; text-align: center; }

    .carousel-stage {
      position: relative;
      height: clamp(480px, 52vw, 780px);
      perspective: clamp(900px, 120vw, 1800px);
      perspective-origin: center center;
      display: flex; align-items: center; justify-content: center;
    }
    .carousel-track {
      position: relative; width: 100%; height: 100%;
      transform-style: preserve-3d;
      display: flex; align-items: center; justify-content: center;
    }

    /* Single source of truth: --pw = phone width, drives all offsets */
    :root {
      --pw: clamp(180px, 14vw, 300px);
      --gap1: clamp(200px, 19vw, 380px);
      --gap2: clamp(360px, 34vw, 660px);
      --gap-hide: clamp(500px, 48vw, 900px);
    }

    .phone-card {
      position: absolute;
      transition: transform 0.6s var(--silk), opacity 0.6s var(--silk);
      cursor: pointer;
    }
    .phone-shell {
      background: #C8D4D2;
      border-radius: 32px;
      padding: 5px;
      border: none;
      box-shadow:
        0 0 0 1px rgba(150,175,170,0.5),
        0 24px 56px rgba(13,30,28,0.18),
        inset 0 1px 0 rgba(255,255,255,0.6);
      position: relative;
      transition: box-shadow 0.6s var(--silk);
    }
    .phone-screen {
      background: var(--bg);
      border-radius: 28px;
      overflow: hidden;
      aspect-ratio: 9/19.5;
    }
    .phone-screen-inner {
      width: 100%; height: 100%;
      display: flex; flex-direction: column;
    }
    .ps-topbar {
      padding: 10px 12px 6px;
      display: flex; justify-content: space-between; align-items: center;
    }
    .ps-topbar-label { font-size: 8px; font-weight: 700; color: var(--text-1); letter-spacing: -0.02em; }
    .ps-dot { width: 20px; height: 20px; border-radius: 50%; background: var(--accent); }
    .ps-hero-block { padding: 6px 12px 10px; }
    .ps-hero-title { font-size: 9px; font-weight: 700; color: var(--text-1); line-height: 1.3; margin-bottom: 4px; }
    .ps-hero-sub { font-size: 6.5px; color: var(--text-3); line-height: 1.4; }
    .ps-btn {
      display: inline-block; margin-top: 6px;
      background: var(--accent); color: #fff;
      font-size: 6px; font-weight: 700; padding: 4px 10px; border-radius: 100px;
    }
    .ps-cards { padding: 6px 8px; display: flex; flex-direction: column; gap: 5px; }
    .ps-card {
      background: var(--surface-2); border-radius: 8px; padding: 8px 10px;
      border: 1px solid var(--border);
      display: flex; align-items: center; gap: 8px;
    }
    .ps-card-icon {
      width: 22px; height: 22px; border-radius: 6px;
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      flex-shrink: 0;
    }
    .ps-card-text { flex: 1; }
    .ps-card-title { height: 5px; background: var(--border); border-radius: 2px; width: 60%; margin-bottom: 4px; }
    .ps-card-sub { height: 4px; background: var(--bg-alt); border-radius: 2px; width: 80%; }
    .ps-card-val { font-size: 8px; font-weight: 700; color: var(--accent); }
    .ps-nav {
      margin-top: auto; padding: 6px 8px;
      display: flex; justify-content: space-around;
      border-top: 1px solid var(--border); background: var(--surface-2);
    }
    .ps-nav-item { display: flex; flex-direction: column; align-items: center; gap: 2px; }
    .ps-nav-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--bg-alt); }
    .ps-nav-dot.active { background: var(--accent); }
    .ps-nav-label { font-size: 4.5px; color: var(--text-3); }
    .ps-nav-label.active { color: var(--accent); }

    /* Card positions — z-index only, transforms set entirely by JS */
    .phone-card[data-pos="center"]       { z-index: 10; }
    .phone-card[data-pos="left1"],
    .phone-card[data-pos="right1"]       { z-index: 8; }
    .phone-card[data-pos="left2"],
    .phone-card[data-pos="right2"]       { z-index: 6; }
    .phone-card[data-pos="hidden-left"],
    .phone-card[data-pos="hidden-right"] { z-index: 4; }

    /* Reflection floor line */
      position: absolute; bottom: 60px; left: 0; right: 0;
      height: 1px; background: linear-gradient(90deg, transparent, var(--border), transparent);
    }

    /* Controls */
    .carousel-controls {
      display: flex; align-items: center; justify-content: center; gap: 24px;
      width: 100%; margin-top: 48px;
    }
    .carousel-btn {
      width: 44px; height: 44px; border-radius: 50%;
      border: 1.5px solid var(--accent-border);
      background: var(--surface-2);
      display: flex; align-items: center; justify-content: center;
      color: var(--accent); cursor: pointer;
      transition: all 0.4s var(--silk);
    }
    .carousel-btn:hover {
      background: var(--accent); color: #fff;
      border-color: var(--accent);
      transform: scale(1.05);
    }
    .carousel-dots { display: flex; gap: 8px; align-items: center; }
    .carousel-dot {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--accent-border); cursor: pointer;
      transition: all 0.4s var(--silk);
    }
    .carousel-dot.active {
      background: var(--accent); width: 24px; border-radius: 4px;
    }

    /* Zoom control */
    .carousel-zoom {
      display: flex; align-items: center; justify-content: center;
      gap: 8px; padding: 30px 0 0;
    }
    .zoom-btn {
      width: 32px; height: 32px; border-radius: 50%;
      border: 1.5px solid var(--accent-border);
      background: var(--surface-2);
      display: flex; align-items: center; justify-content: center;
      color: var(--accent); cursor: pointer; font-size: 16px; line-height: 1;
      transition: all 0.35s var(--silk);
      user-select: none;
    }
    .zoom-btn:hover:not(:disabled) {
      background: var(--accent); color: #fff; border-color: var(--accent);
    }
    .zoom-btn:disabled { opacity: 0.28; cursor: not-allowed; }
    .zoom-pips { display: flex; gap: 5px; align-items: center; }
    .zoom-pip {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--accent-border);
      transition: background 0.3s var(--silk), transform 0.3s var(--silk);
      cursor: pointer;
    }
    .zoom-pip.active { background: var(--accent); transform: scale(1.4); }
    .zoom-label {
      font-size: 0.72rem; font-weight: 500; color: var(--text-3);
      letter-spacing: 0.06em; text-transform: uppercase; width: 36px; text-align: center;
    }

    /* ══════════════════════════════════════════
       6. STATS
    ══════════════════════════════════════════ */
    .stats-section { padding: 80px 0; border-top: 1px solid var(--border); }
    .stats-grid {
      display: grid; grid-template-columns: repeat(4, 1fr);
    }
    .stat-card {
      padding: 40px 36px;
      border-right: 1px solid var(--border);
      transition: background var(--silk-dur) var(--silk);
    }
    .stat-card:last-child { border-right: none; }
    .stat-card:hover { background: var(--surface-2); }
    .stat-rule {
      width: 32px; height: 2px; background: var(--accent);
      border-radius: 2px; margin-bottom: 24px;
      transition: width 0.5s var(--silk);
    }
    .stat-card:hover .stat-rule { width: 56px; }
    .stat-value {
      font-size: clamp(2.4rem, 3.5vw, 3.6rem);
      font-weight: 700; letter-spacing: -0.05em;
      color: var(--text-1); line-height: 1; margin-bottom: 12px;
      display: flex; align-items: baseline; gap: 2px;
    }
    .stat-suffix { font-size: 55%; color: var(--accent); font-weight: 600; }
    .stat-label {
      font-size: 0.9rem; font-weight: 600;
      color: var(--text-1); margin-bottom: 6px;
    }
    .stat-sublabel { font-size: 0.78rem; color: var(--text-3); line-height: 1.5; }

    /* ══════════════════════════════════════════
       7. PRICING
    ══════════════════════════════════════════ */
    .pricing-section { padding: 100px 0; background: var(--surface); border-top: 1px solid var(--border); }
    .pricing-header { text-align: center; margin-bottom: 48px; }
    .pricing-header .section-sub { margin: 16px auto 0; text-align: center; }

    .pricing-toggle {
      display: flex; align-items: center; justify-content: center; gap: 14px;
      margin-bottom: 56px;
    }
    .toggle-label { font-size: 0.9rem; font-weight: 500; color: var(--text-2); }
    .toggle-label.active { color: var(--accent); font-weight: 600; }
    .toggle-switch {
      width: 52px; height: 28px; border-radius: 100px;
      background: var(--accent); cursor: pointer; position: relative;
      transition: background 0.4s var(--silk);
    }
    .toggle-switch::after {
      content: ''; position: absolute; top: 3px; left: 3px;
      width: 22px; height: 22px; border-radius: 50%; background: #fff;
      transition: transform 0.4s var(--silk);
    }
    .toggle-switch.annual::after { transform: translateX(24px); }
    .toggle-badge {
      font-size: 0.7rem; font-weight: 700; color: var(--accent);
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      padding: 3px 10px; border-radius: 100px;
    }

    .pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
    .pricing-card {
      background: var(--surface-2); border-radius: var(--radius-lg);
      border: 1px solid var(--border); padding: 36px 32px;
      box-shadow: var(--shadow-sm);
      transition: transform var(--silk-dur) var(--silk), box-shadow var(--silk-dur) var(--silk);
      position: relative;
    }
    .pricing-card:hover { transform: scale(1.02); box-shadow: var(--shadow-md); }
    .pricing-card.featured {
      border-color: var(--accent); background: var(--text-1);
      box-shadow: 0 20px 60px rgba(26,122,110,0.25);
    }
    .pricing-card.featured:hover { transform: scale(1.025); box-shadow: 0 28px 80px rgba(26,122,110,0.35); }
    .pricing-badge {
      position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
      background: var(--accent); color: #fff;
      font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
      padding: 5px 16px; border-radius: 100px;
      white-space: nowrap;
    }
    .pricing-tier { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-3); margin-bottom: 12px; }
    .pricing-card.featured .pricing-tier { color: rgba(255,255,255,0.5); }
    .pricing-price { display: flex; align-items: baseline; gap: 2px; margin-bottom: 4px; }
    .price-annual-note {
      font-size: 0.78rem; color: var(--text-3); margin-bottom: 16px;
      min-height: 1.2em;
      transition: opacity 0.4s var(--silk);
    }
    .pricing-card.featured .price-annual-note { color: rgba(255,255,255,0.4); }
    .price-currency { font-size: 1.4rem; font-weight: 600; color: var(--text-2); margin-top: 6px; }
    .price-amount { font-size: 3.2rem; font-weight: 700; letter-spacing: -0.04em; color: var(--text-1); line-height: 1; }
    .pricing-card.featured .price-currency,
    .pricing-card.featured .price-amount { color: #fff; }
    .price-period { font-size: 0.875rem; color: var(--text-3); }
    .pricing-card.featured .price-period { color: rgba(255,255,255,0.5); }
    .pricing-desc { font-size: 0.875rem; color: var(--text-2); line-height: 1.6; margin-bottom: 28px; }
    .pricing-card.featured .pricing-desc { color: rgba(255,255,255,0.65); }
    .pricing-divider { height: 1px; background: var(--border); margin-bottom: 24px; }
    .pricing-card.featured .pricing-divider { background: rgba(255,255,255,0.1); }
    .pricing-features { display: flex; flex-direction: column; gap: 10px; margin-bottom: 32px; }
    .pricing-feature {
      display: flex; align-items: flex-start; gap: 10px;
      font-size: 0.875rem; color: var(--text-2);
    }
    .pricing-card.featured .pricing-feature { color: rgba(255,255,255,0.8); }
    .pricing-check {
      width: 18px; height: 18px; border-radius: 50%;
      background: var(--accent-ghost); border: 1px solid var(--accent-border);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; color: var(--accent); font-size: 10px; font-weight: 700;
      margin-top: 1px;
    }
    .pricing-card.featured .pricing-check {
      background: rgba(91,191,181,0.2); border-color: rgba(91,191,181,0.4); color: var(--accent-light);
    }
    .pricing-cta {
      display: block; text-align: center; font-size: 0.9rem; font-weight: 600;
      padding: 13px; border-radius: 100px;
      border: 1.5px solid var(--accent-border); color: var(--accent);
      transition: all 0.4s var(--silk);
    }
    .pricing-cta:hover { background: var(--accent-ghost); }
    .pricing-card.featured .pricing-cta {
      background: var(--accent); border-color: var(--accent); color: #fff;
      box-shadow: 0 6px 24px rgba(26,122,110,0.35);
    }
    .pricing-card.featured .pricing-cta:hover { background: var(--accent-mid); }

    /* ══════════════════════════════════════════
       8. TESTIMONIALS
    ══════════════════════════════════════════ */
    .testimonials-section { padding: 100px 0; }
    .testimonials-header { text-align: center; margin-bottom: 64px; }
    .testimonials-header .section-sub { margin: 16px auto 0; text-align: center; }
    .testimonials-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      grid-template-rows: auto auto;
      gap: 24px;
    }
    .testimonial-card {
      background: var(--surface-2); border-radius: var(--radius-lg);
      border: 1px solid var(--border); padding: 32px;
      box-shadow: var(--shadow-sm);
      transition: transform var(--silk-dur) var(--silk), box-shadow var(--silk-dur) var(--silk);
    }
    .testimonial-card:hover { transform: scale(1.015); box-shadow: var(--shadow-md); }
    .testimonial-card.tall { grid-row: span 2; }
    .testimonial-stars { display: flex; gap: 3px; margin-bottom: 16px; }
    .testimonial-stars span { color: var(--accent); font-size: 14px; }
    .testimonial-quote {
      font-size: 0.9375rem; line-height: 1.7; color: var(--text-2);
      margin-bottom: 24px; font-style: italic;
    }
    .testimonial-card.tall .testimonial-quote { font-size: 1.0625rem; }
    .testimonial-author { display: flex; align-items: center; gap: 12px; }
    .author-avatar {
      width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
      border: 2px solid var(--accent-border);
      display: flex; align-items: center; justify-content: center;
      font-weight: 700; font-size: 0.875rem; color: var(--accent);
      background: var(--accent-ghost);
    }
    .author-name { font-size: 0.875rem; font-weight: 600; color: var(--text-1); }
    .author-role { font-size: 0.75rem; color: var(--text-3); margin-top: 1px; }

    /* ══════════════════════════════════════════
       9. INTEGRATIONS
    ══════════════════════════════════════════ */
    .integrations-section {
      padding: 100px 0; background: var(--surface);
      border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    }
    .integrations-header { text-align: center; margin-bottom: 56px; }
    .integrations-header .section-sub { margin: 16px auto 0; text-align: center; }
    .integrations-grid {
      display: flex; flex-wrap: wrap; gap: 12px;
      justify-content: center; max-width: 860px; margin: 0 auto;
    }
    .integration-tile {
      background: var(--surface-2); border-radius: 100px;
      border: 1px solid var(--border); padding: 10px 22px;
      box-shadow: var(--shadow-sm);
      transition: transform var(--silk-dur) var(--silk), box-shadow var(--silk-dur) var(--silk),
                  border-color 0.4s, color 0.4s, background 0.4s;
      cursor: default;
    }
    .integration-tile:hover {
      transform: translateY(-2px); box-shadow: var(--shadow-md);
      border-color: var(--accent-border); background: var(--accent-ghost);
    }
    .integration-name {
      font-size: 0.875rem; font-weight: 600; color: var(--text-2);
      white-space: nowrap; letter-spacing: -0.01em;
    }
    .integration-tile:hover .integration-name { color: var(--accent); }

    /* ══════════════════════════════════════════
       10. FAQ
    ══════════════════════════════════════════ */
    .faq-section { padding: 100px 0; }
    .faq-inner { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; }
    .faq-sidebar { position: sticky; top: 100px; }
    .faq-sidebar .section-sub { margin-top: 16px; margin-bottom: 32px; }
    .faq-toggle-all {
      font-size: 0.875rem; font-weight: 600; color: var(--accent);
      display: flex; align-items: center; gap: 6px;
      transition: opacity 0.3s;
    }
    .faq-toggle-all:hover { opacity: 0.75; }

    .faq-list { display: flex; flex-direction: column; gap: 0; }
    .faq-item {
      border-bottom: 1px solid var(--border);
    }
    .faq-item:first-child { border-top: 1px solid var(--border); }
    .faq-question {
      display: flex; justify-content: space-between; align-items: center;
      padding: 22px 0; cursor: pointer; gap: 16px;
      font-size: 0.9375rem; font-weight: 600; color: var(--text-1);
      transition: color 0.3s;
    }
    .faq-question:hover { color: var(--accent); }
    .faq-icon {
      width: 28px; height: 28px; border-radius: 50%;
      border: 1.5px solid var(--accent-border); flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      color: var(--accent); font-size: 16px; font-weight: 300;
      transition: transform 0.5s var(--silk), background 0.4s, color 0.4s;
    }
    .faq-item.open .faq-icon { transform: rotate(45deg); background: var(--accent); color: #fff; border-color: var(--accent); }
    .faq-answer {
      display: grid; grid-template-rows: 0fr;
      transition: grid-template-rows 0.5s var(--silk);
    }
    .faq-item.open .faq-answer { grid-template-rows: 1fr; }
    .faq-answer-inner {
      overflow: hidden;
      font-size: 0.9rem; line-height: 1.75; color: var(--text-2);
      padding-bottom: 0;
      transition: padding-bottom 0.5s var(--silk);
    }
    .faq-item.open .faq-answer-inner { padding-bottom: 20px; }

    /* ══════════════════════════════════════════
       11. CTA BANNER
    ══════════════════════════════════════════ */
    .cta-section { padding: 100px 0; }
    .cta-inner {
      background: var(--text-1);
      border-radius: var(--radius-lg);
      padding: 80px;
      display: flex; align-items: center; justify-content: space-between; gap: 48px;
      position: relative; overflow: hidden;
    }
    .cta-inner::before {
      content: '';
      position: absolute; top: -40%; right: -5%;
      width: 500px; height: 500px;
      background: radial-gradient(ellipse at center, rgba(91,191,181,0.15) 0%, transparent 70%);
      border-radius: 50%; pointer-events: none;
    }
    .cta-content { position: relative; z-index: 1; max-width: 560px; }
    .cta-label {
      display: inline-flex; align-items: center; gap: 8px;
      font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
      text-transform: uppercase; color: var(--accent-light);
      border: 1px solid rgba(91,191,181,0.3);
      padding: 6px 14px; border-radius: 100px; margin-bottom: 20px;
    }
    .cta-title {
      font-size: clamp(2rem, 4vw, 3rem); font-weight: 700;
      letter-spacing: -0.03em; line-height: 1.15; color: #fff; margin-bottom: 16px;
    }
    .cta-title em { font-style: italic; font-family: 'Playfair Display', serif; color: var(--accent-light); }
    .cta-sub { font-size: 1rem; line-height: 1.7; color: rgba(255,255,255,0.6); }
    .cta-actions { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 14px; flex-shrink: 0; }
    .btn-cta-primary {
      display: flex; align-items: center; gap: 10px;
      font-size: 0.9375rem; font-weight: 600; color: #fff;
      background: var(--accent); padding: 16px 36px; border-radius: 100px;
      white-space: nowrap;
      transition: background var(--silk-dur) var(--silk), transform var(--silk-dur) var(--silk);
      box-shadow: 0 8px 32px rgba(26,122,110,0.40);
    }
    .btn-cta-primary:hover { background: var(--accent-mid); transform: scale(1.02); }
    .btn-cta-ghost {
      display: flex; align-items: center; justify-content: center; gap: 8px;
      font-size: 0.875rem; font-weight: 500; color: rgba(255,255,255,0.6);
      padding: 14px; border-radius: 100px; border: 1px solid rgba(255,255,255,0.1);
      white-space: nowrap;
      transition: color 0.3s, border-color 0.3s;
    }
    .btn-cta-ghost:hover { color: #fff; border-color: rgba(255,255,255,0.3); }

    /* ══════════════════════════════════════════
       12. FOOTER
    ══════════════════════════════════════════ */
    .footer {
      background: var(--text-1); padding: 80px 0 40px;
      border-top: 1px solid rgba(255,255,255,0.06);
    }
    .footer-grid {
      display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1.2fr;
      gap: 48px; margin-bottom: 64px;
    }
    .footer-brand .nav-logo { color: #fff; font-size: 1.3rem; margin-bottom: 20px; display: inline-flex; }
    .footer-logo-mark {
      width: 184px;
      max-width: 100%;
      height: auto;
      display: block;
      object-fit: contain;
      background: #ffffff;
      border-radius: 24px;
      padding: 18px 22px;
      box-shadow:
        0 20px 44px rgba(0,0,0,0.22),
        inset 0 0 0 1px rgba(10, 44, 67, 0.08);
    }
    .footer-brand-desc { font-size: 0.875rem; line-height: 1.7; color: rgba(255,255,255,0.62); max-width: 320px; }
    .footer-contact-meta {
      display: grid;
      gap: 8px;
      margin: 16px 0 18px;
      max-width: 300px;
      color: rgba(255,255,255,0.62);
      font-size: 0.82rem;
      line-height: 1.65;
    }
    .footer-contact-meta p { margin: 0; }
    .footer-contact-meta a {
      color: rgba(255,255,255,0.82);
      text-decoration: none;
    }
    .footer-contact-meta a:hover {
      color: #ffffff;
    }
    .footer-socials { display: flex; gap: 10px; margin-top: 24px; }
    .social-btn {
      width: 36px; height: 36px; border-radius: 10px;
      border: 1px solid rgba(255,255,255,0.1);
      display: flex; align-items: center; justify-content: center;
      color: rgba(255,255,255,0.4); font-size: 14px; font-weight: 700;
      transition: all 0.4s var(--silk);
    }
    .social-btn:hover { border-color: var(--accent-light); color: var(--accent-light); }
    .footer-col-label {
      font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em;
      text-transform: uppercase; color: rgba(255,255,255,0.25);
      margin-bottom: 20px;
    }
    .footer-links { display: flex; flex-direction: column; gap: 12px; }
    .footer-links a {
      font-size: 0.875rem; color: rgba(255,255,255,0.5);
      transition: color 0.3s;
    }
    .footer-links a:hover { color: var(--accent-light); }
    .footer-newsletter-form {
      display: grid;
      gap: 12px;
      max-width: 280px;
      margin-top: 14px;
    }
    .footer-captcha-field {
      display: grid;
      gap: 8px;
      margin: 0;
      color: rgba(255,255,255,0.86);
      font-size: 0.9rem;
    }
    .footer-captcha-field span {
      font-weight: 700;
      color: #ffffff;
    }
    .footer-captcha-field small {
      color: rgba(255,255,255,0.72);
      line-height: 1.55;
    }
    .footer-captcha-field input {
      width: 100%;
      border: 1px solid rgba(255,255,255,0.14);
      border-radius: 14px;
      background: rgba(255,255,255,0.04);
      color: #fff;
      padding: 13px 16px;
      font-size: 0.92rem;
      outline: none;
      transition: border-color 0.25s ease, background 0.25s ease;
    }
    .footer-captcha-field input::placeholder {
      color: rgba(255,255,255,0.42);
    }
    .footer-captcha-field input:focus {
      border-color: rgba(118,230,191,0.7);
      background: rgba(255,255,255,0.07);
    }
    .footer-newsletter-input {
      width: 100%;
      border: 1px solid rgba(255,255,255,0.14);
      border-radius: 14px;
      background: rgba(255,255,255,0.04);
      color: #fff;
      padding: 13px 16px;
      font-size: 0.92rem;
      outline: none;
      transition: border-color 0.25s ease, background 0.25s ease;
    }
    .footer-newsletter-input::placeholder { color: rgba(255,255,255,0.36); }
    .footer-newsletter-input:focus {
      border-color: rgba(118,230,191,0.7);
      background: rgba(255,255,255,0.07);
    }
    .footer-newsletter-btn {
      width: fit-content;
      min-width: 140px;
      justify-content: center;
    }
    .footer-newsletter-success {
      margin: 0;
      color: #9cf3d6;
      font-size: 0.84rem;
      line-height: 1.6;
    }
    .footer-newsletter-error {
      color: #ffb3b3;
      font-size: 0.8rem;
      line-height: 1.5;
    }
    .footer-bottom {
      border-top: 1px solid rgba(255,255,255,0.06);
      padding-top: 32px;
      display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
    }
    .footer-copy { font-size: 0.8125rem; color: rgba(255,255,255,0.3); }
    .footer-copy a { color: rgba(255,255,255,0.45); transition: color 0.3s; }
    .footer-copy a:hover { color: var(--accent-light); }
    .footer-legal { display: flex; gap: 24px; }
    .footer-legal a { font-size: 0.8125rem; color: rgba(255,255,255,0.3); transition: color 0.3s; }
    .footer-legal a:hover { color: rgba(255,255,255,0.6); }

    /* ══════════════════════════════════════════
       RESPONSIVE
    ══════════════════════════════════════════ */
    @media (max-width: 1024px) {
      .nav-shell { padding: 0 20px; }
      .nav-inner {
        grid-template-columns: auto 1fr auto;
        gap: 12px;
        padding: 12px 14px 12px 16px;
      }
      .nav-brand-wrap { gap: 10px; }
      .nav-status { display: none; }
      .nav-locale-switcher { padding: 6px; gap: 6px; }
      .locale-flag-link { min-width: 40px; min-height: 40px; padding: 0 8px; }
      .nav-links { gap: 4px; }
      .nav-links a { padding: 0 12px; font-size: 0.82rem; }
      .nav-locale { display: none; }
      .hero-inner { grid-template-columns: 1fr; gap: 56px; }
      .hero-visual { max-width: 520px; margin: 0 auto; }
      .feature-row { grid-template-columns: 1fr; gap: 40px; }
      .feature-row.reverse { direction: ltr; }
      .stats-grid { grid-template-columns: repeat(2, 1fr); }
      .stat-card { border-right: none; border-bottom: 1px solid var(--border); }
      .stat-card:last-child { border-bottom: none; }
      .pricing-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }

      .footer-grid { grid-template-columns: 1fr 1fr; }
      .cta-inner { flex-direction: column; padding: 56px 40px; }
      .faq-inner { grid-template-columns: 1fr; }
      .faq-sidebar { position: static; }
    }
    @media (max-width: 768px) {
      .carousel-zoom { padding: 30px 0 0; }
      .container { padding: 0 20px; }
      .nav { padding: 14px 0; }
      .nav-shell { padding: 0 14px; }
      .nav-inner {
        grid-template-columns: 1fr auto;
        padding: 12px 12px 12px 14px;
        border-radius: 24px;
      }
      .nav-locale-switcher { display: none; }
      .nav-logo-mark { width: 50px; height: 50px; }
      .nav-logo-copy strong { font-size: 0.92rem; }
      .nav-logo-copy span { font-size: 0.60rem; }
      .nav-links, .nav-cta { display: none; }
      .nav-hamburger { display: flex; }
      .mobile-menu { padding: 82px 14px 20px; }
      .mobile-menu-panel { padding: 18px; border-radius: 24px; }
      .testimonials-grid { grid-template-columns: 1fr; }
      .testimonial-card.tall { grid-row: auto; }
      .footer-grid { grid-template-columns: 1fr; }
      .cta-inner { padding: 40px 24px; }
      .pricing-grid { max-width: 100%; }
      .stats-grid { grid-template-columns: repeat(2, 1fr); }
      .hero-float-badge-2 { right: 0; }
      /* Carousel mobile */
      .carousel-stage { height: 400px; }
      :root {
        --pw: 150px;
        --gap1: 168px;
        --gap2: 300px;
        --gap-hide: 430px;
      }
      .phone-card[data-pos="left2"],
      .phone-card[data-pos="right2"] { opacity: 0.35; }
    }
    @media (max-width: 480px) {
      .nav-logo-copy span { letter-spacing: 0.12em; }
      .nav-logo-copy strong { max-width: 150px; }
      .mobile-menu-top { flex-direction: column; align-items: stretch; }
      .mobile-menu-locale { align-items: flex-start; }
      .mobile-locale-switcher { flex-direction: column; }
      .mobile-menu-actions { flex-direction: column; }
      .stats-grid { grid-template-columns: 1fr 1fr; }
      .hero-trust { gap: 12px; }
      .trust-divider { display: none; }
    }

    /* HEADER REDESIGN */
    html { scroll-padding-top: 180px; }

    body {
      padding-top: 152px;
      background:
        radial-gradient(circle at top left, rgba(13, 103, 143, 0.16), transparent 28%),
        radial-gradient(circle at top right, rgba(232, 181, 64, 0.18), transparent 24%),
        linear-gradient(180deg, #eff8fb 0%, #edf6f5 32%, #e7f2f1 100%);
    }

    .site-topbar {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 1100;
      background: linear-gradient(90deg, #08253a 0%, #0c4266 54%, #0f5573 100%);
      color: rgba(255, 255, 255, 0.88);
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
      box-shadow: 0 14px 28px rgba(6, 24, 38, 0.16);
    }

    .site-topbar::after {
      content: '';
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(237, 181, 63, 0.72), transparent);
    }

    .site-topbar-inner {
      min-height: 48px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .site-topbar-left,
    .site-topbar-right {
      display: flex;
      align-items: center;
      gap: 14px;
      flex-wrap: wrap;
    }

    .topbar-chip {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(237, 181, 63, 0.12);
      color: #ffe1a0;
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      border: 1px solid rgba(255, 218, 138, 0.18);
    }

    .topbar-chip::before {
      content: '';
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: #f6c562;
      box-shadow: 0 0 0 6px rgba(246, 197, 98, 0.12);
    }

    .topbar-link {
      color: rgba(255, 255, 255, 0.72);
      font-size: 0.85rem;
      transition: color 0.3s ease, transform 0.3s ease;
    }

    .topbar-location {
      color: rgba(255, 255, 255, 0.74);
      font-size: 0.82rem;
      font-weight: 600;
      letter-spacing: normal;
      text-transform: none;
    }

    .topbar-link:hover {
      color: #ffffff;
      transform: translateY(-1px);
    }

    .site-topbar-right span {
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(230, 242, 250, 0.84);
    }

    .nav {
      top: 48px;
      padding: 16px 0;
      overflow: visible;
    }

    .nav-shell {
      max-width: 1268px;
      overflow: visible;
    }

    .nav-inner {
      display: grid;
      grid-template-columns: max-content minmax(0, 1fr) max-content;
      align-items: center;
      column-gap: 18px;
      background: linear-gradient(135deg, rgba(7, 64, 97, 0.92), rgba(12, 89, 125, 0.9));
      border: 1px solid rgba(255, 255, 255, 0.14);
      box-shadow:
        0 24px 56px rgba(6, 33, 52, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.14);
      overflow: visible;
    }

    .nav-inner::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 12% 16%, rgba(255, 255, 255, 0.12), transparent 18%),
        linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.04) 46%, transparent 58%);
      pointer-events: none;
    }

    .nav.scrolled .nav-inner {
      background: linear-gradient(135deg, rgba(7, 64, 97, 0.96), rgba(11, 80, 112, 0.94));
      box-shadow:
        0 26px 58px rgba(6, 33, 52, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.14);
    }

    .nav-brand-wrap,
    .nav-links,
    .nav-cta,
    .nav-hamburger {
      position: relative;
      z-index: 1;
    }

    .nav-logo-mark {
      width: 184px;
      height: 108px;
      object-fit: contain;
      border-radius: 22px;
      background: rgba(255, 255, 255, 0.98);
      padding: 14px 18px;
      box-shadow:
        0 22px 44px rgba(5, 27, 43, 0.18),
        0 0 0 1px rgba(255, 255, 255, 0.38);
      transform: translateY(22px);
      transform-origin: top left;
      transition:
        width 0.45s var(--silk),
        height 0.45s var(--silk),
        padding 0.45s var(--silk),
        border-radius 0.45s var(--silk),
        transform 0.45s var(--silk),
        box-shadow 0.45s var(--silk),
        background 0.45s var(--silk);
    }

    .nav.scrolled .nav-logo-mark {
      width: 118px;
      height: 72px;
      padding: 10px 12px;
      border-radius: 18px;
      transform: translateY(0);
      box-shadow:
        0 14px 28px rgba(5, 27, 43, 0.18),
        0 0 0 1px rgba(255, 255, 255, 0.24);
    }

    .nav-logo-copy span {
      color: rgba(214, 232, 243, 0.72);
      letter-spacing: 0.16em;
    }

    .nav-logo-copy strong {
      color: #ffffff;
      font-size: 1rem;
    }

    .nav-status {
      color: #d8ecf5;
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.14);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    .nav-status-dot {
      background: #f5bf4f;
      box-shadow: 0 0 0 7px rgba(245, 191, 79, 0.16);
    }

    .nav-links {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      width: max-content;
      max-width: 100%;
      justify-self: center;
      padding: 6px 8px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.32);
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14);
    }

    .nav-links a {
      color: rgba(235, 246, 252, 0.78);
      padding: 0 16px;
      line-height: 42px;
      border-radius: 999px;
      font-size: 0.9rem;
      font-weight: 600;
      transition:
        background 0.35s var(--silk),
        color 0.35s var(--silk),
        transform 0.35s var(--silk);
    }

    .nav-links a:hover {
      color: #ffffff;
      background: rgba(255, 255, 255, 0.1);
      transform: translateY(-1px);
    }

    .nav-cta {
      justify-self: end;
      flex-shrink: 0;
      gap: 10px;
    }

    .nav-locale-switcher {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(255, 255, 255, 0.12);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
    }

    .locale-flag-link {
      color: #d9ebf6;
    }

    .locale-flag-link:hover,
    .locale-flag-link.active {
      color: #0d4265;
    }

    .nav-locale span {
      color: rgba(219, 235, 244, 0.66);
    }

    .nav-locale strong {
      color: #ffffff;
    }

    .btn-ghost,
    .btn-primary {
      border-radius: 999px;
      font-weight: 700;
    }

    .btn-ghost {
      color: #ffffff;
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.14);
    }

    .btn-ghost:hover {
      background: rgba(255, 255, 255, 0.16);
      border-color: rgba(255, 255, 255, 0.2);
    }

    .btn-primary {
      color: #0a2f49;
      background: linear-gradient(135deg, #f6c356 0%, #ffd46f 100%);
      box-shadow: 0 14px 28px rgba(237, 181, 63, 0.18);
    }

    .btn-primary:hover {
      background: linear-gradient(135deg, #ffd46f 0%, #f7bc45 100%);
      transform: translateY(-1px);
    }

    .hero {
      position: relative;
      padding: 0 0 92px;
      overflow: hidden;
      background:
        linear-gradient(180deg, rgba(248, 252, 253, 0.98) 0%, rgba(236, 246, 249, 0.94) 100%);
    }

    .hero::before,
    .hero::after {
      content: '';
      position: absolute;
      border-radius: 50%;
      filter: blur(24px);
      pointer-events: none;
    }

    .hero::before {
      top: -40px;
      left: -120px;
      width: 340px;
      height: 340px;
      background: rgba(16, 105, 142, 0.1);
    }

    .hero::after {
      right: -60px;
      top: 90px;
      width: 320px;
      height: 320px;
      background: rgba(237, 181, 63, 0.11);
    }

    .hero-frame {
      position: relative;
      display: grid;
      grid-template-columns: minmax(0, 1.06fr) minmax(420px, 0.94fr);
      gap: 20px;
      align-items: stretch;
      padding: 34px;
      border-radius: 32px;
      overflow: hidden;
      background: linear-gradient(160deg, rgba(255, 255, 255, 0.96), rgba(236, 245, 250, 0.92));
      border: 1px solid rgba(208, 226, 236, 0.78);
      box-shadow:
        0 24px 60px rgba(8, 39, 60, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.88);
    }

    .hero-frame-wide {
      width: 100%;
      max-width: none;
      min-height: 620px;
      grid-template-columns: minmax(0, 1.02fr) minmax(450px, 560px);
      gap: 14px;
      padding: 48px clamp(28px, 5vw, 72px);
      border-radius: 0;
      border-left: none;
      border-right: none;
      border-top: none;
      background:
        radial-gradient(circle at 10% 18%, rgba(237, 181, 63, 0.18), transparent 24%),
        radial-gradient(circle at 48% 52%, rgba(126, 191, 220, 0.16), transparent 30%),
        radial-gradient(circle at 82% 78%, rgba(28, 142, 156, 0.14), transparent 26%),
        linear-gradient(115deg, rgba(255, 255, 255, 0.98) 0%, rgba(239, 246, 250, 0.96) 52%, rgba(227, 239, 246, 0.94) 100%);
      box-shadow:
        0 18px 46px rgba(8, 39, 60, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
    }

    .hero-frame::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 86% 18%, rgba(255, 255, 255, 0.34), transparent 16%),
        radial-gradient(circle at 22% 82%, rgba(16, 105, 142, 0.08), transparent 18%),
        linear-gradient(100deg, transparent 30%, rgba(255, 255, 255, 0.18) 50%, transparent 68%);
      pointer-events: none;
    }

    .hero-copy,
    .hero-visual {
      position: relative;
      z-index: 1;
    }

    .hero-copy {
      max-width: 840px;
      min-height: 0;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding-right: 0;
    }

    .hero-slider {
      position: relative;
      display: grid;
      align-items: start;
      min-height: 400px;
    }

    .header-slide,
    .hero-slide-panel {
      grid-area: 1 / 1;
      pointer-events: none;
      opacity: 0;
    }

    .header-slide {
      transform: translateX(28px);
      transition: opacity 0.68s var(--silk), transform 0.8s var(--silk);
    }

    .header-slide > * {
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 0.55s ease, transform 0.7s var(--silk);
    }

    .header-slide.is-active {
      opacity: 1;
      transform: none;
      pointer-events: auto;
    }

    .header-slide.is-active > * {
      opacity: 1;
      transform: none;
    }

    .header-slide.is-active .header-slide-kicker { transition-delay: 0.04s; }
    .header-slide.is-active .header-slide-title { transition-delay: 0.1s; }
    .header-slide.is-active .header-slide-text { transition-delay: 0.16s; }
    .header-slide.is-active .hero-actions { transition-delay: 0.22s; }

    .header-slide-kicker {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      width: fit-content;
      padding: 10px 14px;
      border-radius: 999px;
      background: rgba(237, 181, 63, 0.12);
      color: #a36700;
      font-size: 0.8rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .header-slide-kicker::before {
      content: '';
      width: 9px;
      height: 9px;
      border-radius: 50%;
      background: #f0b23f;
    }

    .header-slide-title {
      max-width: 13.5ch;
      margin-top: 18px;
      font-size: clamp(3rem, 4.6vw, 4.75rem);
      line-height: 0.96;
      letter-spacing: -0.055em;
      color: #0a2034;
      text-wrap: pretty;
    }

    .header-slide-text {
      max-width: 56ch;
      margin-top: 24px;
      font-size: 1.04rem;
      line-height: 1.85;
      color: #47667a;
    }

    .hero-actions {
      margin-top: 28px;
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
    }

    .btn-primary-lg,
    .btn-outline-lg {
      min-height: 56px;
      border-radius: 999px;
      padding: 0 24px;
      font-weight: 700;
    }

    .btn-primary-lg {
      color: #ffffff;
      background: linear-gradient(135deg, #0b557f 0%, #12819c 100%);
      box-shadow: 0 22px 42px rgba(11, 85, 127, 0.18);
    }

    .btn-primary-lg:hover {
      background: linear-gradient(135deg, #0e6594 0%, #1497a9 100%);
      transform: translateY(-2px);
      box-shadow: 0 28px 46px rgba(11, 85, 127, 0.2);
    }

    .btn-outline-lg {
      color: #0d4a73;
      background: rgba(255, 255, 255, 0.8);
      border: 1px solid rgba(10, 89, 128, 0.12);
      box-shadow: 0 16px 34px rgba(8, 39, 60, 0.06);
    }

    .btn-outline-lg:hover {
      background: #ffffff;
      border-color: rgba(10, 89, 128, 0.2);
      transform: translateY(-2px);
    }

    .header-slider-controls {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-top: 28px;
    }

    .header-slider-arrow {
      width: 44px;
      height: 44px;
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.9);
      border: 1px solid rgba(10, 89, 128, 0.08);
      color: #0d4a73;
      box-shadow: 0 10px 20px rgba(8, 39, 60, 0.06);
      transition:
        transform 0.35s var(--silk),
        box-shadow 0.35s var(--silk),
        color 0.35s var(--silk);
    }

    .header-slider-arrow:hover {
      transform: translateY(-1px);
      color: #0a2e48;
      box-shadow: 0 14px 24px rgba(8, 39, 60, 0.1);
    }

    .header-slider-dots {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .header-slider-dot {
      width: 12px;
      height: 12px;
      border-radius: 999px;
      border: none;
      background: rgba(12, 74, 115, 0.18);
      transition:
        width 0.4s var(--silk),
        background 0.4s var(--silk),
        transform 0.4s var(--silk);
    }

    .header-slider-dot.active {
      width: 28px;
      background: linear-gradient(90deg, #efb341 0%, #0f6f85 100%);
      transform: scale(1.02);
    }

    .hero-visual {
      width: 100%;
      min-height: 0;
      display: grid;
      align-content: stretch;
      justify-self: stretch;
      gap: 0;
      padding: 0;
      margin-left: 0;
    }

    .hero-slide-panel {
      display: grid;
      gap: 0;
      align-self: stretch;
      width: 100%;
      transform: translateY(24px) scale(0.985);
      transition: opacity 0.68s var(--silk), transform 0.8s var(--silk);
    }

    .hero-slide-panel > * {
      opacity: 0;
      transform: translateY(18px);
      transition: opacity 0.55s ease, transform 0.7s var(--silk);
    }

    .hero-slide-panel.is-active {
      opacity: 1;
      transform: none;
      pointer-events: auto;
    }

    .hero-slide-panel.is-active > * {
      opacity: 1;
      transform: none;
    }

    .hero-slide-panel.is-active > :first-child { transition-delay: 0.14s; }
    .hero-slide-panel.is-active > :last-child { transition-delay: 0.22s; }

    .hero-panel-card {
      position: relative;
      overflow: hidden;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      width: 100%;
      min-height: 340px;
      height: auto;
      padding: 34px 36px 38px;
      border-radius: 2px;
      color: #ffffff;
      box-shadow: 0 24px 44px rgba(7, 36, 57, 0.14);
      isolation: isolate;
    }

    .hero-panel-copy {
      display: grid;
      gap: 0;
    }

    .hero-panel-card.has-verse {
      justify-content: space-between;
      min-height: 396px;
      height: auto;
      padding-top: 30px;
    }

    .hero-panel-card.has-verse .hero-panel-copy {
      gap: 2px;
    }

    .hero-panel-card::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.16), transparent 42%),
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.14), transparent 28%);
      z-index: 0;
    }

    .hero-panel-card::after {
      content: '';
      position: absolute;
      right: 18px;
      bottom: 18px;
      width: 74px;
      height: 74px;
      border-radius: 50%;
      background:
        radial-gradient(circle at center, rgba(255, 255, 255, 0.12), transparent 58%),
        url("images/logo/imgi_4_LE-TRANSFIGURANT-2.png") center / 32px no-repeat;
      opacity: 0.14;
      z-index: 0;
    }

    .hero-panel-card > * {
      position: relative;
      z-index: 1;
    }

    .hero-panel-primary {
      background:
        linear-gradient(160deg, rgba(9, 60, 91, 0.96), rgba(19, 116, 136, 0.9));
    }

    .hero-panel-secondary {
      background:
        linear-gradient(160deg, rgba(191, 145, 58, 0.96), rgba(37, 108, 125, 0.9));
    }

    .hero-panel-tag {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      width: fit-content;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.12);
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .hero-panel-tag::before {
      content: '';
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: #f8ca6a;
    }

    .hero-panel-card h3 {
      max-width: 11.5ch;
      margin-top: 18px;
      font-size: clamp(2.05rem, 2.8vw, 2.9rem);
      line-height: 1.06;
      letter-spacing: -0.04em;
      overflow-wrap: anywhere;
    }

    .hero-panel-card.has-verse h3 {
      max-width: 12ch;
      margin-top: 14px;
      font-size: clamp(1.7rem, 2.2vw, 2.3rem);
      line-height: 1.02;
    }

    .hero-panel-card p {
      max-width: 29ch;
      margin-top: 16px;
      color: rgba(255, 255, 255, 0.86);
      line-height: 1.72;
      font-size: 0.98rem;
    }

    .hero-panel-card.has-verse .hero-panel-copy > p {
      max-width: 31ch;
      margin-top: 12px;
      font-size: 0.92rem;
      line-height: 1.62;
    }

    .hero-verse-snippet {
      position: relative;
      z-index: 1;
      margin-top: 18px;
      margin-right: 18px;
      padding: 18px 20px 18px 24px;
      border: 1px solid rgba(255, 255, 255, 0.18);
      border-radius: 22px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.07));
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
      backdrop-filter: blur(10px);
      display: grid;
      gap: 12px;
    }

    .hero-verse-snippet::before {
      content: '“';
      position: absolute;
      left: 16px;
      top: 10px;
      font-family: "Playfair Display", serif;
      font-size: 2.6rem;
      line-height: 1;
      color: rgba(255, 255, 255, 0.16);
      pointer-events: none;
    }

    .hero-verse-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding-left: 18px;
    }

    .hero-verse-label {
      display: inline-flex;
      width: fit-content;
      padding: 5px 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.18);
      color: rgba(255, 255, 255, 0.88);
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }

    .hero-verse-version {
      display: inline-flex;
      align-items: center;
      min-height: 30px;
      padding: 4px 10px;
      border-radius: 999px;
      background: rgba(7, 36, 57, 0.22);
      color: rgba(255, 255, 255, 0.82);
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      white-space: nowrap;
    }

    .hero-verse-body {
      display: grid;
      gap: 8px;
      padding-left: 18px;
    }

    .hero-verse-reference {
      display: block;
      color: #fff;
      font-size: 1.12rem;
      line-height: 1.2;
      letter-spacing: -0.025em;
    }

    .hero-verse-body p {
      max-width: none;
      margin-top: 0;
      font-size: 0.9rem;
      line-height: 1.65;
      color: rgba(255, 255, 255, 0.84);
    }

    .hero-verse-snippet::before {
      content: "\201C";
    }

    @media (max-width: 1024px) {
      body { padding-top: 170px; }
      .site-topbar-inner { padding-top: 6px; padding-bottom: 6px; }
      .nav { top: 60px; }
      .hero-frame {
        grid-template-columns: 1fr;
        gap: 30px;
      }
      .hero-frame-wide {
        min-height: 0;
        padding: 40px 32px;
      }
      .hero-copy,
      .hero-visual {
        min-height: auto;
      }
      .hero-visual {
        max-width: 560px;
        margin: 0 auto;
        width: 100%;
        justify-self: stretch;
        margin-left: 0;
      }
      .hero-panel-card {
        min-height: 320px;
        height: auto;
      }

      .hero-panel-card.has-verse {
        min-height: 400px;
        height: auto;
      }

      .hero-verse-snippet {
        margin-right: 0;
      }
    }

    @media (max-width: 768px) {
      html { scroll-padding-top: 142px; }
      body { padding-top: 136px; }
      .site-topbar-inner {
        min-height: 44px;
      }
      .site-topbar-right {
        display: none;
      }
      .nav {
        top: 44px;
      }
      .nav-inner {
        background: linear-gradient(135deg, rgba(7, 64, 97, 0.96), rgba(10, 83, 117, 0.94));
      }
      .hero {
        padding-bottom: 72px;
      }
      .hero-frame {
        padding: 24px;
        border-radius: 30px;
      }
      .hero-frame-wide {
        padding: 28px 20px 32px;
        border-radius: 0;
      }
      .hero-slider {
        min-height: 0;
      }
      .header-slide-title {
        font-size: clamp(2.5rem, 9vw, 3.8rem);
        max-width: 100%;
      }
      .header-slide-text {
        font-size: 0.98rem;
      }
      .header-slider-controls {
        margin-top: 24px;
      }
      .hero-panel-card {
        min-height: 260px;
        height: auto;
        padding: 26px 22px 28px;
      }
      .hero-panel-card.has-verse {
        min-height: 360px;
        height: auto;
        padding-top: 24px;
      }
      .hero-panel-card h3 {
        font-size: clamp(1.9rem, 7vw, 2.6rem);
      }
      .hero-panel-card.has-verse h3 {
        font-size: clamp(1.55rem, 5.6vw, 2rem);
      }
      .hero-panel-card.has-verse .hero-panel-copy > p {
        font-size: 0.88rem;
        line-height: 1.56;
      }
      .hero-verse-snippet {
        padding: 16px 16px 16px 18px;
      }
      .hero-verse-head,
      .hero-verse-body {
        padding-left: 14px;
      }
      .hero-verse-reference {
        font-size: 1rem;
      }
      .hero-verse-body p {
        font-size: 0.86rem;
      }
    }

    @media (max-width: 480px) {
      body { padding-top: 144px; }
      .container {
        padding: 0 18px;
      }
      .topbar-chip {
        padding: 7px 10px;
        font-size: 0.7rem;
      }
      .topbar-link {
        font-size: 0.78rem;
      }
      .hero-frame {
        padding: 20px;
      }
      .hero-actions {
        flex-direction: column;
      }
      .btn-primary-lg,
      .btn-outline-lg {
        width: 100%;
        justify-content: center;
      }
      .header-slider-controls {
        justify-content: space-between;
      }
    }

    /* HOME PAGE */
    .home-page {
      position: relative;
      z-index: 1;
      padding-bottom: 96px;
    }

    .home-page section {
      padding: 0 0 96px;
    }

    .home-strip {
      padding-bottom: 36px !important;
    }

    .home-alert {
      margin-bottom: 18px;
      padding: 16px 18px;
      border-radius: 20px;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: rgba(255, 255, 255, 0.86);
      box-shadow: 0 18px 34px rgba(8, 39, 60, 0.07);
      color: #21475c;
    }

    .home-alert.success {
      border-color: rgba(31, 128, 102, 0.18);
      background: rgba(231, 249, 243, 0.92);
    }

    .home-alert.error {
      border-color: rgba(180, 83, 67, 0.18);
      background: rgba(255, 244, 242, 0.94);
    }

    .home-alert ul {
      margin-top: 8px;
      padding-left: 18px;
    }

    .home-strip-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 16px;
    }

    .home-strip-card {
      padding: 24px 26px;
      border-radius: 24px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(239, 249, 251, 0.82));
      border: 1px solid rgba(255, 255, 255, 0.78);
      box-shadow: 0 22px 40px rgba(8, 39, 60, 0.08);
    }

    .home-strip-card span {
      display: block;
      font-size: 0.82rem;
      color: #4b6a7d;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      font-weight: 700;
    }

    .home-strip-card strong {
      display: block;
      margin-top: 10px;
      font-size: 2.1rem;
      letter-spacing: -0.05em;
      color: #0c2a43;
    }

    .home-section-head {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      margin-bottom: 34px;
    }

    .service-grid,
    .opportunity-grid,
    .testimonial-grid,
    .prayer-grid {
      display: grid;
      gap: 18px;
    }

    .service-grid {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .service-card,
    .opportunity-card,
    .testimonial-card-home,
    .prayer-card,
    .prayer-form-card,
    .contact-form-card,
    .contact-info-card,
    .empty-card {
      position: relative;
      overflow: hidden;
      border-radius: 28px;
      border: 1px solid rgba(255, 255, 255, 0.76);
      background: rgba(255, 255, 255, 0.88);
      box-shadow: 0 24px 44px rgba(8, 39, 60, 0.08);
    }

    .service-card {
      min-height: 280px;
      padding: 24px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .service-card::before,
    .opportunity-card::before,
    .testimonial-card-home::before,
    .prayer-card::before,
    .prayer-form-card::before,
    .contact-form-card::before {
      content: '';
      position: absolute;
      inset: 0;
      pointer-events: none;
      opacity: 0.85;
    }

    .service-card-blue::before {
      background: linear-gradient(140deg, rgba(10, 95, 136, 0.12), transparent 42%);
    }

    .service-card-gold::before {
      background: linear-gradient(140deg, rgba(237, 181, 63, 0.14), transparent 42%);
    }

    .service-card-teal::before {
      background: linear-gradient(140deg, rgba(37, 151, 146, 0.13), transparent 42%);
    }

    .service-card-slate::before {
      background: linear-gradient(140deg, rgba(67, 94, 116, 0.14), transparent 42%);
    }

    .service-card-top {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .service-badge {
      width: 52px;
      height: 52px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 18px;
      background: #0f5a83;
      color: #fff;
      font-weight: 700;
      letter-spacing: 0.08em;
      box-shadow: 0 16px 26px rgba(15, 90, 131, 0.2);
    }

    .service-card-gold .service-badge {
      background: #d39518;
      box-shadow: 0 16px 26px rgba(211, 149, 24, 0.2);
    }

    .service-card-teal .service-badge {
      background: #14857c;
      box-shadow: 0 16px 26px rgba(20, 133, 124, 0.2);
    }

    .service-card-slate .service-badge {
      background: #486176;
      box-shadow: 0 16px 26px rgba(72, 97, 118, 0.2);
    }

    .service-meta {
      font-size: 0.78rem;
      font-weight: 700;
      color: #6e8796;
      text-transform: uppercase;
      letter-spacing: 0.12em;
    }

    .service-card h3,
    .opportunity-card h3,
    .prayer-card h3,
    .prayer-form-card h3 {
      position: relative;
      z-index: 1;
      margin-top: 24px;
      font-size: 1.45rem;
      line-height: 1.1;
      letter-spacing: -0.04em;
      color: #0d2c43;
    }

    .service-card p,
    .opportunity-card p,
    .testimonial-card-home p,
    .prayer-card p {
      position: relative;
      z-index: 1;
      margin-top: 16px;
      color: #486475;
      line-height: 1.8;
    }

    .opportunity-grid,
    .testimonial-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .opportunity-card,
    .testimonial-card-home {
      padding: 26px;
    }

    .opportunity-card::before {
      background: linear-gradient(160deg, rgba(10, 95, 136, 0.08), transparent 46%);
    }

    .opportunity-card-top,
    .opportunity-meta {
      position: relative;
      z-index: 1;
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
    }

    .opportunity-card-top {
      justify-content: space-between;
      align-items: center;
    }

    .opportunity-type,
    .opportunity-urgent,
    .prayer-card-label {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      padding: 8px 12px;
      border-radius: 999px;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .opportunity-type {
      background: rgba(15, 90, 131, 0.1);
      color: #0f5a83;
    }

    .opportunity-urgent {
      background: rgba(211, 149, 24, 0.14);
      color: #a56d00;
    }

    .opportunity-meta {
      margin-top: 18px;
      color: #6e8796;
      font-size: 0.88rem;
    }

    .opportunity-link {
      position: relative;
      z-index: 1;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-top: 22px;
      color: #0f5a83;
      font-weight: 700;
    }

    .testimonial-card-home::before {
      background: linear-gradient(160deg, rgba(237, 181, 63, 0.1), transparent 40%);
    }

    .testimonial-avatar {
      position: relative;
      z-index: 1;
      width: 56px;
      height: 56px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 20px;
      background: linear-gradient(135deg, #0d4f77 0%, #d7a33f 100%);
      color: #fff;
      font-weight: 700;
      font-size: 1.15rem;
      box-shadow: 0 16px 30px rgba(11, 75, 115, 0.2);
    }

    .testimonial-author {
      position: relative;
      z-index: 1;
      margin-top: 24px;
      padding-top: 18px;
      border-top: 1px solid rgba(10, 89, 128, 0.08);
    }

    .testimonial-author strong {
      display: block;
      color: #0d2c43;
    }

    .testimonial-author span {
      display: block;
      margin-top: 6px;
      color: #718696;
      font-size: 0.9rem;
    }

    .prayer-intro-note {
      margin-top: 12px;
      max-width: 70ch;
      color: #37566c;
      line-height: 1.75;
    }

    .prayer-grid {
      grid-template-columns: repeat(12, minmax(0, 1fr));
      align-items: stretch;
      gap: 22px;
    }

    .prayer-card,
    .prayer-form-card {
      padding: 24px;
      min-height: 100%;
      display: flex;
      flex-direction: column;
    }

    .prayer-verse-card,
    .prayer-testimony-card,
    .prayer-empty-card,
    .prayer-form-card {
      grid-column: span 3;
    }

    .prayer-verse {
      background: linear-gradient(160deg, rgba(11, 75, 115, 0.96), rgba(14, 110, 132, 0.86));
      color: #fff;
      border-color: rgba(255, 255, 255, 0.1);
    }

    .prayer-verse h3,
    .prayer-verse p,
    .prayer-verse .prayer-card-label {
      color: #fff;
    }

    .prayer-verse-version {
      position: relative;
      z-index: 1;
      display: inline-flex;
      margin-top: auto;
      padding-top: 18px;
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.76);
    }

    .prayer-card-label {
      position: relative;
      z-index: 1;
      background: rgba(10, 89, 128, 0.08);
      color: #0f5a83;
    }

    .prayer-verse .prayer-card-label {
      background: rgba(255, 255, 255, 0.12);
    }

    .prayer-testimony-card::before {
      background: linear-gradient(160deg, rgba(12, 89, 128, 0.08), transparent 42%);
    }

    .prayer-testimony-meta {
      position: relative;
      z-index: 1;
      margin-top: auto;
      padding-top: 18px;
      color: #6c8292;
      font-size: 0.84rem;
      font-weight: 700;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      border-top: 1px solid rgba(10, 89, 128, 0.08);
    }

    .prayer-empty-card-wide {
      grid-column: span 9;
    }

    .prayer-form-card::before {
      background: linear-gradient(160deg, rgba(237, 181, 63, 0.12), transparent 42%);
    }

    .stack-form,
    .contact-form-card {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .field-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .stack-form input,
    .stack-form textarea,
    .contact-form-card input,
    .contact-form-card textarea,
    .contact-form-card select {
      width: 100%;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: rgba(255, 255, 255, 0.92);
      border-radius: 18px;
      padding: 15px 16px;
      color: #153850;
      font: inherit;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
    }

    .stack-form textarea,
    .contact-form-card textarea {
      resize: vertical;
      min-height: 132px;
    }

    .stack-form input:focus,
    .stack-form textarea:focus,
    .contact-form-card input:focus,
    .contact-form-card textarea:focus,
    .contact-form-card select:focus {
      outline: none;
      border-color: rgba(15, 90, 131, 0.34);
      box-shadow: 0 0 0 4px rgba(15, 90, 131, 0.08);
    }

    .checkbox-line {
      display: flex;
      align-items: center;
      gap: 10px;
      color: #506c7d;
      font-size: 0.92rem;
    }

    .checkbox-line input {
      width: 18px;
      height: 18px;
      padding: 0;
      box-shadow: none;
    }

    .solid-submit,
    .ghost-submit {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 54px;
      padding: 0 22px;
      border-radius: 999px;
      font-weight: 700;
      transition: transform 0.35s var(--silk), box-shadow 0.35s var(--silk), background 0.35s var(--silk);
    }

    .solid-submit {
      background: linear-gradient(135deg, #0d5a82 0%, #15869d 100%);
      color: #fff;
      box-shadow: 0 20px 34px rgba(13, 90, 130, 0.18);
    }

    .solid-submit:hover,
    .ghost-submit:hover {
      transform: translateY(-2px);
    }

    .ghost-submit {
      background: rgba(255, 255, 255, 0.8);
      color: #0d5a82;
      border: 1px solid rgba(10, 89, 128, 0.12);
      box-shadow: 0 16px 28px rgba(8, 39, 60, 0.08);
    }

    .contact-shell {
      display: grid;
      grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
      gap: 26px;
      padding: 34px;
      border-radius: 34px;
      background: linear-gradient(160deg, rgba(255, 255, 255, 0.86), rgba(236, 246, 250, 0.8));
      border: 1px solid rgba(255, 255, 255, 0.78);
      box-shadow: 0 28px 60px rgba(8, 39, 60, 0.08);
    }

    .contact-cards {
      display: grid;
      gap: 14px;
      margin-top: 26px;
    }

    .contact-info-card {
      padding: 20px 22px;
    }

    .contact-info-card span {
      display: block;
      font-size: 0.8rem;
      color: #5f7d8f;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      font-weight: 700;
    }

    .contact-info-card strong,
    .contact-info-card a {
      display: block;
      margin-top: 10px;
      color: #0d2c43;
      font-size: 1.08rem;
      font-weight: 700;
    }

    .contact-form-wrap {
      display: flex;
      align-items: stretch;
    }

    .contact-form-card {
      width: 100%;
      padding: 24px;
    }

    .contact-form-actions {
      display: flex;
      gap: 12px;
    }

    .empty-card {
      padding: 28px;
    }

    .empty-card h3 {
      color: #0d2c43;
    }

    .empty-card p {
      margin-top: 10px;
      color: #587181;
      line-height: 1.8;
    }

    @media (max-width: 1024px) {
      .home-strip-grid,
      .service-grid,
      .opportunity-grid,
      .testimonial-grid,
      .contact-shell {
        grid-template-columns: 1fr 1fr;
      }

      .prayer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .prayer-form-card,
      .prayer-empty-card-wide,
      .contact-form-wrap,
      .contact-copy {
        grid-column: span 2;
      }
    }

    @media (max-width: 768px) {
      .home-page {
        padding-bottom: 72px;
      }

      .home-page section {
        padding-bottom: 72px;
      }

      .home-strip-grid,
      .service-grid,
      .opportunity-grid,
      .testimonial-grid,
      .contact-shell,
      .field-row {
        grid-template-columns: 1fr;
      }

      .prayer-grid {
        grid-template-columns: 1fr;
      }

      .prayer-form-card,
      .prayer-verse-card,
      .prayer-testimony-card,
      .prayer-empty-card,
      .prayer-empty-card-wide,
      .contact-form-wrap,
      .contact-copy {
        grid-column: auto;
      }

      .contact-shell {
        padding: 24px;
      }

      .contact-form-actions {
        flex-direction: column;
      }
    }

    /* TOPBAR REFINEMENTS */
    .nav {
      padding: 0;
    }

    .nav-shell {
      max-width: none;
      width: 100%;
      padding: 0;
      margin: 0;
    }

    .nav-inner {
      width: 100%;
      border-radius: 0;
      padding: 14px 32px 14px 32px;
      border-left: none;
      border-right: none;
      box-shadow:
        0 16px 36px rgba(6, 33, 52, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    }

    .site-topbar {
      transition: transform 0.45s var(--silk), opacity 0.3s ease;
    }

    .site-topbar-left,
    .site-topbar-right {
      gap: 12px;
    }

    .site-topbar-right {
      justify-content: flex-end;
    }

    .topbar-locale-text {
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(230, 242, 250, 0.72);
    }

    .topbar-locale-switcher {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 5px;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.12);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    .topbar-locale-switcher .locale-flag-link {
      min-width: 40px;
      min-height: 36px;
      padding: 0 10px;
      border-radius: 12px;
      color: #d9ebf6;
      font-size: 0.72rem;
      font-weight: 700;
    }

    .topbar-locale-switcher .locale-flag-link:hover,
    .topbar-locale-switcher .locale-flag-link.active {
      color: #0d4265;
    }

    .nav {
      transition: padding var(--silk-dur) var(--silk), top 0.45s var(--silk);
    }

    body.topbar-hidden .site-topbar {
      transform: translateY(-100%);
      opacity: 0;
    }

    body.topbar-hidden .nav {
      top: 0;
    }

    @media (max-width: 768px) {
      .nav-inner {
        padding: 12px 18px;
        border-radius: 0;
      }

      .site-topbar-inner {
        justify-content: space-between;
      }

      .site-topbar-right {
        display: flex;
      }

      .topbar-locale-text {
        display: none;
      }

      .topbar-locale-switcher .locale-flag-link {
        min-width: 36px;
        min-height: 34px;
        padding: 0 8px;
      }
    }

    @media (max-width: 480px) {
      .nav-inner {
        padding: 12px 16px;
      }

      .site-topbar-left {
        gap: 8px;
      }

      .topbar-link {
        font-size: 0.73rem;
      }

      .topbar-locale-switcher {
        gap: 6px;
        padding: 4px;
      }

      .topbar-locale-switcher .locale-flag-link span:last-child {
        display: none;
      }
    }

    /* MENU RESPONSIVENESS TUNING */
    @media (max-width: 1320px) {
      .nav-inner {
        grid-template-columns: max-content minmax(0, 1fr) max-content;
        gap: 12px;
        padding: 12px 20px;
      }

      .nav-brand-wrap {
        gap: 10px;
      }

      .nav-status {
        display: none;
      }

      .nav-links {
        gap: 4px;
        padding: 5px 6px;
      }

      .nav-links a {
        min-height: 38px;
        padding: 0 11px;
        font-size: 0.8rem;
      }

      .nav-cta {
        gap: 8px;
      }

      .btn-ghost,
      .btn-primary {
        min-height: 42px;
        padding: 0 16px;
        font-size: 0.82rem;
      }
    }

    @media (max-width: 1140px) {
      .nav-inner {
        padding: 12px 18px;
        column-gap: 10px;
      }

      .nav-links a {
        padding: 0 10px;
        font-size: 0.77rem;
      }

      .btn-ghost,
      .btn-primary {
        min-height: 40px;
        padding: 0 14px;
        font-size: 0.78rem;
      }
    }

    @media (max-width: 980px) {
      .nav-inner {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px;
        padding: 12px 20px;
      }

      .nav-links,
      .nav-cta {
        display: none;
      }

      .nav-hamburger {
        display: flex;
        justify-self: end;
      }

      .nav-brand-wrap,
      .nav-logo {
        min-width: 0;
        width: 100%;
      }

      .nav-logo-copy-mobile {
        display: flex;
      }

      .nav-logo-copy strong {
        max-width: 240px;
      }

      .mobile-menu {
        padding: 94px 16px 20px;
      }

      .nav-logo-mark,
      .nav.scrolled .nav-logo-mark {
        width: 132px;
        height: 78px;
        padding: 10px 12px;
        border-radius: 18px;
        transform: translateY(0);
      }
    }

    @media (max-width: 760px) {
      .page-banner {
        padding: 142px 0 28px;
      }

      .page-banner-inner {
        grid-template-columns: 1fr;
        align-items: flex-start;
        padding: 26px 22px;
      }

      .page-banner-title {
        max-width: none;
      }

      .page-banner-breadcrumbs {
        justify-self: start;
      }

      .site-topbar-inner {
        min-height: auto;
        padding-top: 8px;
        padding-bottom: 8px;
        align-items: flex-start;
      }

      .site-topbar-left,
      .site-topbar-right {
        min-width: 0;
      }

      .site-topbar-left {
        flex: 1;
      }

      .site-topbar-right {
        flex-shrink: 0;
      }

      .topbar-link {
        font-size: 0.78rem;
      }

      .nav-inner {
        padding: 12px 18px;
      }
    }

    @media (max-width: 620px) {
      .page-banner-title {
        font-size: 2rem;
      }

      .page-banner-subtitle {
        font-size: 0.94rem;
        line-height: 1.7;
      }

      .page-banner-breadcrumbs {
        font-size: 0.9rem;
        gap: 10px;
        padding: 12px 14px;
      }

      .site-topbar-inner {
        gap: 10px;
      }

      .site-topbar-left {
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
      }

      .site-topbar-right {
        align-self: flex-start;
      }

      .nav-logo-mark,
      .nav.scrolled .nav-logo-mark {
        width: 112px;
        height: 66px;
        padding: 8px 10px;
        border-radius: 16px;
        transform: translateY(0);
      }

      .nav-logo-copy span {
        font-size: 0.58rem;
      }

      .nav-logo-copy strong {
        max-width: 180px;
        font-size: 0.9rem;
      }

      .nav-hamburger {
        width: 44px;
        height: 44px;
        border-radius: 14px;
      }

      .mobile-menu {
        padding: 106px 12px 18px;
      }

      .mobile-menu-panel {
        width: 100%;
        padding: 16px;
        border-radius: 22px;
      }

      .mobile-menu-links a {
        min-height: 52px;
        padding: 0 16px;
        font-size: 0.95rem;
      }
    }

    /* MOBILE HEADER COMPACTION */
    @media (max-width: 760px) {
      html {
        scroll-padding-top: 176px;
      }

      body {
        padding-top: 170px;
      }

      .site-topbar-inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 86px;
        align-items: start;
        gap: 10px 12px;
        padding: 8px 12px;
      }

      .site-topbar-left {
        display: grid;
        gap: 4px;
        min-width: 0;
      }

      .site-topbar-right {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        min-width: max-content;
      }

      .topbar-link {
        display: block;
        width: 100%;
        font-size: 0.76rem;
        line-height: 1.35;
        white-space: normal;
        overflow-wrap: anywhere;
      }

      .topbar-locale-switcher {
        gap: 4px;
        padding: 3px;
        border-radius: 14px;
      }

      .topbar-locale-switcher .locale-flag-link {
        min-width: 34px;
        min-height: 32px;
        padding: 0 7px;
        border-radius: 10px;
      }

      .nav {
        top: 86px;
        padding: 0;
      }

      .nav-inner {
        min-height: 72px;
        grid-template-columns: minmax(0, 1fr) auto;
        padding: 12px 14px;
        align-items: center;
      }

      .nav-brand-wrap,
      .nav-logo {
        width: 100%;
        min-width: 0;
      }

      .nav-logo {
        gap: 10px;
      }

      .nav-logo-mark,
      .nav.scrolled .nav-logo-mark {
        width: 86px;
        height: 52px;
        padding: 6px 8px;
        border-radius: 14px;
        transform: translateY(0);
      }

      .nav-logo-copy-mobile span {
        font-size: 0.54rem;
        letter-spacing: 0.13em;
      }

      .nav-logo-copy-mobile strong {
        max-width: none;
        font-size: 0.9rem;
        line-height: 1.1;
        white-space: normal;
      }

      .nav-hamburger {
        width: 44px;
        height: 44px;
      }

      .mobile-menu {
        padding-top: 146px;
      }
    }

    @media (max-width: 520px) {
      html {
        scroll-padding-top: 166px;
      }

      body {
        padding-top: 160px;
      }

      .site-topbar-inner {
        min-height: 82px;
        padding: 8px 10px;
      }

      .site-topbar-left {
        gap: 3px;
      }

      .topbar-link {
        font-size: 0.71rem;
      }

      .nav {
        top: 82px;
      }

      .nav-inner {
        min-height: 68px;
        padding: 10px 12px;
      }

      .nav-logo-mark,
      .nav.scrolled .nav-logo-mark {
        width: 78px;
        height: 48px;
      }

      .nav-logo-copy-mobile strong {
        font-size: 0.84rem;
      }

      .mobile-menu {
        padding-top: 138px;
      }
    }

    /* OFFERS PAGE */
    .offers-page {
      position: relative;
      z-index: 1;
      padding: 168px 0 96px;
    }

    .offers-services-section {
      padding-top: 12px;
    }

    .offers-service-card .article-card-visual {
      min-height: 220px;
    }

    .offers-hero {
      padding-bottom: 28px;
    }

    .offers-hero-shell {
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.8fr);
      gap: 22px;
      align-items: end;
      padding: 34px;
      border-radius: 34px;
      background:
        radial-gradient(circle at top right, rgba(237, 181, 63, 0.16), transparent 20%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(234, 245, 249, 0.9));
      border: 1px solid rgba(255, 255, 255, 0.82);
      box-shadow: 0 28px 52px rgba(8, 39, 60, 0.08);
    }

    .offers-hero-meta {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .offers-hero-stat {
      padding: 20px 22px;
      border-radius: 24px;
      background: rgba(9, 72, 105, 0.92);
      color: #fff;
      box-shadow: 0 18px 32px rgba(8, 39, 60, 0.14);
    }

    .offers-hero-stat span {
      display: block;
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.68);
    }

    .offers-hero-stat strong {
      display: block;
      margin-top: 10px;
      font-size: 2rem;
      letter-spacing: -0.05em;
    }

    .offers-search-section {
      padding: 0 0 28px;
    }

    .offers-search-shell {
      padding: 24px;
      border-radius: 28px;
      background: rgba(255, 255, 255, 0.9);
      border: 1px solid rgba(255, 255, 255, 0.82);
      box-shadow: 0 22px 42px rgba(8, 39, 60, 0.07);
    }

    .offers-search-bar {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      gap: 14px;
    }

    .offers-search-field {
      position: relative;
    }

    .offers-search-meta {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      margin-top: 12px;
      color: #698393;
      font-size: 0.85rem;
      font-weight: 600;
    }

    .offers-search-bar input,
    .offers-filters select {
      width: 100%;
      min-height: 56px;
      padding: 0 18px;
      border-radius: 18px;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: rgba(248, 252, 253, 0.96);
      color: #163a51;
      font: inherit;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84);
    }

    .offers-search-bar input:focus,
    .offers-filters select:focus {
      outline: none;
      border-color: rgba(15, 90, 131, 0.34);
      box-shadow: 0 0 0 4px rgba(15, 90, 131, 0.08);
    }

    .offers-filters {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr)) auto auto auto;
      gap: 12px;
      margin-top: 16px;
      align-items: center;
    }

    .offers-check {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      min-height: 56px;
      padding: 0 16px;
      border-radius: 18px;
      background: rgba(248, 252, 253, 0.96);
      border: 1px solid rgba(10, 89, 128, 0.12);
      color: #375769;
      font-weight: 600;
      white-space: nowrap;
      transition: border-color 0.35s var(--silk), background 0.35s var(--silk), box-shadow 0.35s var(--silk);
    }

    .offers-check input {
      width: 18px;
      height: 18px;
      accent-color: #0f5a83;
    }

    .offers-check.is-active {
      background: rgba(15, 90, 131, 0.1);
      border-color: rgba(15, 90, 131, 0.24);
      box-shadow: 0 12px 24px rgba(8, 39, 60, 0.05);
    }

    .offers-reset {
      min-width: 150px;
    }

    .offers-list-section {
      padding: 0;
    }

    .offers-results-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 20px;
      color: #557182;
      font-weight: 600;
    }

    .offers-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .offers-grid-loading {
      opacity: 0.72;
      transition: opacity 0.25s ease;
    }

    .offer-list-card {
      position: relative;
      overflow: hidden;
      padding: 24px;
      border-radius: 28px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        linear-gradient(165deg, rgba(255, 255, 255, 0.94), rgba(238, 247, 250, 0.9));
      box-shadow: 0 24px 42px rgba(8, 39, 60, 0.07);
    }

    .offer-list-card::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(150deg, rgba(15, 90, 131, 0.08), transparent 44%);
      pointer-events: none;
    }

    .offer-card-top,
    .offer-badges,
    .offer-meta-list,
    .offer-card-actions,
    .offer-list-card h2,
    .offer-list-card p {
      position: relative;
      z-index: 1;
    }

    .offer-card-top {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 14px;
    }

    .offer-badges {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
    }

    .offer-remote-badge {
      display: inline-flex;
      align-items: center;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(27, 145, 131, 0.12);
      color: #15766d;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .offer-date {
      color: #6f8797;
      font-size: 0.82rem;
      white-space: nowrap;
    }

    .offer-list-card h2 {
      margin-top: 18px;
      font-size: 1.5rem;
      line-height: 1.12;
      letter-spacing: -0.04em;
      color: #0d2c43;
    }

    .offer-list-card p {
      margin-top: 14px;
      color: #4d6878;
      line-height: 1.82;
    }

    .offer-meta-list {
      display: grid;
      gap: 10px;
      margin-top: 18px;
      color: #60798a;
      font-size: 0.92rem;
    }

    .offer-card-actions {
      margin-top: 22px;
    }

    .offers-pagination {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 16px;
      margin-top: 28px;
    }

    .pagination-btn,
    .pagination-state {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 0 18px;
      border-radius: 999px;
      font-weight: 700;
    }

    .pagination-btn {
      background: rgba(255, 255, 255, 0.9);
      border: 1px solid rgba(10, 89, 128, 0.12);
      color: #0f5a83;
      box-shadow: 0 14px 26px rgba(8, 39, 60, 0.08);
    }

    .pagination-btn.disabled {
      color: #8da0ad;
      background: rgba(242, 247, 249, 0.9);
      box-shadow: none;
      pointer-events: none;
    }

    .pagination-state {
      color: #476678;
    }

    .offers-detail-page {
      position: relative;
      z-index: 1;
      padding: 168px 0 96px;
    }

    .offers-detail-hero {
      padding-bottom: 30px;
    }

    .offers-detail-hero-shell {
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
      gap: 24px;
      align-items: start;
      padding: 34px;
      border-radius: 34px;
      background:
        radial-gradient(circle at top right, rgba(237, 181, 63, 0.16), transparent 20%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.95), rgba(234, 245, 249, 0.9));
      border: 1px solid rgba(255, 255, 255, 0.82);
      box-shadow: 0 28px 52px rgba(8, 39, 60, 0.08);
    }

    .offers-detail-back {
      display: inline-flex;
      align-items: center;
      min-height: 44px;
      padding: 0 16px;
      border-radius: 999px;
      background: rgba(15, 90, 131, 0.08);
      color: #0f5a83;
      font-weight: 700;
      margin-bottom: 18px;
    }

    .offers-detail-badges {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 18px;
    }

    .offers-detail-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 22px;
    }

    .offers-detail-meta span,
    .offers-detail-summary li {
      padding: 12px 14px;
      border-radius: 18px;
      background: rgba(246, 250, 252, 0.92);
      border: 1px solid rgba(10, 89, 128, 0.10);
      color: #4c6778;
    }

    .offers-detail-side {
      display: grid;
      gap: 16px;
    }

    .offers-detail-action-card,
    .offers-detail-stat-card,
    .offers-detail-main,
    .offers-detail-panel {
      border-radius: 28px;
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid rgba(255, 255, 255, 0.82);
      box-shadow: 0 24px 42px rgba(8, 39, 60, 0.06);
    }

    .offers-detail-action-card {
      padding: 24px;
      display: grid;
      gap: 12px;
    }

    .offers-detail-action-card span {
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #6b8797;
    }

    .offers-detail-action-card strong {
      font-size: 1.4rem;
      line-height: 1.1;
      color: #0d2c43;
    }

    .offers-detail-action-card p {
      color: #506b7a;
      line-height: 1.8;
    }

    .offers-detail-actions {
      display: grid;
      gap: 12px;
      margin-top: 8px;
    }

    .offers-detail-stat-card {
      padding: 24px;
      background: rgba(9, 72, 105, 0.92);
      color: #fff;
    }

    .offers-detail-stat-card span {
      display: block;
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.72);
    }

    .offers-detail-stat-card strong {
      display: block;
      margin-top: 10px;
      font-size: 2rem;
      letter-spacing: -0.05em;
    }

    .offers-detail-content {
      padding: 0 0 34px;
    }

    .offers-detail-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
      gap: 22px;
      align-items: start;
    }

    .offers-detail-main {
      padding: 28px;
      display: grid;
      gap: 24px;
    }

    .offers-detail-section {
      display: grid;
      gap: 14px;
      padding-bottom: 22px;
      border-bottom: 1px solid rgba(13, 30, 28, 0.08);
    }

    .offers-detail-section:last-child {
      padding-bottom: 0;
      border-bottom: 0;
    }

    .offers-detail-section h2,
    .offers-detail-panel h2 {
      font-size: 1.22rem;
      line-height: 1.2;
      color: #0d2c43;
    }

    .offers-detail-section p {
      color: #4d6878;
      line-height: 1.9;
      white-space: pre-line;
    }

    .offers-detail-panel {
      padding: 24px;
    }

    .offers-detail-summary {
      display: grid;
      gap: 12px;
      margin-top: 18px;
    }

    .offers-detail-summary li {
      display: grid;
      gap: 6px;
    }

    .offers-detail-summary span {
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.10em;
      text-transform: uppercase;
      color: #6b8797;
    }

    .offers-detail-summary strong {
      color: #14384d;
      font-size: 1rem;
      line-height: 1.5;
    }

    .offers-application-form {
      display: grid;
      gap: 16px;
      margin-top: 8px;
    }

    .offers-application-upload-grid {
      display: grid;
      gap: 14px;
    }

    .offers-upload-field {
      display: grid;
      gap: 8px;
      padding: 18px;
      border-radius: 22px;
      background: rgba(247, 251, 252, 0.92);
      border: 1px solid rgba(10, 89, 128, 0.10);
    }

    .offers-upload-field span {
      font-size: 0.88rem;
      font-weight: 700;
      color: #31566a;
    }

    .offers-upload-field input[type="file"] {
      width: 100%;
      color: #456678;
      font: inherit;
    }

    .offers-application-actions {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }

    .offers-application-login-card,
    .offers-application-status-card {
      display: grid;
      gap: 14px;
      padding: 22px;
      border-radius: 24px;
      background: rgba(246, 250, 252, 0.94);
      border: 1px solid rgba(10, 89, 128, 0.10);
    }

    .offers-application-status-card strong {
      font-size: 1.06rem;
      color: #0d2c43;
    }

    .offers-application-status-pill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 42px;
      width: fit-content;
      padding: 0 14px;
      border-radius: 999px;
      background: rgba(26, 122, 110, 0.10);
      color: #15766d;
      font-weight: 700;
    }

    .offers-application-status-card p,
    .offers-application-login-card p {
      color: #4d6878;
      line-height: 1.8;
    }

    .offers-application-inline-note {
      display: inline-flex;
      align-items: center;
      min-height: 48px;
      padding: 0 16px;
      border-radius: 18px;
      background: rgba(244, 196, 89, 0.14);
      color: #9a6c10;
      font-weight: 700;
      line-height: 1.4;
    }

    .offers-detail-related {
      padding-top: 10px;
    }

    .articles-page {
      padding: 168px 0 96px;
      background:
        radial-gradient(circle at top left, rgba(245, 158, 11, 0.10), transparent 30%),
        radial-gradient(circle at top right, rgba(26, 122, 110, 0.12), transparent 32%),
        linear-gradient(180deg, #f8f4ec 0%, #f4efe6 100%);
    }

    .articles-hero {
      padding-bottom: 26px;
    }

    .articles-hero-shell,
    .articles-search-shell,
    .article-detail-main,
    .article-detail-aside .offers-detail-panel {
      border: 1px solid rgba(10, 89, 128, 0.10);
      background: rgba(255, 255, 255, 0.92);
      box-shadow: 0 24px 48px rgba(13, 44, 67, 0.08);
    }

    .articles-hero-shell {
      display: grid;
      grid-template-columns: 1.4fr 1fr;
      gap: 24px;
      padding: 36px;
      border-radius: 32px;
    }

    .articles-hero-meta {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
    }

    .articles-hero-stat {
      display: grid;
      gap: 10px;
      align-content: start;
      padding: 18px;
      min-height: 116px;
      border-radius: 24px;
      background: linear-gradient(160deg, #10253d 0%, #16395c 100%);
      color: #fff;
    }

    .articles-hero-stat span {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: rgba(255,255,255,0.58);
    }

    .articles-hero-stat strong {
      font-size: 2.1rem;
      line-height: 1;
      color: var(--accent-light);
    }

    .articles-search-section {
      padding-bottom: 34px;
    }

    .articles-search-shell {
      display: grid;
      gap: 18px;
      padding: 24px;
      border-radius: 30px;
    }

    .articles-search-field input {
      width: 100%;
      min-height: 60px;
      padding: 0 18px;
      border-radius: 18px;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: #fff;
      color: #0d2c43;
      font: inherit;
    }

    .articles-search-field input:focus {
      outline: none;
      border-color: rgba(26, 122, 110, 0.36);
      box-shadow: 0 0 0 4px rgba(26, 122, 110, 0.08);
    }

    .articles-search-meta {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      flex-wrap: wrap;
      color: #527080;
      font-size: 0.88rem;
    }

    .articles-filter-row {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      align-items: center;
    }

    .articles-filter-chip {
      min-height: 44px;
      padding: 0 16px;
      border-radius: 999px;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: rgba(247, 251, 252, 0.92);
      color: #24465a;
      font-size: 0.88rem;
      font-weight: 700;
      transition: all 0.25s ease;
    }

    .articles-filter-chip:hover {
      border-color: rgba(26, 122, 110, 0.24);
      transform: translateY(-1px);
    }

    .articles-filter-chip.is-active {
      background: linear-gradient(135deg, #1a7a6e 0%, #155e66 100%);
      border-color: transparent;
      color: #fff;
      box-shadow: 0 12px 28px rgba(26, 122, 110, 0.20);
    }

    .articles-reset {
      margin-left: auto;
    }

    .articles-results-head {
      margin-bottom: 20px;
      color: #456678;
    }

    .articles-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 24px;
    }

    .article-card {
      display: grid;
      grid-template-rows: 220px 1fr;
      border-radius: 30px;
      overflow: hidden;
      border: 1px solid rgba(10, 89, 128, 0.10);
      background: rgba(255,255,255,0.94);
      box-shadow: 0 20px 42px rgba(13, 44, 67, 0.08);
    }

    .article-card-visual {
      position: relative;
      background:
        radial-gradient(circle at 18% 18%, rgba(255,255,255,0.18), transparent 24%),
        linear-gradient(140deg, var(--article-accent) 0%, #10253d 100%);
    }

    .article-card-visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .article-card-placeholder {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      gap: 12px;
      padding: 24px;
      color: #fff;
    }

    .article-card-placeholder span {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: rgba(255,255,255,0.72);
    }

    .article-card-placeholder strong {
      font-size: 1.3rem;
      line-height: 1.25;
    }

    .article-card-body {
      display: grid;
      gap: 16px;
      padding: 24px;
    }

    .article-card-top,
    .article-badges,
    .article-detail-meta {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      align-items: center;
    }

    .article-card-top {
      justify-content: space-between;
      align-items: flex-start;
    }

    .article-category-badge,
    .article-featured-badge,
    .article-date {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      padding: 0 12px;
      border-radius: 999px;
      font-size: 0.76rem;
      font-weight: 700;
    }

    .article-category-badge {
      background: color-mix(in srgb, var(--article-accent) 12%, white);
      color: color-mix(in srgb, var(--article-accent) 84%, #10253d);
    }

    .article-featured-badge {
      background: rgba(245, 158, 11, 0.14);
      color: #9f6900;
    }

    .article-date {
      background: rgba(10, 89, 128, 0.06);
      color: #5b7686;
    }

    .article-card h2,
    .article-card h3 {
      margin: 0;
      color: #0d2c43;
      font-size: 1.32rem;
      line-height: 1.3;
    }

    .article-card p {
      margin: 0;
      color: #4d6878;
      line-height: 1.75;
    }

    .article-meta-list {
      display: flex;
      gap: 10px 16px;
      flex-wrap: wrap;
      color: #5b7686;
      font-size: 0.87rem;
    }

    .article-card-actions {
      margin-top: auto;
    }

    .article-detail-page {
      padding: 168px 0 96px;
      background: linear-gradient(180deg, #f8f4ec 0%, #f4efe6 100%);
    }

    .article-detail-shell {
      display: grid;
      grid-template-columns: 1.5fr 0.8fr;
      gap: 28px;
      align-items: start;
      padding-bottom: 36px;
    }

    .article-detail-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.72fr);
      gap: 28px;
      align-items: start;
    }

    .article-detail-main {
      padding: 24px;
      border-radius: 30px;
    }

    .article-detail-cover {
      margin-bottom: 24px;
      border-radius: 24px;
      overflow: hidden;
      max-height: 420px;
    }

    .article-detail-cover img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .article-detail-richtext {
      color: #24465a;
      line-height: 1.95;
    }

    .home-articles {
      padding-top: 10px;
    }

    .article-detail-gallery {
      display: grid;
      gap: 16px;
      margin-bottom: 28px;
    }

    .article-detail-gallery-head {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      flex-wrap: wrap;
      align-items: center;
    }

    .article-detail-gallery-head h2 {
      margin: 0;
      color: #0d2c43;
      font-size: 1.15rem;
    }

    .article-detail-gallery-head span {
      color: #5b7686;
      font-size: 0.88rem;
      font-weight: 700;
    }

    .article-detail-gallery-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
    }

    .article-detail-gallery-item {
      margin: 0;
      border-radius: 18px;
      overflow: hidden;
      min-height: 130px;
      background: rgba(245, 248, 250, 0.94);
      border: 1px solid rgba(10, 89, 128, 0.08);
    }

    .article-detail-gallery-item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    @media (max-width: 1024px) {
      .offers-page {
        padding-top: 176px;
      }

      .offers-detail-page {
        padding-top: 176px;
      }

      .offers-hero-shell,
      .offers-grid {
        grid-template-columns: 1fr 1fr;
      }

      .offers-detail-hero-shell,
      .offers-detail-layout {
        grid-template-columns: 1fr;
      }

      .offers-hero-copy,
      .offers-search-bar {
        grid-column: span 2;
      }

      .offers-filters {
        grid-template-columns: 1fr 1fr 1fr;
      }

      .offers-reset {
        width: 100%;
      }

      .articles-page,
      .article-detail-page {
        padding-top: 176px;
      }

      .articles-hero-shell,
      .article-detail-shell,
      .article-detail-layout {
        grid-template-columns: 1fr;
      }

      .articles-hero-meta,
      .articles-grid {
        grid-template-columns: 1fr 1fr;
      }

      .article-detail-gallery-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    @media (max-width: 768px) {
      .offers-page {
        padding-top: 146px;
      }

      .offers-detail-page {
        padding-top: 146px;
      }

      .offers-hero-shell,
      .offers-hero-meta,
      .offers-grid,
      .offers-search-bar,
      .offers-filters {
        grid-template-columns: 1fr;
      }

      .offers-detail-hero-shell {
        grid-template-columns: 1fr;
      }

      .offers-search-shell,
      .offers-hero-shell,
      .offers-detail-hero-shell,
      .offers-detail-main,
      .offers-detail-panel {
        padding: 20px;
      }

      .offers-hero-copy,
      .offers-search-bar {
        grid-column: auto;
      }

      .offers-search-meta,
      .offers-results-head,
      .offers-pagination {
        flex-direction: column;
        align-items: flex-start;
      }

      .offers-pagination {
        align-items: center;
      }

      .articles-page,
      .article-detail-page {
        padding-top: 146px;
      }

      .articles-hero-shell,
      .articles-hero-meta,
      .articles-grid {
        grid-template-columns: 1fr;
      }

      .article-detail-gallery-grid {
        grid-template-columns: 1fr;
      }

      .articles-search-shell,
      .articles-hero-shell,
      .article-detail-main,
      .article-detail-aside .offers-detail-panel {
        padding: 20px;
      }

      .articles-search-meta {
        flex-direction: column;
        align-items: flex-start;
      }

      .articles-reset {
        margin-left: 0;
        width: 100%;
      }
    }

    /* CV SERVICES PAGE */
    .cv-services-page {
      position: relative;
      z-index: 1;
      padding: 168px 0 96px;
    }

    .cv-services-hero {
      padding-bottom: 28px;
    }

    .cv-services-hero-shell,
    .cv-form-shell,
    .cv-whatsapp-shell {
      border-radius: 32px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        radial-gradient(circle at top right, rgba(237, 181, 63, 0.14), transparent 22%),
        linear-gradient(155deg, rgba(255, 255, 255, 0.94), rgba(234, 245, 249, 0.9));
      box-shadow: 0 26px 48px rgba(8, 39, 60, 0.08);
    }

    .cv-services-hero-shell {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 22px;
      align-items: end;
      padding: 34px;
    }

    .cv-services-hero-actions {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .cv-form-section,
    .cv-services-list-section {
      padding: 0 0 32px;
    }

    .cv-form-shell {
      display: grid;
      grid-template-columns: minmax(280px, 0.84fr) minmax(0, 1.16fr);
      gap: 24px;
      padding: 28px;
    }

    .cv-upload-note {
      margin-top: 24px;
      padding: 18px 20px;
      border-radius: 22px;
      background: rgba(9, 72, 105, 0.92);
      color: #fff;
      box-shadow: 0 18px 30px rgba(8, 39, 60, 0.14);
    }

    .cv-upload-note strong {
      display: block;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.72);
    }

    .cv-upload-note span {
      display: block;
      margin-top: 10px;
      line-height: 1.8;
    }

    .cv-upload-note-soft {
      margin-top: 18px;
      background: rgba(255, 255, 255, 0.88);
      color: #123642;
      box-shadow: 0 12px 24px rgba(8, 39, 60, 0.08);
    }

    .cv-upload-note-soft strong {
      color: #1a7a6e;
    }

    .cv-form-card {
      display: flex;
      flex-direction: column;
      gap: 14px;
      padding: 24px;
      border-radius: 26px;
      background: rgba(255, 255, 255, 0.9);
      border: 1px solid rgba(255, 255, 255, 0.84);
      box-shadow: 0 18px 32px rgba(8, 39, 60, 0.06);
    }

    .cv-form-card input,
    .cv-form-card textarea,
    .cv-form-card select {
      width: 100%;
      border: 1px solid rgba(10, 89, 128, 0.12);
      background: rgba(248, 252, 253, 0.96);
      border-radius: 18px;
      padding: 15px 16px;
      color: #153850;
      font: inherit;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
    }

    .cv-auth-card strong {
      display: block;
      color: #0d2c43;
      font-size: 1.1rem;
    }

    .cv-auth-card p {
      margin-top: 12px;
      color: #4d6878;
      line-height: 1.8;
    }

    .cv-form-card input:focus,
    .cv-form-card textarea:focus,
    .cv-form-card select:focus {
      outline: none;
      border-color: rgba(15, 90, 131, 0.34);
      box-shadow: 0 0 0 4px rgba(15, 90, 131, 0.08);
    }

    .field-row-wide {
      grid-template-columns: minmax(0, 1fr) auto;
      align-items: stretch;
    }

    .cv-services-checks {
      display: grid;
      gap: 10px;
    }

    .cv-file-field {
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding: 18px;
      border-radius: 22px;
      border: 1px dashed rgba(10, 89, 128, 0.24);
      background: rgba(248, 252, 253, 0.84);
      color: #355568;
      font-weight: 700;
    }

    .cv-file-field input {
      padding: 0;
      border: 0;
      background: transparent;
      box-shadow: none;
    }

    .cv-services-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
    }

    .cv-service-footer {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-top: 20px;
      position: relative;
      z-index: 1;
    }

    .cv-service-footer strong {
      color: #0d2c43;
      font-size: 0.98rem;
    }

    .cv-whatsapp-section {
      padding: 0;
    }

    .cv-whatsapp-shell {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 24px;
      align-items: center;
      padding: 28px 32px;
    }

    @media (max-width: 1024px) {
      .cv-services-page {
        padding-top: 176px;
      }

      .cv-form-shell {
        grid-template-columns: 1fr;
      }

      .cv-services-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    @media (max-width: 768px) {
      .cv-services-page {
        padding-top: 146px;
      }

      .cv-services-hero-shell,
      .cv-whatsapp-shell,
      .cv-services-grid,
      .field-row-wide {
        grid-template-columns: 1fr;
      }

      .cv-services-hero-shell,
      .cv-form-shell,
      .cv-whatsapp-shell {
        padding: 22px;
      }

      .cv-services-hero-actions,
      .cv-service-footer {
        justify-content: flex-start;
      }
    }

    /* TRAININGS PAGE */
    .trainings-page {
      position: relative;
      z-index: 1;
      padding: 168px 0 96px;
    }

    .trainings-hero {
      padding-bottom: 28px;
    }

    .trainings-hero-shell,
    .training-registration-shell {
      border-radius: 32px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        radial-gradient(circle at top right, rgba(237, 181, 63, 0.14), transparent 22%),
        linear-gradient(155deg, rgba(255, 255, 255, 0.94), rgba(234, 245, 249, 0.9));
      box-shadow: 0 26px 48px rgba(8, 39, 60, 0.08);
    }

    .trainings-hero-shell {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 22px;
      align-items: end;
      padding: 34px;
    }

    .trainings-hero-stat {
      padding: 22px 24px;
      border-radius: 24px;
      background: rgba(9, 72, 105, 0.92);
      color: #fff;
      box-shadow: 0 18px 32px rgba(8, 39, 60, 0.14);
    }

    .trainings-hero-stat span {
      display: block;
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.68);
    }

    .trainings-hero-stat strong {
      display: block;
      margin-top: 10px;
      font-size: 2rem;
      letter-spacing: -0.05em;
    }

    .trainings-list-section,
    .training-registration-section {
      padding: 0 0 32px;
    }

    .training-details-section {
      padding: 0 0 32px;
    }

    .trainings-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .training-card {
      position: relative;
      overflow: hidden;
      padding: 24px;
      border-radius: 28px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        linear-gradient(165deg, rgba(255, 255, 255, 0.94), rgba(238, 247, 250, 0.9));
      box-shadow: 0 24px 42px rgba(8, 39, 60, 0.07);
    }

    .training-card::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(150deg, rgba(15, 90, 131, 0.08), transparent 44%);
      pointer-events: none;
    }

    .training-card-top,
    .training-card h3,
    .training-card p,
    .training-card-actions,
    .training-selected-card {
      position: relative;
      z-index: 1;
    }

    .training-card h3 {
      margin-top: 18px;
      font-size: 1.5rem;
      line-height: 1.12;
      letter-spacing: -0.04em;
      color: #0d2c43;
    }

    .training-card p {
      margin-top: 14px;
      color: #4d6878;
      line-height: 1.82;
    }

    .training-card-actions {
      display: flex;
      gap: 12px;
      margin-top: 22px;
      flex-wrap: wrap;
    }

    .training-cover,
    .training-details-cover {
      width: 100%;
      border-radius: 24px;
      object-fit: cover;
      border: 1px solid rgba(8, 67, 104, 0.08);
      box-shadow: 0 18px 36px rgba(12, 39, 62, 0.10);
    }

    .training-cover {
      aspect-ratio: 16 / 9;
      margin-top: 14px;
    }

    .training-details-shell {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
      gap: 28px;
      padding: 30px;
      border-radius: 32px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        radial-gradient(circle at top right, rgba(237, 181, 63, 0.12), transparent 22%),
        linear-gradient(160deg, rgba(255,255,255,0.95), rgba(237,246,245,0.92));
      box-shadow: 0 24px 46px rgba(8, 39, 60, 0.08);
    }

    .training-details-copy,
    .training-details-panels {
      display: grid;
      gap: 18px;
      align-content: start;
    }

    .training-detail-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px 18px;
      color: #4d6878;
      line-height: 1.7;
    }

    .training-detail-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .training-status-pill {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      padding: 9px 14px;
      border-radius: 999px;
      font-size: 0.82rem;
      font-weight: 800;
      letter-spacing: 0.04em;
      background: rgba(8, 67, 104, 0.08);
      color: #0b5675;
    }

    .training-status-pill.state-ouverte {
      background: rgba(40, 151, 102, 0.12);
      color: #196846;
    }

    .training-status-pill.state-fermee,
    .training-status-pill.state-demarree {
      background: rgba(201, 149, 32, 0.14);
      color: #8a5d14;
    }

    .training-status-pill.state-complete,
    .training-status-pill.state-annulee,
    .training-status-pill.state-terminee {
      background: rgba(161, 51, 51, 0.12);
      color: #8a2c2c;
    }

    .training-info-card {
      padding: 20px 22px;
      border-radius: 24px;
      background: rgba(248, 252, 252, 0.94);
      border: 1px solid rgba(8, 67, 104, 0.08);
      display: grid;
      gap: 10px;
    }

    .training-info-card p {
      margin: 0;
      color: #4d6878;
      line-height: 1.8;
    }

    .training-registration-shell {
      display: grid;
      grid-template-columns: minmax(280px, 0.84fr) minmax(0, 1.16fr);
      gap: 24px;
      padding: 28px;
    }

    .training-selected-card {
      margin-top: 24px;
      padding: 20px 22px;
      border-radius: 24px;
      background: rgba(9, 72, 105, 0.92);
      color: #fff;
      box-shadow: 0 18px 30px rgba(8, 39, 60, 0.14);
    }

    .training-selected-card span {
      display: block;
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.68);
    }

    .training-selected-card strong {
      display: block;
      margin-top: 10px;
      font-size: 1.2rem;
    }

    .training-selected-card p {
      margin-top: 10px;
      line-height: 1.8;
    }

    .training-selected-card-soft {
      background: linear-gradient(180deg, rgba(236,248,246,0.92), rgba(249,252,252,0.96));
      color: #123844;
    }

    .training-selected-card-soft span {
      color: rgba(18, 56, 68, 0.62);
    }

    @media (max-width: 1024px) {
      .trainings-page {
        padding-top: 176px;
      }

      .trainings-grid {
        grid-template-columns: 1fr 1fr;
      }

      .training-registration-shell {
        grid-template-columns: 1fr;
      }

      .training-details-shell {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 768px) {
      .trainings-page {
        padding-top: 146px;
      }

      .trainings-hero-shell,
      .trainings-grid {
        grid-template-columns: 1fr;
      }

      .trainings-hero-shell,
      .training-registration-shell {
        padding: 22px;
      }

      .training-details-shell {
        padding: 22px;
      }

      .training-detail-grid {
        grid-template-columns: 1fr;
      }
    }

    /* MOBILE HEADER OUTER MARGINS */
    @media (max-width: 760px) {
      .site-topbar {
        top: 0;
        left: 0;
        right: 0;
        border-radius: 0;
        overflow: hidden;
      }

      .nav {
        left: 0;
        right: 0;
        width: 100%;
        top: 86px;
      }

      .nav-shell {
        padding: 0;
      }

      .nav-inner {
        border-radius: 0 0 22px 22px;
        overflow: visible;
      }

      body.topbar-hidden .nav {
        top: 0;
      }
    }

    @media (max-width: 520px) {
      .site-topbar {
        top: 0;
        left: 0;
        right: 0;
        border-radius: 0;
      }

      .nav {
        left: 0;
        right: 0;
        top: 82px;
      }

      .nav-inner {
        border-radius: 0 0 18px 18px;
      }

      body.topbar-hidden .nav {
        top: 0;
      }
    }

    /* CONTACT / PRAYER PAGE */
    .contact-prayer-page {
      position: relative;
      z-index: 1;
      padding: 168px 0 96px;
    }

    .contact-prayer-hero,
    .contact-prayer-panels,
    .contact-prayer-request {
      padding-bottom: 32px;
    }

    .contact-prayer-hero-shell,
    .contact-prayer-request-shell {
      border-radius: 32px;
      border: 1px solid rgba(255, 255, 255, 0.82);
      background:
        radial-gradient(circle at top left, rgba(237, 181, 63, 0.14), transparent 24%),
        linear-gradient(155deg, rgba(255, 255, 255, 0.95), rgba(232, 244, 249, 0.92));
      box-shadow: 0 26px 48px rgba(8, 39, 60, 0.08);
    }

    .contact-prayer-hero-shell {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
      gap: 22px;
      align-items: center;
      padding: 34px;
    }

    .contact-prayer-hero-cards {
      display: grid;
      gap: 14px;
    }

    .contact-prayer-info-card,
    .contact-prayer-verse-card,
    .contact-prayer-request-note {
      padding: 18px 20px;
      border-radius: 24px;
      border: 1px solid rgba(8, 39, 60, 0.08);
      background: rgba(255, 255, 255, 0.86);
    }

    .contact-prayer-info-card.accent,
    .contact-prayer-request-note {
      background: rgba(9, 72, 105, 0.94);
      color: #fff;
      box-shadow: 0 20px 34px rgba(8, 39, 60, 0.14);
    }

    .contact-prayer-info-card span,
    .contact-prayer-verse-card span,
    .contact-prayer-request-note strong {
      display: block;
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
    }

    .contact-prayer-info-card span,
    .contact-prayer-verse-card span {
      color: #7c93a0;
    }

    .contact-prayer-info-card.accent span {
      color: rgba(255, 255, 255, 0.7);
    }

    .contact-prayer-info-card strong {
      display: block;
      margin-top: 10px;
      color: #0d2c43;
      font-size: 1.1rem;
    }

    .contact-prayer-info-card.accent strong {
      color: #fff;
    }

    .contact-prayer-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
      gap: 22px;
      align-items: start;
    }

    .contact-prayer-form-wrap .home-section-head {
      margin-bottom: 18px;
    }

    .contact-prayer-side {
      display: grid;
      gap: 18px;
    }

    .whatsapp-focus-card {
      padding: 28px;
      border-radius: 30px;
      background:
        linear-gradient(155deg, rgba(9, 72, 105, 0.98), rgba(28, 118, 152, 0.93));
      color: #fff;
      box-shadow: 0 24px 42px rgba(8, 39, 60, 0.14);
    }

    .whatsapp-focus-card .section-label,
    .whatsapp-focus-card p {
      color: rgba(255, 255, 255, 0.78);
    }

    .whatsapp-focus-card h2 {
      margin: 14px 0 0;
      color: #fff;
      font-size: clamp(1.8rem, 3vw, 2.35rem);
      line-height: 1.04;
      letter-spacing: -0.05em;
    }

    .whatsapp-focus-card p {
      margin-top: 14px;
      line-height: 1.85;
    }

    .contact-prayer-side-points {
      display: grid;
      gap: 10px;
      margin: 20px 0 26px;
    }

    .contact-prayer-side-points span {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 600;
      color: #fff;
    }

    .contact-prayer-side-points span::before {
      content: '';
      width: 9px;
      height: 9px;
      border-radius: 999px;
      background: #edb53f;
      box-shadow: 0 0 0 6px rgba(237, 181, 63, 0.14);
      flex-shrink: 0;
    }

    .contact-prayer-verse-card p,
    .contact-prayer-request-note p {
      margin-top: 12px;
      line-height: 1.82;
    }

    .contact-prayer-request-shell {
      display: grid;
      grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
      gap: 24px;
      padding: 28px;
    }

    .contact-prayer-wall-note {
      margin-top: 12px;
      max-width: 72ch;
      color: #37566c;
      line-height: 1.78;
    }

    .contact-prayer-wall-stats {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      margin-bottom: 24px;
    }

    .contact-prayer-wall-stat,
    .contact-prayer-wall-card,
    .contact-prayer-wall-empty {
      position: relative;
      overflow: hidden;
      border-radius: 28px;
      border: 1px solid rgba(255, 255, 255, 0.76);
      background: rgba(255, 255, 255, 0.88);
      box-shadow: 0 24px 44px rgba(8, 39, 60, 0.08);
    }

    .contact-prayer-wall-stat {
      padding: 22px 24px;
      background:
        linear-gradient(155deg, rgba(255, 255, 255, 0.96), rgba(231, 243, 248, 0.94));
    }

    .contact-prayer-wall-stat.accent {
      background:
        linear-gradient(155deg, rgba(9, 72, 105, 0.98), rgba(31, 126, 161, 0.92));
      color: #fff;
    }

    .contact-prayer-wall-stat span {
      display: block;
      font-size: 0.76rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #6f8898;
    }

    .contact-prayer-wall-stat.accent span {
      color: rgba(255, 255, 255, 0.74);
    }

    .contact-prayer-wall-stat strong {
      display: block;
      margin-top: 12px;
      font-size: clamp(2rem, 4vw, 2.6rem);
      line-height: 1;
      letter-spacing: -0.05em;
      color: #0d2c43;
    }

    .contact-prayer-wall-stat.accent strong {
      color: #fff;
    }

    .contact-prayer-wall-stat small {
      display: block;
      margin-top: 10px;
      color: #4f6d7e;
      line-height: 1.6;
    }

    .contact-prayer-wall-stat.accent small {
      color: rgba(255, 255, 255, 0.8);
    }

    .contact-prayer-wall-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
      align-items: stretch;
    }

    .contact-prayer-wall-card,
    .contact-prayer-wall-empty {
      padding: 24px;
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }

    .contact-prayer-wall-card::before,
    .contact-prayer-wall-empty::before {
      content: '';
      position: absolute;
      inset: 0;
      pointer-events: none;
      opacity: 0.9;
      background: linear-gradient(160deg, rgba(10, 95, 136, 0.08), transparent 42%);
    }

    .contact-prayer-wall-card-top,
    .contact-prayer-wall-actions {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      flex-wrap: wrap;
    }

    .contact-prayer-wall-country {
      display: inline-flex;
      align-items: center;
      min-height: 38px;
      padding: 8px 14px;
      border-radius: 999px;
      background: rgba(10, 89, 128, 0.08);
      color: #0f5a83;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }

    .contact-prayer-wall-message {
      position: relative;
      z-index: 1;
      margin-top: 18px;
      color: #39586d;
      line-height: 1.85;
      font-size: 1rem;
      flex: 1 1 auto;
    }

    .contact-prayer-wall-actions {
      margin-top: 24px;
    }

    .contact-prayer-wall-count,
    .contact-prayer-wall-button {
      min-height: 48px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }

    .contact-prayer-wall-empty {
      grid-column: 1 / -1;
      padding: 32px;
      align-items: flex-start;
      background:
        linear-gradient(155deg, rgba(255, 255, 255, 0.96), rgba(237, 246, 250, 0.93));
    }

    .contact-prayer-wall-empty h3,
    .contact-prayer-wall-empty p,
    .contact-prayer-wall-empty .prayer-card-label {
      position: relative;
      z-index: 1;
    }

    .contact-prayer-wall-empty h3 {
      margin-top: 18px;
      color: #0d2c43;
      font-size: clamp(1.7rem, 3vw, 2.3rem);
      line-height: 1.06;
      letter-spacing: -0.05em;
    }

    .contact-prayer-wall-empty p {
      margin-top: 16px;
      max-width: 60ch;
      color: #486475;
      line-height: 1.8;
    }

    .contact-prayer-wall-empty .btn-primary-lg {
      position: relative;
      z-index: 1;
      margin-top: 24px;
    }

    @media (max-width: 1024px) {
      .contact-prayer-page {
        padding-top: 176px;
      }

      .contact-prayer-hero-shell,
      .contact-prayer-grid,
      .contact-prayer-request-shell {
        grid-template-columns: 1fr;
      }

      .contact-prayer-wall-stats,
      .contact-prayer-wall-grid {
        grid-template-columns: 1fr 1fr;
      }

      .contact-prayer-wall-empty {
        grid-column: span 2;
      }
    }

    @media (max-width: 768px) {
      .contact-prayer-page {
        padding-top: 146px;
      }

      .contact-prayer-hero-shell,
      .contact-prayer-request-shell,
      .whatsapp-focus-card {
        padding: 22px;
      }

      .contact-prayer-wall-stats,
      .contact-prayer-wall-grid {
        grid-template-columns: 1fr;
      }

      .contact-prayer-wall-empty {
        grid-column: auto;
        padding: 24px;
      }
    }
