@import url(https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;800&family=Inter:wght@400;500;600&family=Space+Grotesk:wght@400;500;600&display=swap);
@charset "UTF-8";
:root {
  --ui-font-heading: "Montserrat", sans-serif;
  --ui-font-body: "Inter", sans-serif;
  --ui-font-label: "Space Grotesk", sans-serif;
  --ui-c-bg-950: #06050f;
  --ui-c-bg-900: #0b0818;
  --ui-c-surface: rgba(16, 10, 30, 0.62);
  --ui-c-text: #ffffff;
  --ui-c-text-soft: rgba(255, 255, 255, 0.72);
  --ui-c-cyan: #00f5ff;
  --ui-c-orange: #ff6b35;
  --ui-c-rose: #ff1493;
  --ui-c-violet: #9d4edd;
  --ui-grad-accent: linear-gradient(98deg, #ff6b35 0%, #ff1493 56%, #9d4edd 100%);
  --ui-grad-cyan-violet: linear-gradient(95deg, #00f5ff 0%, #9d4edd 100%);
  --ui-grad-section-fade: linear-gradient(180deg, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.35) 42%, rgba(0, 0, 0, 0) 100%);
  --ui-radius-sm: 12px;
  --ui-radius-md: 18px;
  --ui-radius-lg: 24px;
  --ui-radius-pill: 9999px;
  --ui-space-2: 8px;
  --ui-space-3: 12px;
  --ui-space-4: 16px;
  --ui-space-5: 20px;
  --ui-space-6: 24px;
  --ui-space-8: 32px;
  --ui-shadow-soft: 0 10px 26px rgba(3, 2, 12, 0.4);
  --ui-shadow-glass: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 16px 34px rgba(2, 1, 9, 0.52);
  --ui-shadow-neon: 0 0 22px rgba(255, 20, 147, 0.28), 0 0 54px rgba(157, 78, 221, 0.2);
}

.ui-container {
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: clamp(14px, 1.2vw, 20px);
}

.ui-section {
  position: relative;
  overflow: hidden;
  padding-block: clamp(52px, 6vw, 86px);
}

.ui-section--fade::before,
.ui-section--fade::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: clamp(72px, 8vw, 132px);
  pointer-events: none;
}

.ui-section--fade::before {
  top: 0;
  background: var(--ui-grad-section-fade);
}

.ui-section--fade::after {
  bottom: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.35) 42%, rgba(0, 0, 0, 0) 100%);
}

.ui-eyebrow {
  display: inline-flex;
  align-items: center;
  border-radius: var(--ui-radius-pill);
  padding: 1px;
  background: var(--ui-grad-accent);
  box-shadow: var(--ui-shadow-neon);
}

.ui-eyebrow__inner {
  display: inline-flex;
  align-items: center;
  border-radius: var(--ui-radius-pill);
  padding: 7px 16px;
  background: rgba(10, 7, 22, 0.84);
  color: rgba(255, 255, 255, 0.94);
  font-family: var(--ui-font-label);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.neon-badge-rail {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.neon-badge-rail__trail {
  position: relative;
  display: flex;
  align-items: center;
}

.neon-badge-rail__blur {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}

.neon-badge-rail__blur--left-soft {
  height: 8px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 107, 53, 0.25) 100%);
  filter: blur(4px);
}

.neon-badge-rail__blur--left-mid {
  height: 3px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 140, 40, 0.55) 100%);
  filter: blur(2px);
}

.neon-badge-rail__blur--right-mid {
  height: 3px;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.55) 0%, rgba(255, 255, 255, 0) 100%);
  filter: blur(2px);
}

.neon-badge-rail__blur--right-soft {
  height: 8px;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.25) 0%, rgba(255, 255, 255, 0) 100%);
  filter: blur(4px);
}

.neon-badge-rail__core {
  width: 70px;
  height: 1.5px;
}

.neon-badge-rail__core--left {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 160, 40, 0.95) 100%);
}

.neon-badge-rail__core--right {
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.95) 0%, rgba(255, 255, 255, 0) 100%);
}

.neon-badge-rail__spark {
  position: relative;
  z-index: 5;
  flex-shrink: 0;
}

.neon-badge-rail__spark-h,
.neon-badge-rail__spark-v {
  position: absolute;
  top: 50%;
  left: 50%;
}

.neon-badge-rail__spark-h {
  width: 22px;
  height: 1.5px;
}

.neon-badge-rail__spark-h--left {
  right: 50%;
  left: auto;
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 200, 80, 0.6) 50%, rgb(255, 255, 255) 100%);
}

.neon-badge-rail__spark-h--right {
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgb(255, 255, 255) 0%, rgba(200, 100, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
}

.neon-badge-rail__spark-v {
  width: 1.5px;
  height: 16px;
  transform: translate(-50%, -50%);
}

.neon-badge-rail__spark-v--left {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 180, 80, 0.5) 30%, rgba(255, 255, 255, 0.9) 50%, rgba(255, 180, 80, 0.5) 70%, rgba(255, 255, 255, 0) 100%);
}

.neon-badge-rail__spark-v--right {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(180, 80, 255, 0.5) 30%, rgba(255, 255, 255, 0.9) 50%, rgba(180, 80, 255, 0.5) 70%, rgba(255, 255, 255, 0) 100%);
}

.neon-badge-rail__spark-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #fff;
}

.neon-badge-rail__spark-dot--left {
  box-shadow: 0 0 4px 2px rgb(255, 210, 80), 0 0 10px 4px rgba(255, 130, 40, 0.95), 0 0 22px 7px rgba(255, 80, 120, 0.65), 0 0 38px 10px rgba(255, 107, 53, 0.4);
}

.neon-badge-rail__spark-dot--right {
  box-shadow: 0 0 4px 2px rgb(210, 100, 255), 0 0 10px 4px rgba(157, 78, 221, 0.95), 0 0 22px 7px rgba(157, 78, 221, 0.65), 0 0 38px 10px rgba(157, 78, 221, 0.4);
}

.neon-badge {
  display: inline-flex;
  flex-shrink: 0;
  background: linear-gradient(95deg, #ff6b35, #9d4edd);
  padding: 2px;
  border-radius: 9999px;
  box-shadow: 0 0 28px rgba(255, 107, 53, 0.8), 0 0 50px rgba(157, 78, 221, 0.6), 0 0 80px rgba(255, 107, 53, 0.3);
}

.neon-badge__inner {
  display: inline-flex;
  align-items: center;
  background: rgba(10, 7, 22, 0.82);
  padding: 12px 32px;
  border-radius: 9999px;
  font-size: 13px;
  letter-spacing: 0.24em;
  color: rgba(255, 255, 255, 0.98);
  font-family: var(--ui-font-heading);
  font-weight: 700;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.neon-badge-rail--compact .neon-badge-rail__core {
  width: 46px;
}

.neon-badge-rail--compact .neon-badge__inner,
.neon-badge--compact .neon-badge__inner {
  padding: 9px 20px;
  font-size: 11px;
  letter-spacing: 0.18em;
}

.neon-badge-rail--compact .neon-badge-rail__spark-h {
  width: 16px;
}

.neon-badge-rail--compact .neon-badge-rail__spark-v {
  height: 12px;
}

@media (max-width: 767px) {
  .neon-badge-rail--compact {
    width: auto;
    max-width: min(100%, 100vw - 24px);
    justify-content: center;
    overflow: visible;
    margin-inline: auto;
  }
}
.ui-title {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-weight: 700;
  font-size: clamp(28px, 2.2vw, 40px);
  line-height: 1.14;
  letter-spacing: -0.012em;
  color: var(--ui-c-text);
  text-shadow: 0 3px 14px rgba(0, 0, 0, 0.52);
}

.ui-title-accent {
  background: var(--ui-grad-accent);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.ui-lead {
  margin: 0;
  font-family: var(--ui-font-body);
  font-size: clamp(15px, 1vw, 18px);
  line-height: 1.55;
  color: var(--ui-c-text-soft);
}

.ui-card {
  border-radius: var(--ui-radius-md);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: var(--ui-c-surface);
  box-shadow: var(--ui-shadow-soft);
}

.ui-card--glass {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--ui-shadow-glass);
}

.ui-card--featured {
  border-color: rgba(255, 20, 147, 0.58);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 0 1px rgba(255, 20, 147, 0.4), var(--ui-shadow-neon);
}

.ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: var(--ui-radius-pill);
  border: 1px solid transparent;
  padding: 12px 22px;
  font-family: var(--ui-font-heading);
  font-weight: 700;
  text-decoration: none;
  transition: transform 220ms ease, filter 220ms ease, box-shadow 220ms ease;
}

.ui-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

.ui-btn--primary {
  color: #fff;
  background: var(--ui-grad-accent);
  border-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 0 20px rgba(255, 107, 53, 0.35), 0 0 36px rgba(255, 20, 147, 0.3);
}

.ui-btn--ghost {
  color: rgba(255, 255, 255, 0.94);
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.26);
}

.ui-grid {
  display: grid;
  gap: var(--ui-space-4);
}

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

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

.ui-stack {
  display: flex;
  flex-direction: column;
  gap: var(--ui-space-4);
}

@media (max-width: 1023px) {
  .ui-grid--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .ui-title {
    font-size: clamp(24px, 7.2vw, 34px);
  }
  .ui-btn {
    width: 100%;
  }
  .ui-grid--2,
  .ui-grid--3 {
    grid-template-columns: 1fr;
  }
}
.stat-card {
  --sc-c1: 157, 78, 221;
  --sc-c2: 157, 78, 221;
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  padding: 18px;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(10, 5, 22, 0.42);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  box-shadow: none;
}
.stat-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.95) 12%, rgba(255, 40, 80, 0.7) 28%, rgba(var(--sc-c1), 0.6) 50%, rgba(var(--sc-c2), 0.45) 75%, rgba(var(--sc-c1), 0.35) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
}
.stat-card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 19px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 18px 6px rgba(var(--sc-c1), 0.6), 0 0 40px 16px rgba(var(--sc-c1), 0.38), 0 0 80px 32px rgba(var(--sc-c1), 0.2), 0 0 130px 55px rgba(var(--sc-c1), 0.09);
}

.stat-card__glow {
  display: none;
}

.stat-card__hotspot {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  box-shadow: 0 0 8px 4px rgba(var(--sc-c1), 0.95), 0 0 20px 9px rgba(var(--sc-c1), 0.7), 0 0 40px 16px rgba(var(--sc-c1), 0.4), 0 0 70px 28px rgba(var(--sc-c1), 0.18);
}

.stat-card__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
}

.stat-card__value {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(30px, 2.4vw, 40px);
  line-height: 1;
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, rgb(var(--sc-c1)) 30%, #ffffff) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 12px rgba(var(--sc-c1), 0.5)) drop-shadow(0 2px 6px rgba(0, 0, 0, 0.9));
}

.stat-card__label {
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 1.1vw, 16px);
  line-height: 1.45;
  letter-spacing: 0.01em;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92) 0%, color-mix(in srgb, rgb(var(--sc-c1)) 18%, rgba(255, 255, 255, 0.85)) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 8px rgba(var(--sc-c1), 0.28)) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.85));
}

.stat-card--cyan {
  --sc-c1: 0, 245, 255;
  --sc-c2: 0, 200, 255;
}

.stat-card--orange {
  --sc-c1: 255, 107, 53;
  --sc-c2: 255, 179, 71;
}

.stat-card--rose {
  --sc-c1: 255, 20, 147;
  --sc-c2: 255, 0, 110;
}

.stat-card--violet {
  --sc-c1: 157, 78, 221;
  --sc-c2: 120, 50, 200;
}

.stat-card--gold {
  --sc-c1: 255, 179, 71;
  --sc-c2: 255, 210, 100;
}

.hero-title {
  --ht-size: clamp(32px, 3.8vw, 58px);
  --ht-from: #ff6b35;
  --ht-to: #ff1493;
  font-size: var(--ht-size);
  line-height: 1.1;
  letter-spacing: -0.022em;
  display: block;
  margin: 0;
  padding: 0;
}

.hero-title__straight {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-style: normal;
  color: #ffffff;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9), 0 0 30px rgba(255, 255, 255, 0.06);
}

.hero-title__soft {
  font-family: Montserrat, sans-serif;
  font-weight: 400;
  font-style: italic;
  color: rgba(255, 255, 255, 0.82);
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}

.hero-title__accent {
  display: inline-block;
  overflow: visible;
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-style: italic;
  background: linear-gradient(105deg, var(--ht-from) 0%, color-mix(in srgb, var(--ht-from) 40%, var(--ht-to)) 48%, var(--ht-to) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--ht-from) 65%, var(--ht-to))) drop-shadow(0 0 26px color-mix(in srgb, var(--ht-from) 30%, var(--ht-to))) drop-shadow(0 2px 6px rgba(0, 0, 0, 0.85));
  padding: 0 0.05em 0 0;
}

.hero-title--soft-glow .hero-title__accent {
  filter: drop-shadow(0 0 6px rgba(255, 107, 53, 0.42)) drop-shadow(0 0 14px rgba(157, 78, 221, 0.28)) drop-shadow(0 2px 5px rgba(0, 0, 0, 0.82));
}

@media (max-width: 640px) {
  .hero-title {
    line-height: 1.14;
    letter-spacing: -0.018em;
  }
}
.catalogue-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 80px 24px 56px;
  position: relative;
  z-index: 1;
}

.catalogue-header__badge-wrap {
  margin-bottom: 28px;
}

.catalogue-header__badge-component {
  align-self: center;
}

.catalogue-header__hero-title {
  margin-bottom: 18px;
  white-space: nowrap;
}

.catalogue-header__subtitle {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #a0a0b0;
  line-height: 1.6;
  margin-bottom: 40px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
  max-width: 700px;
}

.catalogue-header__search-wrap {
  width: 100%;
  max-width: 820px;
  min-width: 0;
  box-sizing: border-box;
}

.catalogue-header__search {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  height: 58px;
  padding: 0 8px 0 22px;
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.13);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.06);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
  min-width: 0;
  box-sizing: border-box;
}
.catalogue-header__search:focus-within {
  border-color: rgba(255, 107, 53, 0.55);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.35), 0 0 20px rgba(255, 107, 53, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.catalogue-header__search-icon {
  flex-shrink: 0;
  opacity: 0.6;
  transition: opacity 0.2s ease;
}
.catalogue-header__search:focus-within .catalogue-header__search-icon {
  opacity: 1;
  stroke: #ff6b35;
}

.catalogue-header__search-input {
  flex: 1;
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
  background: transparent;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 15px;
  color: #ffffff;
  caret-color: #ff6b35;
  -webkit-tap-highlight-color: transparent;
}
.catalogue-header__search-input::-moz-placeholder {
  color: #6a6a7a;
}
.catalogue-header__search-input::placeholder {
  color: #6a6a7a;
}
.catalogue-header__search-input:focus, .catalogue-header__search-input:focus-visible, .catalogue-header__search-input:active {
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
  outline-color: transparent !important;
}

.catalogue-header__search-sep {
  width: 1px;
  height: 26px;
  background: rgba(255, 255, 255, 0.12);
  flex-shrink: 0;
}

.catalogue-header__search-btn {
  flex-shrink: 0;
  height: 42px;
  padding: 0 26px;
  min-height: 42px;
  font-size: 14px;
  letter-spacing: 0.03em;
  border-radius: 40px;
}

@media (max-width: 768px) {
  .catalogue-header {
    padding: 56px 20px 40px;
  }
  .catalogue-header__badge-wrap {
    margin-bottom: 40px;
  }
  .catalogue-header__hero-title {
    margin-bottom: 30px;
  }
  .catalogue-header__subtitle {
    margin-bottom: 56px;
    line-height: 1.7;
  }
  .catalogue-header__search {
    height: 52px;
    padding: 0 6px 0 16px;
    gap: 8px;
  }
  .catalogue-header__search-btn {
    flex-shrink: 0;
    min-width: 0;
    white-space: nowrap;
    padding: 0 18px;
    font-size: 13px;
  }
  .catalogue-header__search-sep {
    display: none;
  }
  .catalogue-header__hero-title {
    white-space: normal;
  }
}
.catalogue-domains {
  width: 100%;
  padding: 0 24px 48px;
}

.catalogue-domains__track {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 1100px) {
  .catalogue-domains__track {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 560px) {
  .catalogue-domains__track {
    grid-template-columns: repeat(2, 1fr);
  }
}

.domain-card {
  --dc-rgb: var(--domain-rgb);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  background: rgba(10, 5, 22, 0.52);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  padding: 0;
  text-align: left;
  border: none;
  box-shadow: none;
  transition: transform 0.22s ease;
}
.domain-card:not(.domain-card--active) {
  opacity: 0.82;
}
.domain-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.95) 10%, rgba(255, 40, 80, 0.65) 22%, rgba(var(--dc-rgb), 0.7) 38%, rgba(var(--dc-rgb), 0.35) 62%, rgba(var(--dc-rgb), 0.18) 80%, rgba(var(--dc-rgb), 0.08) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
  opacity: 0.7;
  transition: opacity 0.28s ease;
}
.domain-card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 17px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 18px 6px rgba(var(--dc-rgb), 0.6), 0 0 40px 16px rgba(var(--dc-rgb), 0.38), 0 0 80px 32px rgba(var(--dc-rgb), 0.2), 0 0 130px 55px rgba(var(--dc-rgb), 0.09);
  opacity: 0.18;
  transition: opacity 0.28s ease, box-shadow 0.28s ease;
}
.domain-card__bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% -20%, rgba(var(--dc-rgb), 0.09) 0%, transparent 65%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.28s ease;
  z-index: 0;
}
.domain-card:hover:not(.domain-card--active) {
  transform: translateY(-3px);
  opacity: 0.96;
}
.domain-card:hover:not(.domain-card--active)::before {
  opacity: 1;
}
.domain-card:hover:not(.domain-card--active)::after {
  opacity: 0.55;
  box-shadow: 0 0 22px 8px rgba(var(--dc-rgb), 0.72), 0 0 50px 20px rgba(var(--dc-rgb), 0.44), 0 0 95px 36px rgba(var(--dc-rgb), 0.24), 0 0 150px 58px rgba(var(--dc-rgb), 0.11);
}
.domain-card:hover:not(.domain-card--active) .domain-card__hotspot {
  opacity: 0.75;
}
.domain-card:hover:not(.domain-card--active) .domain-card__icon-wrap svg {
  filter: drop-shadow(0 0 6px rgba(var(--dc-rgb), 0.9)) drop-shadow(0 0 12px rgba(var(--dc-rgb), 0.5));
}
.domain-card:hover:not(.domain-card--active) .domain-card__icon-wrap i {
  filter: drop-shadow(0 0 6px rgba(var(--dc-rgb), 0.9)) drop-shadow(0 0 12px rgba(var(--dc-rgb), 0.5));
}
.domain-card:hover:not(.domain-card--active) .domain-card__label {
  color: var(--domain-color);
}
.domain-card--active {
  opacity: 1;
  transform: translateY(-3px) scale(1.015);
  background: linear-gradient(165deg, rgba(20, 14, 38, 0.96) 0%, rgba(12, 10, 28, 0.98) 100%);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 0 2px rgba(var(--dc-rgb), 0.34), 0 0 22px rgba(var(--dc-rgb), 0.5), 0 0 44px rgba(var(--dc-rgb), 0.24);
}
.domain-card--active::before {
  opacity: 1;
  background: linear-gradient(145deg, rgb(255, 140, 50) 0%, rgba(255, 90, 60, 0.98) 10%, rgba(255, 50, 90, 0.8) 22%, rgba(var(--dc-rgb), 0.95) 38%, rgba(var(--dc-rgb), 0.6) 62%, rgba(var(--dc-rgb), 0.3) 80%, rgba(var(--dc-rgb), 0.12) 100%);
}
.domain-card--active::after {
  opacity: 1;
  box-shadow: 0 0 26px 10px rgba(var(--dc-rgb), 0.82), 0 0 56px 22px rgba(var(--dc-rgb), 0.52), 0 0 104px 36px rgba(var(--dc-rgb), 0.28), 0 0 165px 62px rgba(var(--dc-rgb), 0.14);
}
.domain-card--active .domain-card__hotspot {
  opacity: 1;
  box-shadow: 0 0 8px 4px rgba(var(--dc-rgb), 0.95), 0 0 20px 9px rgba(var(--dc-rgb), 0.7), 0 0 40px 16px rgba(var(--dc-rgb), 0.4), 0 0 70px 28px rgba(var(--dc-rgb), 0.18);
}
.domain-card--active .domain-card__icon-wrap svg {
  filter: drop-shadow(0 0 8px rgba(var(--dc-rgb), 1)) drop-shadow(0 0 16px rgba(var(--dc-rgb), 0.6));
}
.domain-card--active .domain-card__icon-wrap i {
  filter: drop-shadow(0 0 8px rgba(var(--dc-rgb), 1)) drop-shadow(0 0 16px rgba(var(--dc-rgb), 0.6));
}
.domain-card--active .domain-card__label {
  background: linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, rgb(var(--dc-rgb)) 40%, #ffffff) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 10px rgba(var(--dc-rgb), 0.6)) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.9));
}
.domain-card--active .domain-card__count {
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 0 10px rgba(var(--dc-rgb), 0.32);
}

.domain-card__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  opacity: 0.3;
  box-shadow: 0 0 8px 4px rgba(var(--dc-rgb), 0.95), 0 0 20px 9px rgba(var(--dc-rgb), 0.7), 0 0 40px 16px rgba(var(--dc-rgb), 0.4), 0 0 70px 28px rgba(var(--dc-rgb), 0.18);
  transition: opacity 0.28s ease, box-shadow 0.28s ease;
}

.domain-card__inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 16px 18px;
}

.domain-card__icon-wrap {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  color: var(--domain-color);
}
.domain-card__icon-wrap svg {
  width: 100%;
  height: 100%;
  display: block;
  stroke: currentColor;
  filter: drop-shadow(0 0 4px rgba(var(--dc-rgb), 0.6)) drop-shadow(0 0 8px rgba(var(--dc-rgb), 0.3));
  transition: filter 0.28s ease;
}
.domain-card__icon-wrap i {
  width: 100%;
  height: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  line-height: 1;
  color: currentColor;
  filter: drop-shadow(0 0 4px rgba(var(--dc-rgb), 0.6)) drop-shadow(0 0 8px rgba(var(--dc-rgb), 0.3));
  transition: filter 0.28s ease;
}

.domain-card__text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.domain-card__label {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: #E8E8F0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.9);
  transition: color 0.28s ease, filter 0.28s ease;
  -webkit-text-fill-color: unset;
  background: none;
}

.domain-card--active .domain-card__label {
  text-shadow: none;
}

.domain-card__count {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: rgba(214, 214, 234, 0.8);
  white-space: nowrap;
  letter-spacing: 0.02em;
  text-shadow: 0 0 6px rgba(var(--dc-rgb), 0.14), 0 1px 2px rgba(0, 0, 0, 0.55);
}

@media (max-width: 1100px) {
  .domain-card__inner {
    padding: 14px 14px 16px;
  }
}
@media (max-width: 560px) {
  .domain-card__inner {
    gap: 10px;
    padding: 14px 12px 16px;
  }
  .domain-card__label {
    font-size: 12px;
  }
  .domain-card__count {
    font-size: 11.5px;
  }
}
.catalogue-filters {
  width: 100%;
  padding: 0 24px 36px;
  position: relative;
  z-index: 2;
}

.catalogue-filters__mobile-overlay,
.catalogue-filters__mobile-toggle,
.catalogue-filters__mobile-head,
.catalogue-filters__apply {
  display: none;
}

.catalogue-filters__wrap {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.catalogue-filters__row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.catalogue-filters__row--subcats {
  justify-content: space-between;
  gap: 12px;
}

.catalogue-filters__row--secondary {
  flex-wrap: wrap;
  gap: 10px;
}

.catalogue-filters__count {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: #6A6A7A;
  white-space: nowrap;
  flex-shrink: 0;
}

.catalogue-filters__count-num {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #FFFFFF;
  margin-right: 4px;
}

.catalogue-filters__sep {
  width: 1px;
  height: 20px;
  background: rgba(255, 255, 255, 0.1);
  flex-shrink: 0;
  margin: 0 4px;
}

.catalogue-filters__pills {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.filter-pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 40px;
  padding: 0 18px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  white-space: nowrap;
  transition: transform 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  background: rgba(255, 255, 255, 0.06);
  color: #BFC5DC;
}
.filter-pill::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1px;
  background: linear-gradient(145deg, rgba(255, 120, 40, 0.62) 0%, rgba(255, 40, 80, 0.38) 25%, rgba(157, 78, 221, 0.28) 60%, rgba(157, 78, 221, 0.12) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0.72;
  transition: opacity 0.2s ease;
}
.filter-pill::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 51px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 12px 3px rgba(157, 78, 221, 0.2), 0 0 26px 7px rgba(157, 78, 221, 0.1);
  opacity: 0.28;
  transition: opacity 0.2s ease;
}
.filter-pill:hover:not(.filter-pill--active) {
  color: #FFFFFF;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(8, 4, 24, 0.22);
}
.filter-pill:hover:not(.filter-pill--active)::before {
  opacity: 1;
}
.filter-pill:hover:not(.filter-pill--active)::after {
  opacity: 1;
}
.filter-pill--active {
  background: linear-gradient(90deg, #FF6B35 0%, #FF1493 100%);
  color: #FFFFFF;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
  box-shadow: 0 10px 22px rgba(8, 4, 20, 0.26);
}
.filter-pill--active::before {
  background: linear-gradient(145deg, rgb(255, 180, 80) 0%, rgba(255, 100, 60, 0.9) 30%, rgba(255, 20, 147, 0.7) 70%, rgba(255, 0, 110, 0.4) 100%);
  opacity: 1;
}
.filter-pill--active::after {
  box-shadow: 0 0 14px 4px rgba(255, 107, 53, 0.55), 0 0 32px 10px rgba(255, 20, 147, 0.3), 0 0 60px 20px rgba(255, 107, 53, 0.12);
  opacity: 1;
}

.filter-pill--ghost {
  background: rgba(0, 245, 255, 0.1);
  color: rgba(215, 248, 255, 0.98);
}
.filter-pill--ghost::before {
  background: linear-gradient(145deg, rgba(0, 245, 255, 0.72) 0%, rgba(157, 78, 221, 0.42) 100%);
  opacity: 0.75;
}
.filter-pill--ghost::after {
  opacity: 1;
  box-shadow: 0 0 12px 3px rgba(0, 245, 255, 0.16), 0 0 24px 8px rgba(157, 78, 221, 0.1);
}

.filter-pill__check {
  flex-shrink: 0;
  stroke: #FFFFFF;
  position: relative;
  z-index: 2;
}

.filter-pill__icon {
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  opacity: 0.9;
}

.filter-pill__count {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  border-radius: 9999px;
  padding: 0 6px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 11px;
  color: rgba(5, 24, 36, 0.96);
  background: linear-gradient(135deg, rgba(0, 245, 255, 0.95) 0%, rgba(170, 115, 255, 0.95) 100%);
  box-shadow: 0 0 10px rgba(0, 245, 255, 0.28);
}

.catalogue-subcat-picker {
  position: fixed;
  inset: 0;
  z-index: 2147483000 !important;
  pointer-events: none;
}

.catalogue-filters.is-subcat-picker-open {
  z-index: 2147482999 !important;
  isolation: isolate;
}

body.catalogue-subcat-picker-open .formation-catalogue > .ui-container {
  z-index: 1 !important;
}

.catalogue-subcat-picker[hidden] {
  display: none !important;
}

.catalogue-subcat-picker__overlay {
  display: block;
  position: fixed;
  inset: 0;
  border: 0;
  background: rgba(3, 3, 10, 0.62);
  z-index: 2147483001 !important;
  pointer-events: auto;
}

.catalogue-subcat-picker__panel {
  position: fixed;
  top: clamp(88px, 12vh, 132px);
  left: 50%;
  width: min(760px, 100vw - 48px);
  max-height: min(72vh, 760px);
  transform: translateX(-50%);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(180deg, rgba(17, 10, 33, 0.98) 0%, rgba(10, 7, 23, 0.99) 100%);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.55), 0 0 35px rgba(157, 78, 221, 0.22);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 2147483002 !important;
  pointer-events: auto;
}

.catalogue-subcat-picker__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.catalogue-subcat-picker__head p {
  margin: 0;
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.9);
}

.catalogue-subcat-picker__close {
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 9999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.8);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.catalogue-subcat-picker__search-wrap {
  padding-top: 2px;
}

.catalogue-subcat-picker__search {
  width: 100%;
  height: 40px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  padding: 0 12px;
  font-family: "Inter", sans-serif;
  font-size: 14px;
}

.catalogue-subcat-picker__list {
  overflow: auto;
  max-height: min(58vh, 560px);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding-right: 2px;
}

.catalogue-subcat-picker__item {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.03);
  padding: 10px 11px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
}
.catalogue-subcat-picker__item span {
  font-family: "Montserrat", sans-serif;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.92);
}
.catalogue-subcat-picker__item small {
  font-family: "Inter", sans-serif;
  font-size: 12px;
  color: rgba(184, 197, 228, 0.8);
}
.catalogue-subcat-picker__item:hover {
  border-color: rgba(0, 245, 255, 0.42);
  box-shadow: 0 0 12px rgba(0, 245, 255, 0.16);
}

.filter-select-wrap {
  position: relative;
  z-index: 6;
}

.filter-select {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 16px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #D0D2E4;
  background: rgba(255, 255, 255, 0.06);
  transition: color 0.2s ease, transform 0.2s ease;
}
.filter-select::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1px;
  background: linear-gradient(145deg, rgba(255, 120, 40, 0.58) 0%, rgba(255, 40, 80, 0.34) 25%, rgba(157, 78, 221, 0.24) 60%, rgba(157, 78, 221, 0.1) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0.72;
  transition: opacity 0.2s ease;
}
.filter-select::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 51px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 12px 3px rgba(255, 107, 53, 0.24), 0 0 28px 8px rgba(255, 107, 53, 0.12);
  opacity: 0.2;
  transition: opacity 0.2s ease;
}
.filter-select svg {
  flex-shrink: 0;
  stroke: currentColor;
  opacity: 0.6;
}
.filter-select:hover {
  color: #FFFFFF;
  transform: translateY(-1px);
}
.filter-select:hover::before {
  opacity: 1;
}
.filter-select:hover::after {
  opacity: 1;
}
.filter-select:hover svg {
  opacity: 1;
}
.filter-select[aria-expanded=true] {
  color: #FF6B35;
}
.filter-select[aria-expanded=true]::before {
  opacity: 1;
}
.filter-select[aria-expanded=true] .filter-select__caret {
  transform: rotate(180deg);
}

.filter-select__label {
  position: relative;
  z-index: 2;
}

.filter-select__caret {
  position: relative;
  z-index: 2;
  opacity: 0.7;
  transition: transform 0.2s ease;
}

.filter-select__menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 210px;
  padding: 6px;
  border-radius: 12px;
  background: #110c22;
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.45), 0 0 24px rgba(157, 78, 221, 0.16);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  opacity: 0;
  transform: translateY(-6px) scale(0.985);
  transform-origin: top left;
  will-change: opacity, transform;
  transition: opacity 180ms ease, transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.filter-select-wrap.is-open .filter-select__menu {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (min-width: 769px) {
  .catalogue-filters {
    position: relative;
    z-index: 60;
  }
  .catalogue-filters__wrap,
  .catalogue-filters__row,
  .catalogue-filters__row--secondary,
  .filter-select-wrap {
    overflow: visible;
  }
  .filter-select-wrap.is-open {
    z-index: 80;
  }
  .filter-select-wrap.is-open .filter-select__menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    width: min(260px, 90vw);
    margin-top: 0;
    z-index: 90;
  }
}
.filter-select__option {
  display: block;
  width: 100%;
  text-align: left;
  border: none;
  background: transparent;
  color: #d5d5e4;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  border-radius: 8px;
  padding: 8px 10px;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease;
}
.filter-select__option:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
}
.filter-select__option.is-active {
  background: linear-gradient(90deg, rgba(255, 107, 53, 0.22) 0%, rgba(255, 20, 147, 0.2) 100%);
  color: #ffffff;
}

.filter-toggle-wrap {
  display: flex;
  align-items: center;
}

.filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  height: 40px;
  padding: 0 16px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.04);
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: #BFC5DC;
  position: relative;
  transition: color 0.25s ease, transform 0.2s ease;
}
.filter-toggle::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1px;
  background: linear-gradient(145deg, rgba(255, 120, 40, 0.5) 0%, rgba(255, 40, 80, 0.28) 25%, rgba(157, 78, 221, 0.18) 60%, rgba(157, 78, 221, 0.06) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0.72;
  transition: opacity 0.25s ease;
}
.filter-toggle::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 51px;
  pointer-events: none;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.filter-toggle--active {
  color: #FFFFFF;
}
.filter-toggle--active::before {
  opacity: 1;
}
.filter-toggle--active::after {
  box-shadow: 0 0 14px 4px rgba(255, 107, 53, 0.45), 0 0 32px 10px rgba(255, 20, 147, 0.22), 0 0 60px 20px rgba(255, 107, 53, 0.1);
  opacity: 1;
}

.filter-toggle__track {
  position: relative;
  width: 34px;
  height: 19px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.12);
  flex-shrink: 0;
  transition: background 0.25s ease, box-shadow 0.25s ease;
  z-index: 2;
}
.filter-toggle--active .filter-toggle__track {
  background: linear-gradient(90deg, #FF6B35, #FF1493);
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.6);
}

.filter-toggle__thumb {
  position: absolute;
  top: 2.5px;
  left: 3px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #FFFFFF;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
  transition: transform 0.25s ease;
}
.filter-toggle--active .filter-toggle__thumb {
  transform: translateX(15px);
}

.filter-toggle__label {
  position: relative;
  z-index: 2;
}

.filter-reset {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 34px;
  padding: 0 12px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  background: transparent;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #50506A;
  transition: color 0.2s ease;
}
.filter-reset svg {
  stroke: currentColor;
  transition: transform 0.3s ease;
}
.filter-reset:hover {
  color: #FF6B35;
}
.filter-reset:hover svg {
  transform: rotate(-180deg);
}

@media (max-width: 768px) {
  body.catalogue-filters-open {
    overflow: auto;
  }
  .catalogue-filters {
    padding: 0 14px 26px;
  }
  .catalogue-filters.is-mobile-open {
    z-index: 12002;
  }
  .catalogue-filters__wrap {
    gap: 10px;
  }
  .catalogue-filters__row--subcats {
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 8px;
    padding-block: 4px;
    overflow: visible;
  }
  .catalogue-filters__pills {
    flex-wrap: wrap;
    overflow: visible;
    width: 100%;
    padding-bottom: 0;
    gap: 9px;
    padding-block: 3px;
  }
  .catalogue-filters__mobile-toggle {
    display: none !important;
  }
  .catalogue-filters__count {
    display: none;
  }
  .catalogue-filters__mobile-count {
    min-width: 18px;
    height: 18px;
    border-radius: 9999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
    font-size: 11px;
    font-weight: 700;
    color: #050210;
    background: #fff;
  }
  .filter-pill {
    flex: 0 1 auto;
    min-height: 40px;
    height: 40px;
    padding: 0 15px;
    font-size: 14px;
    overflow: visible;
  }
  .catalogue-filters__row--secondary {
    position: static;
    z-index: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 0;
    border-radius: 0;
    background: transparent;
    border-top: 0;
    box-shadow: none;
    transform: none;
    opacity: 1;
    pointer-events: auto;
    transition: none;
    max-height: none;
    overflow: visible;
    overscroll-behavior: auto;
  }
  .catalogue-filters__mobile-head {
    display: none !important;
  }
  .catalogue-filters__mobile-head p {
    margin: 0;
    color: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 16px;
    font-weight: 700;
  }
  .catalogue-filters__mobile-close {
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    font-size: 24px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
  }
  .filter-select-wrap,
  .filter-select {
    width: 100%;
  }
  .filter-select-wrap {
    position: relative;
  }
  .filter-select-wrap.is-open {
    z-index: auto;
  }
  .filter-select {
    height: 44px;
    justify-content: space-between;
    font-size: 14px;
    padding: 0 16px;
  }
  .filter-select__menu {
    position: static;
    top: auto;
    left: auto;
    right: auto;
    min-width: 0;
    width: 100%;
    margin-top: 8px;
    max-height: min(44vh, 320px);
    overflow-y: auto;
    overscroll-behavior: contain;
    border-radius: 10px;
    background: #110c22;
    transform: translateY(-4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease, transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
    z-index: auto;
  }
  .filter-select-wrap.is-open .filter-select__menu {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .catalogue-filters__sep {
    display: none;
  }
  .filter-reset,
  .catalogue-filters__apply {
    width: 100%;
    justify-content: center;
    min-height: 42px;
    border-radius: 12px;
    font-size: 14px;
  }
  .filter-reset {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.82);
  }
  .catalogue-filters__apply {
    display: none !important;
  }
  .catalogue-filters__mobile-overlay {
    display: none !important;
  }
  .catalogue-filters.is-mobile-open .catalogue-filters__mobile-overlay {
    opacity: 0;
    pointer-events: none;
  }
  .catalogue-filters.is-mobile-open .catalogue-filters__row--secondary {
    opacity: 1;
    pointer-events: auto;
  }
  .catalogue-subcat-picker__panel {
    position: fixed;
    width: calc(100vw - 16px);
    max-height: calc(100dvh - 92px);
    bottom: 8px;
    left: 50%;
    top: auto;
    transform: translateX(-50%);
    border-radius: 14px;
    z-index: 20042;
  }
  .catalogue-subcat-picker {
    z-index: 2147483000 !important;
  }
  .catalogue-subcat-picker__overlay {
    z-index: 2147483001 !important;
  }
  .catalogue-subcat-picker__list {
    grid-template-columns: 1fr;
    max-height: calc(100dvh - 210px);
  }
}
.catalogue-banner {
  position: relative;
  display: flex;
  align-items: center;
  gap: 28px;
  max-width: 1200px;
  margin: 40px auto 0;
  padding: 24px 36px;
  border-radius: 18px;
  background: rgba(10, 5, 22, 0.52);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  overflow: hidden;
  background-image: radial-gradient(ellipse at 0% 50%, rgba(255, 107, 53, 0.06) 0%, transparent 60%);
}
.catalogue-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.9) 10%, rgba(255, 40, 80, 0.6) 22%, rgba(0, 245, 255, 0.6) 42%, rgba(0, 245, 255, 0.25) 65%, rgba(0, 245, 255, 0.08) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
}
.catalogue-banner::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 19px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 18px 6px rgba(0, 245, 255, 0.18), 0 0 40px 16px rgba(0, 245, 255, 0.1), 0 0 80px 32px rgba(0, 245, 255, 0.05);
}
@media (max-width: 768px) {
  .catalogue-banner {
    flex-direction: column;
    text-align: center;
    gap: 20px;
    padding: 24px 20px;
    margin: 32px 24px 0;
  }
}

.catalogue-banner__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  box-shadow: 0 0 8px 4px rgba(0, 245, 255, 0.95), 0 0 20px 9px rgba(0, 245, 255, 0.7), 0 0 40px 16px rgba(0, 245, 255, 0.4), 0 0 70px 28px rgba(0, 245, 255, 0.18);
}

.catalogue-banner__icon {
  position: relative;
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 245, 255, 0.08);
  border: 1px solid rgba(0, 245, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 14px rgba(0, 245, 255, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.catalogue-banner__icon svg {
  filter: drop-shadow(0 0 6px rgba(0, 245, 255, 0.8));
}

.catalogue-banner__icon-pulse {
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 1.5px solid rgba(0, 245, 255, 0.4);
  animation: bannerPulse 2.2s ease-out infinite;
  pointer-events: none;
}

@keyframes bannerPulse {
  0% {
    transform: scale(1);
    opacity: 0.7;
  }
  70% {
    transform: scale(1.35);
    opacity: 0;
  }
  100% {
    transform: scale(1.35);
    opacity: 0;
  }
}
.catalogue-banner__content {
  flex: 1;
  min-width: 0;
}

.catalogue-banner__title {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #FFFFFF;
  margin-bottom: 5px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
}

.catalogue-banner__subtitle {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #80809A;
  line-height: 1.5;
}

.catalogue-banner__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .catalogue-banner__actions {
    flex-direction: column;
    width: 100%;
  }
}

.catalogue-banner__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 44px;
  padding: 0 22px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
  transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease;
}
.catalogue-banner__btn svg {
  flex-shrink: 0;
}
.catalogue-banner__btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.1);
}
.catalogue-banner__btn:active {
  transform: translateY(0);
  filter: brightness(0.96);
}
@media (max-width: 768px) {
  .catalogue-banner__btn {
    width: 100%;
    justify-content: center;
  }
}
.catalogue-banner__btn--primary {
  background: linear-gradient(90deg, #00F5FF 0%, #9D4EDD 100%);
  color: #0A0A0F;
  text-shadow: none;
  box-shadow: 0 4px 20px rgba(0, 245, 255, 0.35);
}
.catalogue-banner__btn--primary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.6) 0%, rgba(0, 245, 255, 0.3) 50%, rgba(157, 78, 221, 0.2) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.catalogue-banner__btn--primary:hover {
  box-shadow: 0 6px 28px rgba(0, 245, 255, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.2);
}
.catalogue-banner__btn--secondary {
  background: rgba(255, 255, 255, 0.05);
  color: #FFFFFF;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.catalogue-banner__btn--secondary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgba(255, 120, 40, 0.7) 0%, rgba(255, 40, 80, 0.4) 25%, rgba(0, 245, 255, 0.5) 60%, rgba(0, 245, 255, 0.15) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.catalogue-banner__btn--secondary::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 51px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 14px 4px rgba(0, 245, 255, 0.2), 0 0 30px 10px rgba(0, 245, 255, 0.08);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.catalogue-banner__btn--secondary:hover::after {
  opacity: 1;
}

.catalogue-floating {
  position: fixed !important;
  bottom: max(16px, env(safe-area-inset-bottom, 0px)) !important;
  right: max(16px, env(safe-area-inset-right, 0px)) !important;
  left: auto !important;
  top: auto !important;
  inset-inline-end: max(16px, env(safe-area-inset-right, 0px)) !important;
  inset-inline-start: auto !important;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  animation: floatingEntrance 0.55s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  animation-delay: 0.8s;
  transition: opacity 0.26s ease, transform 0.26s ease;
  max-width: calc(100vw - 20px);
  pointer-events: none;
}

.catalogue-floating--near-footer {
  animation: none;
  opacity: 0 !important;
  visibility: hidden;
  transform: translateY(22px) scale(0.98) !important;
  pointer-events: none !important;
}

@keyframes floatingEntrance {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.92);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.catalogue-floating__panel {
  position: relative;
  width: min(280px, 100vw - 32px);
  background: rgba(10, 5, 22, 0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 18px;
  padding: 20px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  opacity: 0;
  transform: translateY(10px) scale(0.97);
  pointer-events: none;
  transition: opacity 0.28s cubic-bezier(0.34, 1.56, 0.64, 1), transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.catalogue-floating__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.9) 10%, rgba(255, 40, 80, 0.6) 22%, rgba(0, 245, 255, 0.7) 42%, rgba(0, 245, 255, 0.3) 65%, rgba(0, 245, 255, 0.1) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
}
.catalogue-floating__panel::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 19px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 10px 3px rgba(0, 245, 255, 0.22), 0 0 20px 7px rgba(0, 245, 255, 0.12);
}
.catalogue-floating--open .catalogue-floating__panel {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.catalogue-floating__panel-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.06);
  color: #70708A;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, color 0.2s ease;
  z-index: 3;
}
.catalogue-floating__panel-close:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #FFFFFF;
}

.catalogue-floating__panel-header {
  padding-right: 24px;
}

.catalogue-floating__panel-title {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #FFFFFF;
  margin-bottom: 3px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
}

.catalogue-floating__panel-sub {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #70708A;
}

.catalogue-floating__panel-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalogue-floating__field {
  position: relative;
}

.catalogue-floating__input {
  width: 100%;
  height: 42px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: #FFFFFF;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 13px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  caret-color: #FF6B35;
  box-sizing: border-box;
}
.catalogue-floating__input::-moz-placeholder {
  color: #50506A;
}
.catalogue-floating__input::placeholder {
  color: #50506A;
}
.catalogue-floating__input:focus {
  border-color: rgba(0, 245, 255, 0.45);
  box-shadow: 0 0 0 3px rgba(0, 245, 255, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.catalogue-floating__panel-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 44px;
  border-radius: 10px;
  border: none;
  cursor: pointer;
  background: linear-gradient(90deg, #FF6B35 0%, #FF1493 100%);
  color: #FFFFFF;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 13px;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
  box-shadow: 0 4px 20px rgba(255, 107, 53, 0.4);
  transition: filter 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.catalogue-floating__panel-cta svg {
  flex-shrink: 0;
}
.catalogue-floating__panel-cta:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(255, 107, 53, 0.4);
}
.catalogue-floating__panel-cta:active {
  transform: translateY(0);
  filter: brightness(0.96);
}

.catalogue-floating__panel-cta-label {
  transition: opacity 0.2s ease;
}

.catalogue-floating__panel-cta-loader {
  width: 15px;
  height: 15px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: #00F5FF;
  animation: catalogueFloatingSpin 0.8s linear infinite;
  display: none;
  flex-shrink: 0;
}

.catalogue-floating__panel-cta.is-loading {
  cursor: wait;
}

.catalogue-floating__panel-cta.is-loading .catalogue-floating__panel-cta-label {
  opacity: 0.72;
}

.catalogue-floating__panel-cta.is-loading .catalogue-floating__panel-cta-loader {
  display: inline-flex;
}

.catalogue-floating__panel-cta.is-loading svg {
  opacity: 0.35;
}

.catalogue-floating__panel-feedback {
  margin: 2px 0 0;
  min-height: 18px;
  text-align: center;
  font-family: "Inter", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: rgba(0, 245, 255, 0.95);
}

.catalogue-floating__panel-reassurance {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 11px;
  color: #50506A;
  text-align: center;
  justify-content: center;
}
.catalogue-floating__panel-reassurance svg {
  flex-shrink: 0;
  stroke: #50506A;
}

.catalogue-floating__pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 13px;
  padding: 10px 20px 10px 10px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  background: rgba(10, 5, 22, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  max-width: 100%;
  box-sizing: border-box;
  pointer-events: auto;
}
.catalogue-floating__pill::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.9) 10%, rgba(255, 40, 80, 0.6) 22%, rgba(0, 245, 255, 0.8) 42%, rgba(0, 245, 255, 0.4) 65%, rgba(0, 245, 255, 0.15) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
}
.catalogue-floating__pill::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 51px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 10px 3px rgba(0, 245, 255, 0.22), 0 0 20px 7px rgba(0, 245, 255, 0.12);
}
.catalogue-floating__pill:hover .catalogue-floating__label {
  color: #00F5FF;
}

.catalogue-floating__avatar {
  position: relative;
  flex-shrink: 0;
  width: 50px;
  height: 50px;
}

.catalogue-floating__avatar-img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border: 2px solid rgba(0, 245, 255, 0.5);
  box-shadow: 0 0 12px rgba(0, 245, 255, 0.4);
}

.catalogue-floating__avatar-fallback {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: rgba(0, 245, 255, 0.1);
  border: 2px solid rgba(0, 245, 255, 0.4);
  align-items: center;
  justify-content: center;
  color: #00F5FF;
}

.catalogue-floating__avatar-status {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #05FFA1;
  border: 2px solid rgba(10, 5, 22, 0.9);
  box-shadow: 0 0 6px rgba(5, 255, 161, 0.8);
  animation: statusPulse 2.5s ease-in-out infinite;
}

@keyframes statusPulse {
  0%, 100% {
    box-shadow: 0 0 6px rgba(5, 255, 161, 0.8);
  }
  50% {
    box-shadow: 0 0 12px rgb(5, 255, 161), 0 0 20px rgba(5, 255, 161, 0.5);
  }
}
.catalogue-floating__content {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  overflow: hidden;
}

.catalogue-floating__label {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #FFFFFF;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
  transition: color 0.22s ease;
}

.catalogue-floating__promise {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.9);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.catalogue-floating__promise-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #05FFA1;
  box-shadow: 0 0 8px rgba(5, 255, 161, 0.85);
  flex-shrink: 0;
}

.catalogue-floating__arrow {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  transition: transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.catalogue-floating__arrow svg {
  display: block;
  filter: drop-shadow(0 0 4px rgba(0, 245, 255, 0.8));
}
.catalogue-floating--open .catalogue-floating__arrow {
  transform: rotate(180deg);
}

.catalogue-floating__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  opacity: 0;
  box-shadow: 0 0 5px 2px rgba(0, 245, 255, 0.55), 0 0 12px 5px rgba(0, 245, 255, 0.28);
  transition: opacity 0.2s ease;
}

.catalogue-floating--open .catalogue-floating__hotspot {
  opacity: 1;
}

@media (max-width: 768px) {
  body.catalogue-filters-open .catalogue-floating {
    opacity: 0 !important;
    visibility: hidden;
    transform: translateY(14px) scale(0.98) !important;
    pointer-events: none !important;
  }
}
@media (max-width: 380px) {
  .catalogue-floating {
    bottom: max(12px, env(safe-area-inset-bottom, 0px)) !important;
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
  }
  .catalogue-floating__pill {
    padding: 8px 14px 8px 8px;
    max-width: calc(100vw - 24px);
  }
  .catalogue-floating__label {
    font-size: 12px;
  }
  .catalogue-floating__promise {
    display: none;
  }
  .catalogue-floating__panel {
    width: min(260px, 100vw - 24px);
    padding: 16px 16px 14px;
  }
}
@keyframes catalogueFloatingSpin {
  to {
    transform: rotate(360deg);
  }
}
.trust-bar {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 64px 0;
  background-color: #0A0A0F;
}
.trust-bar__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: linear-gradient(180deg, rgba(5, 3, 10, 0.74) 0%, rgba(5, 3, 10, 0.66) 48%, rgba(5, 3, 10, 0.74) 100%), url("/img/front-v2/trust-bar-bg.webp");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.trust-bar__bg-stars {
  position: absolute;
  inset: 0;
  opacity: 0.62;
  background-image: radial-gradient(1px 1px at 8% 18%, rgba(255, 255, 255, 0.65) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 14% 72%, rgba(255, 255, 255, 0.5) 0%, transparent 100%), radial-gradient(1px 1px at 22% 35%, rgba(255, 255, 255, 0.7) 0%, transparent 100%), radial-gradient(1px 1px at 31% 88%, rgba(255, 255, 255, 0.4) 0%, transparent 100%), radial-gradient(2px 2px at 38% 12%, rgba(255, 255, 255, 0.6) 0%, transparent 100%), radial-gradient(1px 1px at 46% 55%, rgba(255, 255, 255, 0.45) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 53% 28%, rgba(255, 255, 255, 0.55) 0%, transparent 100%), radial-gradient(1px 1px at 62% 80%, rgba(255, 255, 255, 0.5) 0%, transparent 100%), radial-gradient(1px 1px at 69% 6%, rgba(255, 255, 255, 0.65) 0%, transparent 100%), radial-gradient(1px 1px at 75% 48%, rgba(255, 255, 255, 0.35) 0%, transparent 100%), radial-gradient(2px 2px at 83% 22%, rgba(255, 255, 255, 0.7) 0%, transparent 100%), radial-gradient(1px 1px at 90% 66%, rgba(255, 255, 255, 0.45) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 96% 38%, rgba(255, 255, 255, 0.55) 0%, transparent 100%), radial-gradient(1px 1px at 5% 90%, rgba(255, 255, 255, 0.4) 0%, transparent 100%), radial-gradient(1px 1px at 27% 58%, rgba(255, 255, 255, 0.3) 0%, transparent 100%), radial-gradient(1px 1px at 57% 95%, rgba(255, 255, 255, 0.5) 0%, transparent 100%), radial-gradient(1px 1px at 79% 82%, rgba(255, 255, 255, 0.35) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 17% 45%, rgba(157, 78, 221, 0.8) 0%, transparent 100%), radial-gradient(2px 2px at 43% 74%, rgba(157, 78, 221, 0.6) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 71% 15%, rgba(157, 78, 221, 0.7) 0%, transparent 100%), radial-gradient(1px 1px at 88% 52%, rgba(157, 78, 221, 0.5) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 33% 8%, rgba(0, 245, 255, 0.65) 0%, transparent 100%), radial-gradient(2px 2px at 60% 40%, rgba(0, 245, 255, 0.55) 0%, transparent 100%), radial-gradient(1px 1px at 94% 78%, rgba(0, 245, 255, 0.45) 0%, transparent 100%), radial-gradient(2px 2px at 50% 85%, rgba(255, 107, 53, 0.45) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 77% 30%, rgba(255, 107, 53, 0.35) 0%, transparent 100%);
}
.trust-bar__bg-nebula {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.trust-bar__bg-nebula--left {
  width: 520px;
  height: 360px;
  top: -80px;
  left: -120px;
  background: radial-gradient(ellipse at center, rgba(157, 78, 221, 0.22) 0%, rgba(157, 78, 221, 0.08) 45%, transparent 70%);
  filter: blur(70px);
}
.trust-bar__bg-nebula--center {
  width: 400px;
  height: 280px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(ellipse at center, rgba(255, 20, 147, 0.08) 0%, transparent 65%);
  filter: blur(60px);
}
.trust-bar__bg-nebula--right {
  width: 460px;
  height: 320px;
  bottom: -60px;
  right: -80px;
  background: radial-gradient(ellipse at center, rgba(255, 107, 53, 0.18) 0%, rgba(255, 107, 53, 0.06) 45%, transparent 70%);
  filter: blur(65px);
}
.trust-bar__glow-line {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 1;
  pointer-events: none;
}
.trust-bar__glow-line-core {
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  top: 0;
}
.trust-bar__glow-line-halo {
  position: absolute;
  left: 0;
  right: 0;
  height: 24px;
}
.trust-bar__glow-line--top {
  top: 63px;
}
.trust-bar__glow-line--top .trust-bar__glow-line-core {
  background: linear-gradient(90deg, transparent 0%, rgba(255, 107, 53, 0.15) 8%, rgba(255, 107, 53, 0.75) 25%, rgba(255, 20, 147, 0.95) 50%, rgba(255, 107, 53, 0.75) 75%, rgba(255, 107, 53, 0.15) 92%, transparent 100%);
  box-shadow: 0 0 6px rgba(255, 107, 53, 0.7), 0 0 14px rgba(255, 20, 147, 0.5), 0 0 30px rgba(255, 107, 53, 0.25);
}
.trust-bar__glow-line--top .trust-bar__glow-line-halo {
  top: -12px;
  background: linear-gradient(180deg, transparent 0%, rgba(255, 20, 147, 0.12) 40%, rgba(255, 107, 53, 0.08) 70%, transparent 100%);
  filter: blur(8px);
}
.trust-bar__glow-line--bottom {
  bottom: 63px;
}
.trust-bar__glow-line--bottom .trust-bar__glow-line-core {
  background: linear-gradient(90deg, transparent 0%, rgba(157, 78, 221, 0.12) 8%, rgba(157, 78, 221, 0.8) 28%, rgba(100, 40, 200, 0.95) 50%, rgba(157, 78, 221, 0.8) 72%, rgba(157, 78, 221, 0.12) 92%, transparent 100%);
  box-shadow: 0 0 6px rgba(157, 78, 221, 0.7), 0 0 14px rgba(157, 78, 221, 0.4), 0 0 30px rgba(157, 78, 221, 0.2);
}
.trust-bar__glow-line--bottom .trust-bar__glow-line-halo {
  bottom: -12px;
  background: linear-gradient(0deg, transparent 0%, rgba(157, 78, 221, 0.12) 40%, rgba(157, 78, 221, 0.06) 70%, transparent 100%);
  filter: blur(8px);
}
.trust-bar__inner {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  margin: 0 auto;
  padding-inline: clamp(14px, 1.2vw, 20px);
}
.trust-bar__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  padding: 20px 0;
  align-items: stretch;
}
.trust-bar__card {
  background: rgba(14, 7, 27, 0.85);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(157, 78, 221, 0.18);
  border-radius: 16px;
  padding: 26px 14px 22px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 258px;
  margin: 10px 0;
  position: relative;
  overflow: hidden;
  transition: border-color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease;
}
.trust-bar__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.12), transparent);
  pointer-events: none;
}
.trust-bar__card::after {
  content: "";
  position: absolute;
  top: -40px;
  left: -40px;
  width: 120px;
  height: 120px;
  background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.04) 0%, transparent 65%);
  pointer-events: none;
}
.trust-bar__card:hover {
  border-color: rgba(157, 78, 221, 0.4);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45), 0 0 18px rgba(157, 78, 221, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.07);
}
.trust-bar__card--cpf {
  border-color: rgba(0, 245, 255, 0.2);
}
.trust-bar__card--transitions {
  border-color: rgba(255, 107, 53, 0.2);
}
.trust-bar__card--opco {
  border-color: rgba(157, 78, 221, 0.36);
}
.trust-bar__card--stats {
  background: rgba(18, 6, 36, 0.9);
  border-color: rgba(157, 78, 221, 0.28);
}
.trust-bar__card-shine {
  position: absolute;
  inset: 0;
  border-radius: 16px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0%, transparent 50%, rgba(157, 78, 221, 0.03) 100%);
}
.trust-bar__card-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 88px;
  flex-shrink: 0;
}
.trust-bar__logo-img {
  max-width: 100%;
  max-height: 72px;
  width: auto;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  filter: none;
}
.trust-bar__opco-logo {
  width: min(100%, 150px);
  height: 62px;
  border-radius: 12px;
  border: 1px solid rgba(157, 78, 221, 0.45);
  background: radial-gradient(130% 120% at 8% 50%, rgba(255, 107, 53, 0.16) 0%, transparent 50%), radial-gradient(120% 120% at 92% 50%, rgba(157, 78, 221, 0.22) 0%, transparent 60%), rgba(12, 8, 25, 0.82);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  box-shadow: 0 0 18px rgba(157, 78, 221, 0.25), inset 0 0 10px rgba(157, 78, 221, 0.08);
}
.trust-bar__opco-icon-wrap {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #BFE9FF;
}
.trust-bar__opco-icon {
  width: 100%;
  height: 100%;
  display: block;
  stroke: currentColor;
  filter: drop-shadow(0 0 5px rgba(0, 245, 255, 0.72)) drop-shadow(0 0 10px rgba(157, 78, 221, 0.45));
  transition: filter 0.24s ease;
}
.trust-bar__opco-text {
  font-family: "Montserrat", sans-serif;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #F4EEFF;
  text-shadow: 0 0 8px rgba(157, 78, 221, 0.48), 0 0 18px rgba(255, 20, 147, 0.22);
}
.trust-bar__card--opco:hover .trust-bar__opco-icon {
  filter: drop-shadow(0 0 7px rgba(0, 245, 255, 0.9)) drop-shadow(0 0 14px rgba(157, 78, 221, 0.58));
}
.trust-bar__card-label {
  font-family: "Inter", sans-serif;
  font-size: clamp(14px, 0.8vw, 16px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  text-align: center;
  line-height: 1.45;
  letter-spacing: 0.01em;
  margin: 0;
  max-width: 17ch;
  padding-inline: 4px;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
  display: block;
  width: 100%;
  min-height: 3.1em;
  text-wrap: balance;
  overflow-wrap: anywhere;
  word-break: normal;
  -webkit-hyphens: auto;
          hyphens: auto;
}
.trust-bar__card-label strong {
  color: #FFFFFF;
  font-weight: 700;
}
.trust-bar__label-accent {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(11px, 0.68vw, 12px);
  font-weight: 600;
  color: #BDF8FF;
  opacity: 1;
  margin-top: 8px;
  max-width: none;
  padding: 4px 8px;
  border-radius: 9999px;
  border: 1px solid rgba(0, 245, 255, 0.28);
  background: rgba(0, 245, 255, 0.08);
  text-wrap: nowrap;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: keep-all;
  -webkit-hyphens: none;
          hyphens: none;
  line-height: 1.3;
  box-shadow: 0 0 10px rgba(0, 245, 255, 0.15), inset 0 0 8px rgba(0, 245, 255, 0.06);
}
.trust-bar__badge-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  flex-shrink: 0;
  margin-top: 8px;
}
.trust-bar__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 13px;
  border-radius: 50px;
  font-family: "Inter", sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.025em;
  white-space: nowrap;
  transition: all 0.22s ease;
}
.trust-bar__badge--outline {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: rgba(255, 255, 255, 0.72);
}
.trust-bar__badge--outline:hover {
  border-color: rgba(157, 78, 221, 0.5);
  color: #FFFFFF;
}
.trust-bar__badge--eligible {
  background: rgba(0, 245, 255, 0.1);
  border: 1px solid rgba(0, 245, 255, 0.48);
  color: #00F5FF;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-size: 11.5px;
  box-shadow: 0 0 10px rgba(0, 245, 255, 0.22);
}
.trust-bar__badge--eligible:hover {
  background: rgba(0, 245, 255, 0.16);
  box-shadow: 0 0 16px rgba(0, 245, 255, 0.3);
}
.trust-bar__badge--orange {
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.22), rgba(255, 20, 147, 0.16));
  border: 1px solid rgba(255, 107, 53, 0.48);
  color: #FF9060;
  font-family: "Montserrat", sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.2);
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}
.trust-bar__badge--opco {
  background: rgba(157, 78, 221, 0.1);
  border: 1.5px solid rgba(157, 78, 221, 0.5);
  color: rgba(200, 155, 255, 0.9);
  font-family: "Inter", sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 3px 11px;
  box-shadow: 0 0 8px rgba(157, 78, 221, 0.22);
}
.trust-bar__badge-icon {
  width: 11px;
  height: 11px;
  flex-shrink: 0;
}
.trust-bar__badge-dot {
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}
.trust-bar__badge-dot--cyan {
  background: #00F5FF;
  box-shadow: 0 0 4px #00F5FF;
}
.trust-bar__badge-dot--violet {
  background: #9D4EDD;
  box-shadow: 0 0 4px #9D4EDD;
}
.trust-bar__badge-dot--orange {
  background: #FF6B35;
  box-shadow: 0 0 4px #FF6B35;
}
.trust-bar__stats-top {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  flex-shrink: 0;
}
.trust-bar__stat-rating {
  font-family: "Montserrat", sans-serif;
  font-size: 26px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  background: linear-gradient(135deg, #FFB347 0%, #FF6B35 45%, #FF1493 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 8px rgba(255, 107, 53, 0.55));
}
.trust-bar__stars {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}
.trust-bar__star {
  width: 13px;
  height: 13px;
  color: #FFB347;
  filter: drop-shadow(0 0 3px rgba(255, 179, 71, 0.75));
}
.trust-bar__stat-count {
  margin: 0;
  line-height: 1.1;
  text-align: center;
  font-family: "Montserrat", sans-serif;
  font-size: 32px;
  font-weight: 800;
  color: #FFFFFF;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}
.trust-bar__stat-desc {
  font-family: "Inter", sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
  text-align: center;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}
.trust-bar__stat-sub {
  font-family: "Inter", sans-serif;
  font-size: 10.5px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.42);
  margin: 0;
  text-align: center;
}
@media (max-width: 1280px) {
  .trust-bar__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }
  .trust-bar__stat-rating {
    font-size: 22px;
  }
  .trust-bar__stat-count {
    font-size: 28px;
  }
}
@media (max-width: 900px) {
  .trust-bar__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }
  .trust-bar__glow-line {
    display: none;
  }
}
@media (max-width: 680px) {
  .trust-bar {
    padding: 40px 0;
  }
  .trust-bar__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 10px 0;
  }
  .trust-bar__card {
    min-height: 214px;
    padding: 20px 10px 18px;
    margin: 8px 0;
  }
  .trust-bar__logo-img {
    max-height: 58px;
  }
  .trust-bar__opco-logo {
    height: 56px;
    width: min(100%, 134px);
  }
  .trust-bar__opco-icon-wrap {
    width: 24px;
    height: 24px;
  }
  .trust-bar__opco-text {
    font-size: 17px;
  }
  .trust-bar__card-label {
    font-size: 12.5px;
    max-width: 18ch;
    line-height: 1.4;
    min-height: 2.9em;
  }
  .trust-bar__label-accent {
    font-size: 11.5px;
    margin-top: 6px;
    padding: 3px 7px;
  }
  .trust-bar__stat-rating {
    font-size: 20px;
  }
  .trust-bar__stat-count {
    font-size: 24px;
  }
}
@media (max-width: 560px) {
  .trust-bar__grid {
    grid-template-columns: 1fr;
  }
}

.footer {
  position: relative;
  overflow: hidden;
  background-position: center bottom;
  background-size: cover;
  background-repeat: no-repeat;
}
.footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(4, 2, 10, 0.58) 0%, rgba(5, 3, 12, 0.66) 38%, rgba(6, 4, 14, 0.72) 100%);
  z-index: 0;
}
.footer > * {
  position: relative;
  z-index: 1;
}

.footer__body {
  max-width: none;
  margin: 0;
  padding: 92px clamp(24px, 5vw, 80px) 56px;
  display: grid;
  grid-template-columns: minmax(230px, 300px) repeat(3, minmax(0, 1fr)) minmax(220px, 280px);
  gap: clamp(24px, 3vw, 52px);
  align-items: start;
}
.footer__body > * {
  min-width: 0;
}

.footer__col--brand {
  grid-column: 1;
  grid-row: 1;
}

.footer__col--alexandre {
  grid-column: 5;
  grid-row: 1;
  margin-top: -24px;
}

@media (max-width: 1280px) {
  .footer__body {
    grid-template-columns: minmax(230px, 300px) repeat(3, minmax(0, 1fr));
  }
  .footer__col--alexandre {
    grid-column: 1/-1;
    grid-row: 2;
    justify-self: center;
  }
}
@media (max-width: 900px) {
  .footer__body {
    grid-template-columns: 1fr;
    padding: 44px clamp(16px, 4.8vw, 24px) 52px;
    gap: 34px;
  }
  .footer__col--brand,
  .footer__col--alexandre {
    grid-column: 1;
    grid-row: auto;
    margin-top: 0;
    justify-self: center;
    width: min(100%, 420px);
  }
}
.footer-cta {
  position: relative;
  padding: 0 clamp(24px, 5vw, 80px);
  background: rgba(255, 255, 255, 0.025);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.footer-cta__topline {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, #FF6B35 20%, #FF1493 50%, #9D4EDD 80%, transparent 100%);
  opacity: 0.9;
  box-shadow: 0 0 8px 3px rgba(255, 107, 53, 0.6), 0 0 20px 6px rgba(255, 20, 147, 0.4), 0 0 40px 10px rgba(157, 78, 221, 0.25);
}
.footer-cta__bottomline {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.08) 30%, rgba(255, 255, 255, 0.12) 50%, rgba(255, 255, 255, 0.08) 70%, transparent 100%);
}
.footer-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  min-height: 110px;
  padding: 24px 0;
}
.footer-cta__left {
  display: flex;
  align-items: center;
  gap: 28px;
  flex: 1;
  min-width: 0;
}
.footer-cta__logo {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(22px, 1.8vw, 28px);
  white-space: nowrap;
  background: linear-gradient(105deg, #FF6B35 0%, #FF1493 55%, #9D4EDD 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 10px rgba(255, 107, 53, 0.7)) drop-shadow(0 0 24px rgba(255, 20, 147, 0.4));
  flex-shrink: 0;
}
.footer-cta__sep {
  width: 1.5px;
  height: 48px;
  background: linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.25) 30%, rgba(255, 255, 255, 0.35) 50%, rgba(255, 255, 255, 0.25) 70%, transparent 100%);
  flex-shrink: 0;
}
.footer-cta__text {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}
.footer-cta__headline {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(17px, 1.5vw, 22px);
  color: #ffffff;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
  margin: 0;
  line-height: 1.2;
}
.footer-cta__sub {
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: clamp(12px, 0.9vw, 14px);
  color: rgba(255, 255, 255, 0.58);
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
  margin: 0;
}
.footer-cta__right {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-shrink: 0;
}
.footer-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 30px;
  border-radius: 9999px;
  font-family: Montserrat, sans-serif;
  font-weight: 700;
  font-size: clamp(13px, 1vw, 15px);
  white-space: nowrap;
}
.footer-cta__avatar {
  position: relative;
  width: 100px;
  height: 100px;
  flex-shrink: 0;
}
.footer-cta__avatar img {
  width: 100%;
  height: 100%;
  border-radius: 9999px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
  position: relative;
  z-index: 2;
  padding: 3px;
  background: linear-gradient(135deg, #FF6B35, #FF1493, #9D4EDD) border-box;
  border: 3px solid transparent;
  background-clip: padding-box;
}
.footer-cta__avatar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  padding: 3px;
  background: linear-gradient(135deg, #FF6B35 0%, #FF1493 50%, #9D4EDD 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  z-index: 3;
  pointer-events: none;
}
.footer-cta__avatar-glow {
  position: absolute;
  inset: -8px;
  border-radius: 9999px;
  background: transparent;
  z-index: 0;
  box-shadow: 0 0 15px 5px rgba(157, 78, 221, 0.7), 0 0 35px 12px rgba(157, 78, 221, 0.45), 0 0 65px 22px rgba(157, 78, 221, 0.25), 0 0 100px 35px rgba(255, 20, 147, 0.15);
  pointer-events: none;
}
@media (max-width: 900px) {
  .footer-cta__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    padding: 28px 0;
  }
  .footer-cta__right {
    align-self: stretch;
    justify-content: space-between;
  }
  .footer-cta__btn {
    min-height: 50px;
    padding: 10px 20px;
    font-size: 13px;
  }
}
@media (max-width: 600px) {
  .footer-cta__avatar {
    display: none;
  }
  .footer-cta__btn {
    flex: 1;
    text-align: center;
    min-height: 48px;
    padding: 10px 16px;
    font-size: 12px;
  }
}

.footer-brand {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.footer-brand__qualiopi {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 9px 18px;
  border-radius: 9999px;
  background: rgba(0, 245, 255, 0.06);
  border: 1px solid rgba(0, 245, 255, 0.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 0 10px 2px rgba(0, 245, 255, 0.12), inset 0 0 8px rgba(0, 245, 255, 0.04);
  width: -moz-fit-content;
  width: fit-content;
}
.footer-brand__qualiopi span {
  font-family: Space\ Grotesk, sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #00F5FF;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.6);
}
.footer-brand__qualiopi-icon {
  color: #00F5FF;
  filter: drop-shadow(0 0 4px rgba(0, 245, 255, 0.8));
  flex-shrink: 0;
}
.footer-brand__tagline {
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: clamp(13px, 0.9vw, 15px);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.58);
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
  margin: 0;
  max-width: 260px;
}
.footer-brand__stats {
  display: flex;
  align-items: center;
  gap: 16px;
}
.footer-brand__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.footer-brand__stat-value {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1;
}
.footer-brand__stat-value--cyan {
  background: linear-gradient(105deg, #00F5FF, #00C8FF);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 8px rgba(0, 245, 255, 0.6));
}
.footer-brand__stat-value--orange {
  background: linear-gradient(105deg, #FF6B35, #FFB347);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 8px rgba(255, 107, 53, 0.6));
}
.footer-brand__stat-label {
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.4);
  letter-spacing: 0.04em;
}
.footer-brand__stat-divider {
  width: 1px;
  height: 32px;
  background: linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.18) 50%, transparent 100%);
}

@media (max-width: 900px) {
  .footer-brand {
    gap: 24px;
    align-items: center;
    text-align: center;
  }
  .footer-brand__qualiopi {
    margin-inline: auto;
    width: min(100%, 340px);
    justify-content: center;
  }
  .footer-brand__qualiopi span {
    letter-spacing: 0.1em;
    font-size: 11px;
    text-align: center;
  }
  .footer-brand__tagline {
    font-size: 16px;
    line-height: 1.65;
    max-width: 34ch;
    margin-inline: auto;
  }
  .footer-brand__stats {
    gap: 20px;
    justify-content: center;
  }
}
.footer-nav {
  margin-top: -24px;
}
.footer-nav__title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: clamp(16px, 1.1vw, 22px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: linear-gradient(105deg, #ff9f63 0%, #ff4ca8 45%, #cf6bff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  margin: 0 0 12px 0;
  padding-bottom: 12px;
  position: relative;
  text-shadow: 0 0 8px rgba(255, 80, 140, 0.4), 0 0 18px rgba(157, 78, 221, 0.28);
}
.footer-nav__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 44px;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(255, 107, 53, 0.9) 0%, rgba(255, 20, 147, 0.65) 55%, rgba(157, 78, 221, 0) 100%);
  box-shadow: 0 0 8px rgba(255, 107, 53, 0.28);
}
.footer-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer-nav__item {
  display: flex;
}
.footer-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: clamp(12px, 0.85vw, 14px);
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.7);
  transition: color 0.2s ease, gap 0.2s ease, text-shadow 0.2s ease;
}
.footer-nav__link:hover {
  color: #ffffff;
  text-shadow: 0 0 9px rgba(255, 255, 255, 0.22), 1px 1px 4px rgba(0, 0, 0, 0.7);
}
.footer-nav__link:hover .footer-nav__arrow {
  opacity: 1;
  transform: translateX(2px) rotate(-45deg) scale(1.05);
}
.footer-nav__arrow {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  flex-shrink: 0;
  opacity: 0.92;
  transition: opacity 0.2s ease, transform 0.2s ease, filter 0.2s ease;
}

.footer-nav--apprendre .footer-nav__arrow {
  color: #ff7b35;
  filter: drop-shadow(0 0 4px rgba(255, 107, 53, 0.8));
}

.footer-nav--plateforme .footer-nav__arrow {
  color: #d95bff;
  filter: drop-shadow(0 0 4px rgba(157, 78, 221, 0.85));
}

.footer-nav--infos .footer-nav__arrow {
  color: #00f5ff;
  filter: drop-shadow(0 0 4px rgba(0, 245, 255, 0.85));
}

.footer-nav--plateforme .footer-nav__title {
  background: linear-gradient(105deg, #cf6bff 0%, #00f5ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  text-shadow: 0 0 8px rgba(157, 78, 221, 0.4), 0 0 18px rgba(0, 245, 255, 0.28);
}

.footer-nav--infos .footer-nav__title {
  background: linear-gradient(105deg, #00f5ff 0%, #ff7b35 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.35), 0 0 18px rgba(255, 107, 53, 0.28);
}

@media (max-width: 900px) {
  .footer-nav {
    margin-top: 0;
    width: min(100%, 420px);
    margin-inline: auto;
  }
  .footer-nav__title {
    text-align: center;
    margin-bottom: 14px;
    padding-bottom: 14px;
    font-size: clamp(18px, 4.8vw, 22px);
    letter-spacing: 0.12em;
  }
  .footer-nav__title::after {
    left: 50%;
    transform: translateX(-50%);
    width: 56px;
  }
  .footer-nav__list {
    gap: 14px;
    align-items: center;
  }
  .footer-nav__item {
    justify-content: center;
    width: 100%;
  }
  .footer-nav__link {
    font-size: 16px;
    line-height: 1.35;
    justify-content: center;
    text-align: center;
    gap: 12px;
  }
  .footer-nav__arrow {
    width: 8px;
    height: 8px;
  }
}
.footer-alexandre {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}
.footer-alexandre__avatar-wrap {
  position: relative;
  width: 162px;
  height: 162px;
  flex-shrink: 0;
  overflow: visible;
}
.footer-alexandre__avatar {
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  overflow: hidden;
  z-index: 3;
}
.footer-alexandre__avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
  display: block;
}
.footer-alexandre__ring {
  position: absolute;
  inset: calc(-1 * 3px);
  border-radius: 9999px;
  padding: 3px;
  background: conic-gradient(from 195deg, #FF7000 0deg, #FF9040 12deg, #FF2878 42deg, #FF18B0 70deg, #F040FF 102deg, #FFFFFF 138deg, #E8F0FF 152deg, #DD60FF 188deg, #CC44FF 230deg, #DD60FF 266deg, #FF18B0 303deg, #FF9040 338deg, #FF7000 360deg);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 4;
}
.footer-alexandre__hotspot {
  position: absolute;
  top: calc(50% - 71px);
  left: calc(50% + 41px);
  width: 4px;
  height: 4px;
  border-radius: 9999px;
  background: #ffffff;
  pointer-events: none;
  z-index: 8;
  box-shadow: 0 0 0px 0px rgb(255, 255, 255), 0 0 4px 2px rgb(255, 255, 255), 0 0 8px 3px rgba(245, 252, 255, 0.97), 0 0 14px 6px rgba(225, 242, 255, 0.9), 0 0 24px 10px rgba(200, 228, 255, 0.8), 0 0 40px 16px rgba(170, 90, 255, 0.6);
}
.footer-alexandre__identity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  text-align: center;
}
.footer-alexandre__name {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(15px, 1.1vw, 18px);
  color: #ffffff;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
  margin: 0;
  line-height: 1.2;
}
.footer-alexandre__title {
  font-family: Inter, sans-serif;
  font-weight: 400;
  font-size: clamp(11px, 0.8vw, 13px);
  color: rgba(255, 255, 255, 0.52);
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
  margin: 0;
}
.footer-alexandre__socials {
  display: flex;
  align-items: center;
  gap: 10px;
}
.footer-alexandre__social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
  transition: background 0.22s ease, border-color 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, transform 0.18s ease;
}
.footer-alexandre__social:hover {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.1);
}
.footer-alexandre__social--linkedin:hover {
  background: rgba(0, 168, 224, 0.18);
  border-color: rgba(0, 168, 224, 0.7);
  color: #00c4ff;
  box-shadow: 0 0 10px 2px rgba(0, 168, 224, 0.55), 0 0 24px 7px rgba(0, 168, 224, 0.32), 0 0 42px 14px rgba(157, 78, 221, 0.2);
}
.footer-alexandre__social--instagram:hover {
  background: rgba(255, 20, 147, 0.16);
  border-color: rgba(255, 20, 147, 0.7);
  color: #ff4bc2;
  box-shadow: 0 0 10px 2px rgba(255, 20, 147, 0.55), 0 0 24px 7px rgba(255, 107, 53, 0.32), 0 0 42px 14px rgba(157, 78, 221, 0.2);
}

.financement {
  position: relative;
  isolation: isolate;
  padding: 100px 0 120px;
  background: linear-gradient(180deg, rgba(8, 6, 18, 0.62) 0%, rgba(8, 6, 18, 0.72) 100%), url("/img/front-v2/financement-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  overflow: visible;
}
.financement::before {
  content: "";
  position: absolute;
  top: 10%;
  left: -200px;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(255, 107, 53, 0.06) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.financement::after {
  content: "";
  position: absolute;
  bottom: 5%;
  right: -200px;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(0, 245, 255, 0.05) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.financement__inner {
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
  padding-inline: clamp(14px, 1.2vw, 20px);
}

.financement__header {
  text-align: center;
  margin-bottom: 74px;
}

.financement__badge {
  margin-bottom: 32px;
}

@media (max-width: 767px) {
  .financement__header {
    margin-bottom: 90px;
  }
  .financement__badge {
    margin-bottom: 28px;
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .financement__title {
    margin-bottom: 32px;
  }
  .financement__subtitle {
    margin-top: 0;
    line-height: 1.8;
  }
}
.financement__title {
  --ht-size: clamp(32px, 4vw, 52px);
  margin-bottom: 22px;
}

.financement__subtitle {
  font-family: "Inter", sans-serif;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.6);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.72;
}

.financement__panels {
  position: relative;
}

.financement__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 16px;
}
@media (max-width: 900px) {
  .financement__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .financement__grid {
    grid-template-columns: 1fr;
  }
}

.dispositif-card {
  position: relative;
  border-radius: 16px;
  padding: 28px 24px 24px;
  background: rgba(255, 255, 255, 0.03);
  z-index: 0;
  overflow: visible;
  transition: transform 0.25s ease;
}
.dispositif-card__hotspot {
  position: absolute;
  top: -1px;
  right: -1px;
  width: 60px;
  height: 60px;
  border-radius: 0 16px 0 60px;
  background: linear-gradient(225deg, var(--card-color, #FF6B35), transparent);
  opacity: 0.12;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.dispositif-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(135deg, var(--card-color, #FF6B35) 0%, rgba(157, 78, 221, 0.4) 50%, transparent 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  transition: opacity 0.25s ease;
  opacity: 0.6;
}
.dispositif-card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 17px;
  background: transparent;
  box-shadow: 0 0 20px rgba(var(--card-rgb, 255, 107, 53), 0.08), 0 4px 20px rgba(0, 0, 0, 0.4);
  z-index: -1;
  transition: box-shadow 0.25s ease;
}
.dispositif-card:hover {
  transform: translateY(-4px);
}
.dispositif-card:hover::before {
  opacity: 1;
}
.dispositif-card:hover::after {
  box-shadow: 0 0 30px rgba(var(--card-rgb, 255, 107, 53), 0.2), 0 8px 30px rgba(0, 0, 0, 0.5);
}
.dispositif-card:hover .dispositif-card__hotspot {
  opacity: 0.22;
}
.dispositif-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 16px;
  gap: 12px;
}
.dispositif-card__icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(var(--card-rgb, 255, 107, 53), 0.12);
  border: 1px solid rgba(var(--card-rgb, 255, 107, 53), 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
  box-shadow: 0 0 12px rgba(var(--card-rgb, 255, 107, 53), 0.15);
}
.dispositif-card__badge {
  padding: 4px 10px;
  border-radius: 100px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: rgba(var(--card-rgb, 255, 107, 53), 0.12);
  color: var(--card-color, #FF6B35);
  border: 1px solid rgba(var(--card-rgb, 255, 107, 53), 0.2);
  white-space: nowrap;
  align-self: flex-start;
}
.dispositif-card__badge--green {
  background: rgba(0, 245, 100, 0.1);
  color: #00F564;
  border-color: rgba(0, 245, 100, 0.2);
}
.dispositif-card__badge--cyan {
  background: rgba(0, 245, 255, 0.1);
  color: #00F5FF;
  border-color: rgba(0, 245, 255, 0.2);
}
.dispositif-card__name {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 17px;
  color: #FFFFFF;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
  margin-bottom: 6px;
  line-height: 1.2;
}
.dispositif-card__desc {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
  margin-bottom: 18px;
}
.dispositif-card__amount {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 12px;
}
.dispositif-card__amount .amount-value {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 28px;
  color: var(--card-color, #FF6B35);
  text-shadow: 0 0 20px rgba(var(--card-rgb, 255, 107, 53), 0.4);
  line-height: 1;
}
.dispositif-card__amount .amount-label {
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.3;
}
.dispositif-card__points {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.dispositif-card__points li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.5;
}
.dispositif-card__points li::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--card-color, #FF6B35);
  box-shadow: 0 0 6px rgba(var(--card-rgb, 255, 107, 53), 0.6);
  flex-shrink: 0;
  margin-top: 6px;
}
.dispositif-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--card-color, #FF6B35);
  text-decoration: none;
  transition: gap 0.2s ease;
}
.dispositif-card__cta:hover {
  gap: 10px;
}
.dispositif-card__cta .arrow {
  font-size: 14px;
  transition: transform 0.2s ease;
}
.dispositif-card__cta:hover .arrow {
  transform: translateX(3px);
}
.dispositif-card--highlight {
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.08) 0%, rgba(157, 78, 221, 0.08) 100%);
}
.dispositif-card--highlight::before {
  background: linear-gradient(135deg, #FF6B35 0%, #FF1493 50%, #9D4EDD 100%);
  opacity: 1;
}
.dispositif-card--highlight::after {
  box-shadow: 0 0 40px rgba(255, 107, 53, 0.15), 0 0 40px rgba(157, 78, 221, 0.1), 0 8px 30px rgba(0, 0, 0, 0.5);
}

.financement__notice {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 20px;
  background: rgba(255, 200, 0, 0.04);
  border: 1px solid rgba(255, 200, 0, 0.15);
  border-radius: 10px;
  margin-top: 16px;
}
.financement__notice .notice-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
.financement__notice p {
  font-family: "Inter", sans-serif;
  font-size: 12.5px;
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.6;
  margin: 0;
}
.financement__notice p strong {
  color: rgba(255, 220, 100, 0.8);
  font-weight: 600;
}
.financement__notice p a {
  color: rgba(0, 245, 255, 0.7);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.financement__notice p a:hover {
  color: #00F5FF;
}

.financement__cta-block {
  margin-top: 64px;
  position: relative;
  border-radius: 20px;
  padding: 48px;
  background: rgba(255, 255, 255, 0.02);
  text-align: center;
  z-index: 0;
  overflow: visible;
}
.financement__cta-block::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(135deg, #FF6B35 0%, #9D4EDD 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0.5;
}
.financement__cta-block::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 22px;
  box-shadow: 0 0 40px rgba(255, 107, 53, 0.08), 0 0 40px rgba(157, 78, 221, 0.08);
  z-index: -1;
}
.financement__cta-block .cta-hotspot {
  position: absolute;
  top: -1px;
  right: -1px;
  width: 120px;
  height: 120px;
  border-radius: 0 20px 0 120px;
  background: linear-gradient(225deg, rgba(255, 107, 53, 0.15), transparent);
  pointer-events: none;
}

.financement__cta-block-icon {
  font-size: 40px;
  display: block;
  margin-bottom: 20px;
  filter: drop-shadow(0 0 12px rgba(0, 245, 255, 0.4));
}

.financement__cta-block-title {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: clamp(20px, 2.5vw, 28px);
  color: #FFFFFF;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
  margin-bottom: 12px;
}

.financement__cta-block-text {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
  margin: 0 auto 32px;
  max-width: 480px;
}

.financement__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 18px 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, #FF6B35, #FF1493, #9D4EDD);
  color: #FFFFFF;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.5);
  box-shadow: 0 0 30px rgba(255, 107, 53, 0.25), 0 0 30px rgba(157, 78, 221, 0.2);
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}
.financement__cta-btn::after {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transform: skewX(-20deg);
  transition: left 0.5s ease;
}
.financement__cta-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 0 50px rgba(255, 107, 53, 0.35), 0 0 50px rgba(157, 78, 221, 0.3), 0 8px 20px rgba(0, 0, 0, 0.4);
}
.financement__cta-btn:hover::after {
  left: 150%;
}
.financement__cta-btn .btn-arrow {
  font-size: 18px;
}

@media (max-width: 768px) {
  .financement {
    padding: 80px 0 100px;
  }
  .financement__cta-block {
    padding: 40px 28px;
  }
}
.fin-tabs-wrap {
  display: flex;
  justify-content: center;
  gap: 16px;
  padding: 4px 0 52px;
  flex-wrap: wrap;
}

.fin-tab {
  --ft-c1: 157, 78, 221;
  --ft-c2: 255, 20, 147;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 200px;
  height: 64px;
  padding: 0 26px;
  border-radius: 14px;
  border: none;
  cursor: pointer;
  background: rgba(10, 5, 22, 0.52);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  overflow: hidden;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #7070A0;
  transition: color 0.25s ease, transform 0.2s ease;
}
.fin-tab::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 14px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgba(255, 120, 40, 0.9) 0%, rgba(255, 80, 50, 0.75) 10%, rgba(255, 40, 80, 0.5) 22%, rgba(var(--ft-c1), 0.45) 40%, rgba(var(--ft-c2), 0.2) 65%, rgba(var(--ft-c1), 0.08) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
  opacity: 0.45;
  transition: opacity 0.25s ease;
}
.fin-tab::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 15px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 18px 6px rgba(var(--ft-c1), 0.55), 0 0 40px 16px rgba(var(--ft-c1), 0.32), 0 0 80px 32px rgba(var(--ft-c1), 0.16), 0 0 130px 55px rgba(var(--ft-c1), 0.07);
  opacity: 0.1;
  transition: opacity 0.25s ease, box-shadow 0.25s ease;
}
.fin-tab:hover:not(.is-active) {
  color: color-mix(in srgb, rgb(var(--ft-c1)) 62%, #ffffff);
  transform: translateY(-2px);
}
.fin-tab:hover:not(.is-active)::before {
  opacity: 0.8;
}
.fin-tab:hover:not(.is-active)::after {
  opacity: 0.35;
}
.fin-tab:hover:not(.is-active) .fin-tab__hotspot {
  opacity: 0.5;
}
.fin-tab:hover:not(.is-active) .fin-tab__icon {
  filter: drop-shadow(0 0 5px rgba(var(--ft-c1), 0.7));
}
.fin-tab.is-active {
  color: #FFFFFF;
  transform: translateY(-2px);
}
.fin-tab.is-active::before {
  background: linear-gradient(145deg, rgb(255, 140, 50) 0%, rgba(255, 90, 60, 0.98) 10%, rgba(255, 50, 90, 0.85) 22%, rgba(var(--ft-c1), 0.95) 38%, rgba(var(--ft-c2), 0.65) 62%, rgba(var(--ft-c1), 0.3) 82%, rgba(var(--ft-c1), 0.1) 100%);
  opacity: 1;
}
.fin-tab.is-active::after {
  opacity: 1;
  box-shadow: 0 0 22px 8px rgba(var(--ft-c1), 0.7), 0 0 48px 18px rgba(var(--ft-c1), 0.44), 0 0 90px 32px rgba(var(--ft-c1), 0.22), 0 0 145px 54px rgba(var(--ft-c1), 0.1);
}
.fin-tab.is-active .fin-tab__hotspot {
  opacity: 1;
  box-shadow: 0 0 8px 4px rgba(var(--ft-c1), 0.95), 0 0 20px 9px rgba(var(--ft-c1), 0.7), 0 0 40px 16px rgba(var(--ft-c1), 0.4), 0 0 70px 28px rgba(var(--ft-c1), 0.18);
}
.fin-tab.is-active .fin-tab__icon {
  filter: drop-shadow(0 0 8px rgba(var(--ft-c1), 1)) drop-shadow(0 0 16px rgba(var(--ft-c1), 0.6));
  transform: scale(1.18);
}
.fin-tab.is-active .fin-tab__label {
  background: linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, rgb(var(--ft-c1)) 35%, #ffffff) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 10px rgba(var(--ft-c1), 0.55)) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.9));
}

.fin-tab__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  opacity: 0.15;
  box-shadow: 0 0 8px 4px rgba(157, 78, 221, 0.95), 0 0 20px 9px rgba(157, 78, 221, 0.7), 0 0 40px 16px rgba(157, 78, 221, 0.4), 0 0 70px 28px rgba(157, 78, 221, 0.18);
  transition: opacity 0.25s ease, box-shadow 0.25s ease;
}

.fin-tab__icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 0 4px rgba(157, 78, 221, 0.4));
  transition: filter 0.25s ease, transform 0.25s ease;
  color: color-mix(in srgb, rgb(var(--ft-c1)) 75%, #ffffff);
}
.fin-tab__icon svg {
  width: 100%;
  height: 100%;
  display: block;
  stroke: currentColor;
}

.fin-tab__label {
  position: relative;
  z-index: 2;
  -webkit-text-fill-color: unset;
  background: none;
  transition: color 0.25s ease;
}

@media (max-width: 900px) {
  .fin-tabs-wrap {
    gap: 10px;
  }
  .fin-tab {
    min-width: 150px;
    height: 56px;
    padding: 0 20px;
    font-size: 12px;
  }
  .fin-tab__icon {
    width: 19px;
    height: 19px;
  }
}
@media (max-width: 560px) {
  .fin-tabs-wrap {
    gap: 8px;
  }
  .fin-tab {
    min-width: calc(50% - 4px);
    height: 50px;
    padding: 0 14px;
    justify-content: center;
  }
}
.fin-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  max-width: 100%;
  margin: 0 auto;
  padding: 12px 0 44px;
  align-items: stretch;
}
@media (max-width: 900px) {
  .fin-cards-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
}

.fin-card {
  --cc1: 157, 78, 221;
  --cc2: 120, 50, 200;
  position: relative;
  display: flex;
  flex-direction: column;
  background: rgba(6, 2, 14, 0.9);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 24px;
  overflow: hidden;
  border: none;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.fin-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 24px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgba(255, 130, 40, 0.55) 0%, rgba(255, 75, 60, 0.4) 16%, rgba(255, 30, 85, 0.26) 30%, rgba(var(--cc1), 0.34) 48%, rgba(var(--cc2), 0.16) 72%, rgba(var(--cc1), 0.06) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
  opacity: 0.5;
  transition: opacity 0.3s ease;
}
.fin-card::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 26px;
  pointer-events: none;
  z-index: -1;
  opacity: 0.06;
  box-shadow: 0 0 10px 3px rgba(var(--cc1), 0.5), 0 0 24px 8px rgba(var(--cc1), 0.28), 0 0 50px 18px rgba(var(--cc1), 0.14), 0 0 90px 32px rgba(var(--cc1), 0.07), 0 0 140px 55px rgba(var(--cc1), 0.03);
  transition: opacity 0.3s ease, box-shadow 0.3s ease;
}
.fin-card:hover {
  transform: translateY(-6px);
}
.fin-card:hover::before {
  opacity: 0.95;
}
.fin-card:hover::after {
  opacity: 0.65;
  box-shadow: 0 0 14px 4px rgba(var(--cc1), 0.72), 0 0 32px 12px rgba(var(--cc1), 0.46), 0 0 65px 24px rgba(var(--cc1), 0.24), 0 0 110px 42px rgba(var(--cc1), 0.12), 0 0 170px 68px rgba(var(--cc1), 0.06);
}
.fin-card:hover .fin-card__hotspot {
  opacity: 1;
}
.fin-card:hover .fin-card__icon-wrap {
  box-shadow: 0 0 10px 3px rgba(var(--cc1), 0.85), 0 0 24px 8px rgba(var(--cc1), 0.48), 0 0 48px 18px rgba(var(--cc1), 0.22), inset 0 0 16px rgba(var(--cc1), 0.1);
}
.fin-card:hover .fin-card__cta {
  color: #FFFFFF;
  text-shadow: 0 0 12px rgba(var(--cc1), 0.8);
  border-color: rgba(var(--cc1), 0.8);
  box-shadow: 0 0 12px 3px rgba(var(--cc1), 0.65), 0 0 28px 10px rgba(var(--cc1), 0.34), 0 0 55px 20px rgba(var(--cc1), 0.16), inset 0 0 20px rgba(var(--cc1), 0.07);
}
.fin-card:hover .fin-card__cta .fin-card__cta-arrow {
  transform: translateX(5px);
}
.fin-card--highlight {
  background: rgba(7, 2, 15, 0.94);
  box-shadow: inset 0 0 40px rgba(255, 107, 53, 0.055), inset 0 0 80px rgba(255, 20, 147, 0.03), inset 0 0 120px rgba(157, 78, 221, 0.02);
}
.fin-card--highlight::before {
  padding: 2px;
  opacity: 1;
  background: conic-gradient(from 180deg at 50% 50%, #FF9000 0deg, #FF6B35 45deg, #FF3060 90deg, #FF1493 135deg, #CC22CC 180deg, #9D4EDD 225deg, #7B2FBE 270deg, #9D4EDD 315deg, #FF1493 330deg, #FF6B35 345deg, #FF9000 360deg);
}
.fin-card--highlight::after {
  inset: -4px;
  border-radius: 28px;
  opacity: 1;
  box-shadow: 0 0 6px 2px rgb(255, 130, 50), 0 0 18px 6px rgba(255, 90, 48, 0.85), 0 0 36px 13px rgba(255, 48, 90, 0.62), 0 0 65px 24px rgba(255, 20, 147, 0.4), 0 0 110px 44px rgba(157, 78, 221, 0.24), 0 0 170px 72px rgba(120, 40, 200, 0.12);
}
.fin-card--highlight .fin-card__hotspot {
  opacity: 1;
  box-shadow: 0 0 8px 4px rgb(255, 130, 50), 0 0 20px 10px rgba(255, 80, 50, 0.82), 0 0 44px 20px rgba(255, 20, 147, 0.52), 0 0 80px 36px rgba(157, 78, 221, 0.26);
}
.fin-card--highlight .fin-card__icon-wrap {
  border-color: rgba(255, 130, 50, 0.8);
  box-shadow: 0 0 8px 2px rgba(255, 130, 50, 0.82), 0 0 22px 7px rgba(255, 100, 48, 0.48), 0 0 44px 16px rgba(255, 80, 48, 0.22), inset 0 0 14px rgba(255, 130, 50, 0.09);
}
.fin-card--highlight .fin-card__amount {
  border-color: rgba(255, 120, 48, 0.7);
  box-shadow: 0 0 8px 2px rgba(255, 120, 48, 0.62), 0 0 22px 7px rgba(255, 100, 48, 0.34), 0 0 44px 16px rgba(255, 80, 48, 0.16), inset 0 0 18px rgba(255, 120, 48, 0.07);
}
.fin-card--highlight .fin-card__cta {
  border-color: rgba(255, 110, 48, 0.62);
  box-shadow: 0 0 8px 2px rgba(255, 110, 48, 0.55), 0 0 22px 7px rgba(255, 90, 48, 0.3), 0 0 44px 16px rgba(255, 80, 48, 0.14), inset 0 0 16px rgba(255, 110, 48, 0.05);
}
.fin-card--highlight:hover::after {
  box-shadow: 0 0 8px 3px rgb(255, 130, 50), 0 0 22px 8px rgba(255, 90, 48, 0.94), 0 0 44px 16px rgba(255, 48, 90, 0.72), 0 0 80px 30px rgba(255, 20, 147, 0.52), 0 0 135px 55px rgba(157, 78, 221, 0.32), 0 0 210px 88px rgba(120, 40, 200, 0.16);
}
.fin-card--highlight .fin-card__bar {
  display: none;
}

.fin-card__bar {
  display: block;
  position: relative;
  z-index: 3;
  width: 100%;
  height: 2px;
  flex-shrink: 0;
  background: linear-gradient(90deg, rgba(var(--cc1), 0.18) 0%, rgb(var(--cc1)) 45%, rgb(var(--cc2)) 70%, rgba(var(--cc2), 0.18) 100%);
  opacity: 0.35;
}

.fin-card__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  opacity: 0.12;
  box-shadow: 0 0 8px 4px rgba(var(--cc1), 1), 0 0 22px 10px rgba(var(--cc1), 0.72), 0 0 48px 20px rgba(var(--cc1), 0.38), 0 0 80px 34px rgba(var(--cc1), 0.18);
  transition: opacity 0.3s ease;
}

.fin-card__head {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 28px 28px 0;
}

.fin-card__icon-wrap {
  flex-shrink: 0;
  position: relative;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(var(--cc1), 0.12) 0%, rgba(var(--cc1), 0.05) 100%);
  border: 1.5px solid rgba(var(--cc1), 0.6);
  box-shadow: 0 0 7px 2px rgba(var(--cc1), 0.6), 0 0 18px 6px rgba(var(--cc1), 0.3), 0 0 36px 13px rgba(var(--cc1), 0.13), inset 0 0 10px rgba(var(--cc1), 0.08);
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}
.fin-card__icon-wrap svg {
  width: 24px;
  height: 24px;
  stroke: rgb(var(--cc1));
  filter: drop-shadow(0 0 6px rgba(var(--cc1), 0.9)) drop-shadow(0 0 14px rgba(var(--cc1), 0.45));
  transition: filter 0.3s ease;
}

.fin-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 30px;
  padding: 0 14px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.04em;
  white-space: nowrap;
  flex-shrink: 0;
}
.fin-card__badge--hot {
  background: rgba(255, 120, 48, 0.1);
  color: #FFB868;
  border: 1.5px solid rgba(255, 120, 48, 0.62);
  box-shadow: 0 0 7px 2px rgba(255, 120, 48, 0.42), 0 0 18px 5px rgba(255, 100, 48, 0.2), 0 0 34px 11px rgba(255, 80, 48, 0.09), inset 0 0 10px rgba(255, 120, 48, 0.06);
  text-shadow: 0 0 10px rgba(255, 140, 60, 0.75);
}
.fin-card__badge--neutral {
  background: rgba(157, 78, 221, 0.1);
  color: #C898FF;
  border: 1.5px solid rgba(157, 78, 221, 0.42);
  box-shadow: 0 0 7px 2px rgba(157, 78, 221, 0.32), 0 0 18px 5px rgba(157, 78, 221, 0.16);
}
.fin-card__badge--cyan {
  background: rgba(0, 245, 255, 0.07);
  color: #72F2FF;
  border: 1.5px solid rgba(0, 245, 255, 0.4);
  box-shadow: 0 0 7px 2px rgba(0, 245, 255, 0.36), 0 0 18px 5px rgba(0, 245, 255, 0.16);
  text-shadow: 0 0 10px rgba(0, 245, 255, 0.65);
}

.fin-card__body {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 24px 28px 0;
  gap: 22px;
}

.fin-card__title {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.22;
  color: #FFFFFF;
  text-shadow: 0 0 24px rgba(var(--cc1), 0.18), 0 1px 5px rgba(0, 0, 0, 0.9);
  margin: 0;
}

.fin-card__desc {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.72;
  color: #888899;
  margin: 0;
}

.fin-card__amount {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(var(--cc1), 0.09) 0%, rgba(var(--cc2), 0.04) 100%);
  border: 1.5px solid rgba(var(--cc1), 0.42);
  box-shadow: 0 0 7px 2px rgba(var(--cc1), 0.32), 0 0 20px 6px rgba(var(--cc1), 0.16), 0 0 40px 14px rgba(var(--cc1), 0.07), inset 0 0 16px rgba(var(--cc1), 0.05);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.fin-card__amount-value {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: clamp(26px, 2.2vw, 38px);
  line-height: 1;
  letter-spacing: -0.02em;
  white-space: nowrap;
  flex-shrink: 0;
  background: linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, rgb(var(--cc1)) 48%, #ffffff) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 16px rgba(var(--cc1), 0.75)) drop-shadow(0 2px 5px rgba(0, 0, 0, 0.9));
}

.fin-card__amount-context {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 13px;
  line-height: 1.48;
  color: #6868A0;
}
.fin-card__amount-context small {
  display: block;
  font-size: 11px;
  color: #50506A;
  margin-top: 3px;
}

.fin-card__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.fin-card__list li {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.58;
  color: #B0B0CC;
}

.fin-card__check {
  flex-shrink: 0;
  width: 17px;
  height: 17px;
  margin-top: 1px;
  color: rgb(var(--cc1));
  filter: drop-shadow(0 0 5px rgba(var(--cc1), 0.92)) drop-shadow(0 0 12px rgba(var(--cc1), 0.48));
}

.fin-card__divider {
  display: block;
  height: 1px;
  margin: 14px 28px 0;
  background: linear-gradient(90deg, transparent 0%, rgba(var(--cc1), 0.2) 25%, rgba(var(--cc2), 0.12) 75%, transparent 100%);
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

.fin-card__foot {
  position: relative;
  z-index: 2;
  padding: 22px 28px 28px;
  margin-top: auto;
}

.fin-card__cta {
  display: flex;
  align-items: center;
  width: 100%;
  height: 56px;
  padding: 0 24px;
  border-radius: 50px;
  text-decoration: none;
  box-sizing: border-box;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
  color: rgb(var(--cc1));
  text-shadow: 0 0 10px rgba(var(--cc1), 0.52);
  background: rgba(var(--cc1), 0.06);
  border: 1.5px solid rgba(var(--cc1), 0.42);
  box-shadow: 0 0 7px 2px rgba(var(--cc1), 0.28), 0 0 20px 6px rgba(var(--cc1), 0.14), 0 0 40px 14px rgba(var(--cc1), 0.06), inset 0 0 14px rgba(var(--cc1), 0.04);
  transition: color 0.28s ease, text-shadow 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease, background 0.28s ease;
}

.fin-card__cta-text {
  flex: 1;
  pointer-events: none;
}

.fin-card__cta-arrow {
  flex-shrink: 0;
  width: 17px;
  height: 17px;
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.fin-panel {
  display: none;
}
.fin-panel.is-active {
  display: block;
  animation: finPanelIn 0.32s ease forwards;
}

@keyframes finPanelIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 1060px) {
  .fin-card__amount-value {
    font-size: 24px;
  }
  .fin-card__title {
    font-size: 18px;
  }
}
@media (max-width: 900px) {
  .fin-card__head,
  .fin-card__body,
  .fin-card__foot {
    padding-left: 22px;
    padding-right: 22px;
  }
  .fin-card__divider {
    margin-left: 22px;
    margin-right: 22px;
  }
}
.fin-notice-wrap {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 8px 0 72px;
}

.fin-notice {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: linear-gradient(145deg, rgba(6, 2, 14, 0.94) 0%, rgba(8, 3, 20, 0.92) 35%, rgba(12, 4, 28, 0.9) 70%, rgba(14, 5, 32, 0.92) 100%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 28px;
  overflow: hidden;
  border: none;
  padding: 56px 72px 60px;
}
@media (max-width: 680px) {
  .fin-notice {
    padding: 42px 30px 44px;
  }
}
.fin-notice::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 28px;
  padding: 2px;
  background: conic-gradient(from 175deg at 50% 50%, #FF9000 0deg, #FF6B35 42deg, #FF3060 88deg, #FF1493 132deg, #CC22CC 176deg, #9D4EDD 220deg, #7B2FBE 265deg, #9D4EDD 308deg, #FF1493 330deg, #FF6B35 348deg, #FF9000 360deg);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
}
.fin-notice::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 32px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 6px 2px rgba(255, 130, 50, 0.9), 0 0 18px 6px rgba(255, 90, 48, 0.72), 0 0 36px 13px rgba(255, 48, 90, 0.52), 0 0 65px 24px rgba(255, 20, 147, 0.34), 0 0 110px 44px rgba(157, 78, 221, 0.2), 0 0 170px 72px rgba(120, 40, 200, 0.1);
}

.fin-notice__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  pointer-events: none;
  z-index: 3;
  box-shadow: 0 0 8px 4px rgba(255, 130, 50, 0.95), 0 0 22px 10px rgba(255, 80, 50, 0.78), 0 0 48px 22px rgba(255, 20, 147, 0.46), 0 0 85px 38px rgba(157, 78, 221, 0.22);
}

.fin-notice__hotspot-bl {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  pointer-events: none;
  z-index: 3;
  box-shadow: 0 0 8px 4px rgba(255, 20, 147, 0.8), 0 0 22px 10px rgba(200, 30, 180, 0.55), 0 0 48px 22px rgba(157, 78, 221, 0.32), 0 0 85px 38px rgba(120, 40, 200, 0.15);
}

.fin-notice__title {
  position: relative;
  z-index: 2;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.18;
  color: #FFFFFF;
  margin: 0 0 20px;
  letter-spacing: -0.01em;
  text-shadow: 0 0 30px rgba(200, 100, 255, 0.18), 0 2px 8px rgba(0, 0, 0, 0.85);
}

.fin-notice__desc {
  position: relative;
  z-index: 2;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 1.3vw, 17px);
  line-height: 1.75;
  color: #8888AA;
  margin: 0 0 44px;
  max-width: 660px;
  text-align: center;
}

.fin-notice__cta-wrap {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 760px;
}

.fin-notice__cta {
  height: 66px;
  padding: 0 36px;
  gap: 14px;
  border-radius: 50px;
  font-size: clamp(13px, 1.15vw, 16px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  width: 100%;
  justify-content: center;
}
.fin-notice__cta:hover .fin-notice__cta-arrow {
  transform: translateX(5px);
}

@media (max-width: 767px) {
  .fin-notice__cta {
    min-height: 52px;
    height: auto;
    padding: 11px 18px;
    gap: 10px;
    font-size: 12px;
    letter-spacing: 0.05em;
  }
  .fin-notice__cta-arrow {
    width: 16px;
    height: 16px;
  }
}
.fin-notice__cta-text {
  pointer-events: none;
}

.fin-notice__cta-arrow {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  stroke: #FFFFFF;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.9;
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.fin-notice__footnote {
  position: relative;
  z-index: 2;
  margin-top: 20px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #55557A;
  letter-spacing: 0.03em;
  text-align: center;
}
.fin-notice__footnote span {
  color: #6A6A90;
  margin: 0 8px;
}

.front-advisor-modal {
  position: fixed;
  inset: 0;
  z-index: 1000000000002;
  display: grid;
  place-items: center;
  padding: clamp(16px, 2vw, 24px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 180ms ease, visibility 180ms ease;
}

/* Keep modal out of normal flow even with global `.front-v2-page > *` layering rules. */
.front-v2-page > .front-advisor-modal {
  position: fixed;
  inset: 0;
  z-index: 1000000000002;
}

.front-advisor-modal[aria-hidden=false] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.front-advisor-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.front-advisor-modal__overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 0;
  background: rgba(7, 6, 18, 0.72);
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
}

.front-advisor-modal__panel {
  position: relative;
  z-index: 1;
  width: min(700px, 100vw - 28px);
  border-radius: 22px;
  border: 1px solid rgba(129, 233, 255, 0.24);
  background: radial-gradient(circle at 10% 0%, rgba(100, 246, 255, 0.15) 0%, transparent 52%), radial-gradient(circle at 92% 0%, rgba(255, 93, 204, 0.2) 0%, transparent 54%), linear-gradient(160deg, rgba(25, 15, 54, 0.96) 0%, rgba(17, 10, 39, 0.98) 100%);
  box-shadow: 0 24px 60px rgba(8, 4, 20, 0.56), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  padding: clamp(18px, 2.2vw, 30px);
}

.front-advisor-modal__close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(129, 233, 255, 0.3);
  background: rgba(255, 255, 255, 0.07);
  color: #fff;
  font-size: 20px;
  line-height: 1;
}

.front-advisor-modal__kicker {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(170, 243, 255, 0.92);
  font-weight: 700;
}

.front-advisor-modal__title {
  margin: 10px 0 0;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(24px, 2.1vw, 34px);
  line-height: 1.14;
  color: #fff;
}

.front-advisor-modal__lead {
  margin: 10px 0 0;
  color: rgba(220, 232, 255, 0.82);
  font-size: 14px;
  line-height: 1.6;
}

.front-advisor-modal__form {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.front-advisor-modal__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.front-advisor-modal__field--full {
  grid-column: 1/-1;
}

.front-advisor-modal__field span {
  color: rgba(232, 242, 255, 0.88);
  font-size: 12px;
  font-weight: 600;
}

.front-advisor-modal__field input,
.front-advisor-modal__field textarea {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(127, 238, 255, 0.26);
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  padding: 10px 12px;
}

.front-advisor-modal__field textarea {
  resize: vertical;
}

.front-advisor-modal__actions {
  grid-column: 1/-1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

.front-advisor-modal__submit {
  min-width: 220px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.front-advisor-modal__submit-label {
  transition: opacity 0.2s ease;
}

.front-advisor-modal__submit-loader {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.32);
  border-top-color: #00f5ff;
  animation: frontAdvisorSpin 0.8s linear infinite;
  display: none;
}

.front-advisor-modal__submit.is-loading {
  cursor: wait;
}

.front-advisor-modal__submit.is-loading .front-advisor-modal__submit-label {
  opacity: 0.65;
}

.front-advisor-modal__submit.is-loading .front-advisor-modal__submit-loader {
  display: inline-flex;
}

.front-advisor-modal__feedback {
  grid-column: 1/-1;
  margin: 4px 0 0;
  min-height: 20px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(170, 243, 255, 0.94);
}

.front-advisor-modal__mail-link {
  color: rgba(170, 243, 255, 0.96);
  text-decoration: none;
  font-weight: 600;
}

body.front-advisor-modal-open {
  overflow: hidden;
}

@media (max-width: 760px) {
  .front-advisor-modal__form {
    grid-template-columns: 1fr;
  }
}
@keyframes frontAdvisorSpin {
  to {
    transform: rotate(360deg);
  }
}
.front-v2-page {
  position: relative;
  min-height: 100vh;
  overflow-x: clip;
  overflow-y: visible;
  background: #0a0a0f;
  color: #ffffff;
  font-family: "Inter", sans-serif;
}

.front-v2-page::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: clamp(980px, 100vh + 320px, 1500px);
  z-index: 0;
  background-image: url("/img/front-v2/hero-cosmic-bg.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  pointer-events: none;
}

.front-v2-page::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: clamp(980px, 100vh + 320px, 1500px);
  z-index: 0;
  background: linear-gradient(180deg, rgba(10, 10, 15, 0.04) 0%, rgba(10, 10, 15, 0.16) 56%, rgba(10, 10, 15, 0.94) 100%);
  pointer-events: none;
}

.front-v2-page > * {
  position: relative;
  z-index: 1;
}

.front-v2-nav {
  position: sticky;
  top: 0;
  z-index: 40;
  padding-top: clamp(8px, 0.85vw, 14px);
  background: transparent;
}

.front-v2-nav__inner {
  position: relative;
  width: min(1680px, 100% - clamp(18px, 2.4vw, 56px));
  margin: 0 auto;
  padding: 12px clamp(18px, 2vw, 34px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-radius: 22px;
  border: 1px solid rgba(204, 152, 255, 0.42);
  background: linear-gradient(180deg, rgba(20, 13, 39, 0.28) 0%, rgba(11, 8, 24, 0.44) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.26), inset 0 -1px 0 rgba(255, 83, 173, 0.24), 0 10px 26px rgba(5, 4, 16, 0.34), 0 0 22px rgba(157, 78, 221, 0.2);
}

.front-v2-nav__inner::before {
  content: "";
  pointer-events: none;
  position: absolute;
  top: -1px;
  right: 10%;
  width: clamp(180px, 20vw, 360px);
  height: 3px;
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(171, 107, 255, 0.95) 0%, rgba(171, 107, 255, 0.16) 70%, transparent 100%);
}

.front-v2-nav__inner::after {
  content: "";
  pointer-events: none;
  position: absolute;
  bottom: -1px;
  left: 54%;
  transform: translateX(-50%);
  width: clamp(260px, 34vw, 560px);
  height: 3px;
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(255, 86, 168, 0.9) 0%, rgba(255, 86, 168, 0.14) 72%, transparent 100%);
}

.front-v2-nav__brand {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  line-height: 1;
  white-space: nowrap;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  color: #ffffff;
  text-decoration: none;
}

.front-v2-nav__brand-main {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(30px, 2.3vw, 42px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #fff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.16);
}

.front-v2-nav__brand-dot {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(30px, 2.3vw, 42px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.96);
}

.front-v2-nav__brand-sub {
  font-family: "Inter", sans-serif;
  font-size: clamp(22px, 1.6vw, 32px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.12);
}

.front-v2-nav__links {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.4vw, 46px);
  margin-inline: auto;
}

.front-v2-nav__links a {
  color: rgba(255, 255, 255, 0.96);
  text-decoration: none;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(15px, 1.04vw, 20px);
  font-weight: 700;
  line-height: 1.08;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.1);
  transition: color 180ms ease, text-shadow 180ms ease, opacity 180ms ease;
}

.front-v2-nav__links a:hover {
  color: #fff;
  text-shadow: 0 0 14px rgba(255, 255, 255, 0.26);
}

.front-v2-nav__cta-btn {
  white-space: nowrap;
  padding: 8px 24px;
  font-size: clamp(14px, 0.96vw, 18px);
  line-height: 1;
  text-decoration: none;
}

.front-v2-nav__account-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  min-height: 40px;
  padding: 8px 18px;
  border-radius: 9999px;
  border: 1px solid rgba(214, 170, 255, 0.46);
  background: linear-gradient(180deg, rgba(24, 14, 44, 0.68) 0%, rgba(10, 8, 26, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 14px rgba(157, 78, 221, 0.18);
  color: rgba(255, 255, 255, 0.95);
  text-decoration: none;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(13px, 0.9vw, 16px);
  font-weight: 700;
  line-height: 1;
  transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

.front-v2-nav__account-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 196, 232, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 18px rgba(255, 20, 147, 0.24);
}

.front-v2-nav__actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.front-v2-btn-primary {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.6);
  background: linear-gradient(100deg, #ff6b35 0%, #ff2a73 58%, #8f4cff 100%);
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.55);
  box-shadow: 0 0 18px rgba(255, 109, 53, 0.35), 0 0 30px rgba(255, 20, 147, 0.45), 0 0 42px rgba(157, 78, 221, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.45);
  transition: transform 300ms ease, box-shadow 300ms ease, filter 300ms ease;
}

.front-v2-btn-primary::before {
  content: "";
  pointer-events: none;
  position: absolute;
  inset-inline: 1rem;
  top: 1px;
  height: 42%;
  border-radius: 9999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.45) 0%, rgba(255, 255, 255, 0) 100%);
}

.front-v2-btn-primary::after {
  content: "";
  pointer-events: none;
  position: absolute;
  bottom: -9px;
  left: 50%;
  width: 7rem;
  height: 12px;
  transform: translateX(-50%);
  border-radius: 9999px;
  background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.8;
  filter: blur(3px);
}

.front-v2-btn-primary:hover {
  transform: scale(1.02);
  box-shadow: 0 0 20px rgba(255, 109, 53, 0.45), 0 0 34px rgba(255, 20, 147, 0.62), 0 0 56px rgba(157, 78, 221, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.56);
}

.front-v2-btn-primary:active {
  transform: scale(0.98);
}

@media (max-width: 767px) {
  .front-v2-btn-primary {
    min-height: 48px;
    padding: 10px 16px;
    font-size: 0.92rem;
    line-height: 1.2;
    text-align: center;
  }
}
.front-v2-nav__toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(29, 21, 50, 0.72) 0%, rgba(15, 10, 30, 0.82) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16), 0 8px 16px rgba(5, 4, 16, 0.35);
  padding: 9px;
  gap: 4px;
  flex-direction: column;
  justify-content: center;
  cursor: pointer;
}

.front-v2-nav__toggle span {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
}

.front-v2-mobile-drawer {
  display: none;
}

body.front-v2-nav-open {
  overflow: hidden;
}

.front-v2-hero {
  position: relative;
  z-index: 2;
  width: min(1680px, 100%);
  margin: 0 auto;
  padding: clamp(18px, 1.8vw, 28px) clamp(14px, 1.2vw, 20px) clamp(14px, 1.5vw, 20px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(580px, 0.88fr);
  gap: clamp(16px, 2vw, 30px);
  align-items: start;
}

.front-v2-hero::after {
  content: none;
}

.home-hero::after {
  content: none;
}

.front-v2-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 50px;
  border: 1px solid rgba(255, 255, 255, 0.68);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(103, 62, 162, 0.24) 100%);
  color: #fff;
  font-family: "Space Grotesk", sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 9px 30px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28), 0 0 24px rgba(157, 78, 221, 0.34);
}

.front-v2-badge__dot {
  width: 7px;
  height: 7px;
  border-radius: 9999px;
  background: #00e9ff;
  box-shadow: 0 0 10px rgba(0, 233, 255, 0.9);
}

.front-v2-title {
  margin: 12px 0 0;
  max-width: 980px;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: clamp(64px, 4.45vw, 88px);
  line-height: 0.88;
  letter-spacing: -0.028em;
  text-shadow: 0 4px 14px rgba(0, 0, 0, 0.82);
}

.front-v2-title__line {
  display: block;
}

.front-v2-title__line--mix {
  color: #fff;
}

.front-v2-title__accent {
  background: linear-gradient(102deg, #ff7a18 0%, #ff426f 54%, #cc43ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  -webkit-text-stroke: 0.35px rgba(255, 255, 255, 0.12);
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.14), 0 8px 14px rgba(0, 0, 0, 0.54), 0 0 18px rgba(255, 64, 160, 0.34);
}

.front-v2-title__line--gradient {
  white-space: nowrap;
  background: linear-gradient(102deg, #ff7a18 0%, #ff426f 54%, #cc43ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  -webkit-text-stroke: 0.35px rgba(255, 255, 255, 0.12);
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.14), 0 8px 14px rgba(0, 0, 0, 0.54), 0 0 20px rgba(255, 20, 147, 0.36);
}

.front-v2-lead {
  margin: 18px 0 0;
  max-width: 980px;
  color: rgba(255, 255, 255, 0.92);
  font-size: clamp(22px, 1.38vw, 30px);
  font-family: "Inter", sans-serif;
  font-weight: 600;
  line-height: 1.24;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}

.front-v2-subtext {
  margin: 10px 0 0;
  max-width: 880px;
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(17px, 1.08vw, 22px);
  font-family: "Inter", sans-serif;
  font-weight: 400;
  line-height: 1.38;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}

.front-v2-actions {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.front-v2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  padding: 11px 26px;
  text-decoration: none;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 1.2vw, 28px);
  line-height: 1;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.front-v2-btn:hover {
  transform: translateY(-1px);
}

.front-v2-btn--primary {
  background: linear-gradient(135deg, #ff6b35 0%, #ff1493 100%);
  color: #fff;
  box-shadow: 0 0 25px rgba(255, 20, 147, 0.45);
}

.front-v2-btn--primary:hover {
  box-shadow: 0 0 35px rgba(255, 20, 147, 0.7);
}

.front-v2-btn--secondary {
  border: 2px solid rgba(255, 255, 255, 0.3);
  color: #fff;
  background: rgba(9, 10, 20, 0.42);
}

.front-v2-btn--secondary:hover {
  background: rgba(255, 255, 255, 0.08);
}

.front-v2-metrics {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 650px;
}

.front-v2-metric {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: rgba(255, 255, 255, 0.18);
  padding: 10px 10px;
  text-align: center;
}

.front-v2-metric__value {
  display: block;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(28px, 1.8vw, 40px);
  font-weight: 800;
  line-height: 1;
}

.front-v2-metric__label {
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.84);
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.front-v2-panel {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: rgba(194, 129, 255, 0.45);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 42px rgba(157, 78, 221, 0.38);
  padding: 18px 18px 18px;
  position: relative;
  z-index: 2;
}

.front-v2-panel::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 52px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
}

.front-v2-panel__eyebrow {
  font-family: "Space Grotesk", sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(90deg, #00f5ff 0%, #3be9ff 38%, #ff4f78 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.front-v2-panel__title {
  margin: 14px 0 0;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: clamp(28px, 2.35vw, 62px);
  line-height: 1.06;
  color: #fff;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}

.front-v2-panel__text {
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(16px, 1vw, 20px);
  line-height: 1.4;
}

.front-v2-field {
  margin-top: 8px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  padding: 10px 12px;
}

.front-v2-field__label {
  display: block;
  color: #9ad7ff;
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
}

.front-v2-field__value {
  margin-top: 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: clamp(16px, 1.1vw, 20px);
  color: #fff;
}

.front-v2-field__value strong {
  color: rgba(186, 147, 255, 0.9);
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
}

.front-v2-panel__cta {
  margin-top: 10px;
  width: 100%;
}

.front-v2-panel__cta .front-v2-btn {
  width: 100%;
  font-size: clamp(20px, 1.2vw, 28px);
  padding-block: 11px;
}

.hero-kicker-badge {
  align-self: flex-start;
}

@media (max-width: 640px) {
  .hero-kicker-badge .neon-badge-rail__trail {
    display: none;
  }
  .hero-kicker-badge .neon-badge__inner {
    padding: 8px 14px;
    font-size: 10px;
    letter-spacing: 0.1em;
  }
}
.hero-lead-strong {
  font-family: "Inter", sans-serif;
  text-shadow: 1px 1px 6px rgba(0, 0, 0, 0.8);
}

.hero-lead-text {
  font-family: "Inter", sans-serif;
  color: rgba(255, 255, 255, 0.84);
  text-shadow: 1px 1px 6px rgba(0, 0, 0, 0.75);
}

.hero-btn-secondary {
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.04);
  border: 2px solid rgba(255, 255, 255, 0.3);
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.6);
}

.hero-diagnostic-shell {
  background: linear-gradient(140deg, rgba(31, 20, 54, 0.78) 0%, rgba(18, 13, 34, 0.84) 58%, rgba(16, 12, 30, 0.88) 100%);
  border: 1px solid rgba(196, 146, 255, 0.74);
  box-shadow: 0 0 0 1px rgba(236, 198, 255, 0.2), 0 20px 32px rgba(7, 6, 16, 0.44), inset 0 1px 0 rgba(255, 255, 255, 0.26), inset 0 -1px 0 rgba(157, 78, 221, 0.38);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.hero-diagnostic-shell__highlight {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.hero-diagnostic-kicker {
  font-family: "Space Grotesk", sans-serif;
  color: #00f5ff;
}

.hero-diagnostic-kicker-accent {
  color: #ff4f78;
}

.hero-diagnostic-title {
  font-family: "Montserrat", sans-serif;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.9);
}

.hero-diagnostic-description {
  color: rgba(255, 255, 255, 0.82);
  font-family: "Inter", sans-serif;
}

.hero-diagnostic-field {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.055) 0%, rgba(255, 255, 255, 0.022) 100%);
  border: 1px solid rgba(190, 138, 255, 0.52);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 8px 16px rgba(9, 6, 20, 0.42);
}

.hero-diagnostic-field-label {
  font-family: "Space Grotesk", sans-serif;
  color: rgba(255, 255, 255, 0.72);
}

.hero-diagnostic-field-value {
  font-family: "Inter", sans-serif;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
}

.front-v2-main {
  position: relative;
  z-index: 2;
  width: min(1680px, 100%);
  margin: 0 auto;
  padding-inline: clamp(14px, 1.2vw, 20px);
}

.front-v2-section {
  padding-block: clamp(52px, 6vw, 86px);
}

.front-v2-section--fade::before,
.front-v2-section--fade::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: clamp(72px, 8vw, 132px);
  z-index: 2;
  pointer-events: none;
}

.front-v2-section--fade::before {
  top: 0;
  background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0.82) 28%, rgba(0, 0, 0, 0.38) 64%, rgba(0, 0, 0, 0) 100%);
}

.front-v2-section--fade::after {
  bottom: 0;
  background: linear-gradient(0deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0.82) 30%, rgba(0, 0, 0, 0.4) 66%, rgba(0, 0, 0, 0) 100%);
}

.front-v2-section-divider {
  position: relative;
  z-index: 3;
  width: 100%;
  height: clamp(34px, 4.2vw, 64px);
  margin-top: -1px;
  margin-bottom: -1px;
  background: #000;
  pointer-events: none;
  overflow: visible;
}
.front-v2-section-divider::before, .front-v2-section-divider::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: clamp(28px, 3.6vw, 52px);
  pointer-events: none;
}
.front-v2-section-divider::before {
  bottom: 100%;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.52) 42%, rgba(0, 0, 0, 0.86) 72%, rgb(0, 0, 0) 100%);
}
.front-v2-section-divider::after {
  top: 100%;
  background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0.86) 30%, rgba(0, 0, 0, 0.52) 62%, rgba(0, 0, 0, 0) 100%);
}

.front-v2-section-title {
  margin: 8px 0 0;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 2vw, 42px);
  line-height: 1.15;
  color: #ffffff;
}

.front-v2-card {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: 0 12px 28px rgba(3, 7, 20, 0.45);
}

.front-v2-glass {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: rgba(194, 129, 255, 0.28);
  box-shadow: 0 20px 34px rgba(5, 8, 20, 0.38);
}

.formations-showcase__bg {
  background-image: url("/img/front-v2/formations-showcase-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.financement-showcase__bg {
  background-image: url("/img/front-v2/financement-showcase-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.financement-badge-gradient {
  background: linear-gradient(95deg, #ff6b35 0%, #9d4edd 100%);
}

.methode-showcase__bg {
  background-image: url("/img/front-v2/methode-showcase-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.methode-badge-gradient {
  background: linear-gradient(95deg, #ff6b35 0%, #9d4edd 100%);
}

.methode-grid-perspective {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) perspective(400px) rotateX(60deg);
  width: 140%;
  height: 200px;
  background-image: linear-gradient(rgba(157, 78, 221, 0.15) 1px, transparent 1px), linear-gradient(90deg, rgba(157, 78, 221, 0.15) 1px, transparent 1px);
  background-size: 60px 60px;
  transform-origin: bottom center;
  opacity: 0.5;
  mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
}

.methode-timeline {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 12px;
}
.methode-timeline__numbers {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.methode-timeline__number-slot {
  flex: 1;
  display: flex;
  justify-content: center;
}
.methode-timeline__cards {
  display: flex;
  align-items: stretch;
  gap: 16px;
}
@media (max-width: 1023px) {
  .methode-timeline__numbers {
    display: none;
  }
  .methode-timeline__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
  .methode-timeline__cards .methode-cards-connector {
    display: none;
  }
}
@media (max-width: 767px) {
  .methode-timeline__cards {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.methode-cards-connector {
  flex: 0 0 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
}

.methode-cards-connector__dot {
  width: 10px;
  height: 10px;
  border-radius: 9999px;
  background: #fff;
  box-shadow: 0 0 10px 2px rgb(255, 255, 255), 0 0 26px rgba(255, 107, 53, 0.95), 0 0 52px rgba(255, 20, 147, 0.8), 0 0 84px rgba(157, 78, 221, 0.55);
}

@keyframes methode-pulse {
  0%, 100% {
    box-shadow: 0 0 20px rgba(255, 0, 110, 0.8), 0 0 40px rgba(255, 20, 147, 0.5);
  }
  50% {
    box-shadow: 0 0 30px rgb(255, 0, 110), 0 0 60px rgba(255, 20, 147, 0.8), 0 0 80px rgba(255, 20, 147, 0.3);
  }
}
.methode-featured-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(95deg, rgba(255, 0, 110, 0.3) 0%, rgba(255, 20, 147, 0.5) 100%);
  border: 1px solid rgba(255, 72, 150, 0.55);
  border-radius: 100px;
  padding: 8px 18px;
  white-space: nowrap;
  box-shadow: 0 0 20px rgba(255, 0, 110, 0.8), 0 0 40px rgba(255, 20, 147, 0.5), 0 0 60px rgba(255, 20, 147, 0.2);
  animation: methode-pulse 2.5s ease-in-out infinite;
}

.methode-connector {
  flex: 1;
  position: relative;
  min-width: 0;
  height: 28px;
}
.methode-connector::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 22px;
  transform: translateY(-50%);
  filter: blur(10px);
  opacity: 0.28;
  pointer-events: none;
  z-index: 0;
}
.methode-connector::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 7px;
  transform: translateY(-50%);
  filter: blur(3px);
  opacity: 0.62;
  pointer-events: none;
  z-index: 1;
}
.methode-connector--1::before {
  background: linear-gradient(90deg, rgb(0, 245, 255) 0%, rgb(255, 107, 53) 100%);
}
.methode-connector--1::after {
  background: linear-gradient(90deg, rgb(0, 245, 255) 0%, rgb(255, 107, 53) 100%);
}
.methode-connector--2::before {
  background: linear-gradient(90deg, rgb(255, 107, 53) 0%, rgb(255, 20, 147) 100%);
}
.methode-connector--2::after {
  background: linear-gradient(90deg, rgb(255, 107, 53) 0%, rgb(255, 20, 147) 100%);
}
.methode-connector--3::before {
  background: rgb(255, 20, 147);
}
.methode-connector--3::after {
  background: rgb(255, 20, 147);
}
.methode-connector--4::before {
  background: linear-gradient(90deg, rgb(255, 20, 147) 0%, rgb(157, 78, 221) 100%);
}
.methode-connector--4::after {
  background: linear-gradient(90deg, rgb(255, 20, 147) 0%, rgb(157, 78, 221) 100%);
}

.methode-connector__line {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 1.5px;
  border-radius: 999px;
  z-index: 2;
  pointer-events: none;
}
.methode-connector__line::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  z-index: 5;
}
.methode-connector__line::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(50%, -50%);
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  z-index: 5;
}

.methode-connector__line--1 {
  background: linear-gradient(90deg, rgba(0, 245, 255, 0.9) 0%, rgba(255, 107, 53, 0.9) 100%);
}

.methode-connector__line--2 {
  background: linear-gradient(90deg, rgba(255, 107, 53, 0.9) 0%, rgba(255, 20, 147, 0.9) 100%);
}

.methode-connector__line--3 {
  background: rgba(255, 20, 147, 0.9);
}

.methode-connector__line--4 {
  background: linear-gradient(90deg, rgba(255, 20, 147, 0.9) 0%, rgba(157, 78, 221, 0.9) 100%);
}

.methode-connector--1 .methode-connector__line::before {
  box-shadow: 0 0 6px 4px rgb(0, 245, 255), 0 0 16px 8px rgba(0, 245, 255, 0.75), 0 0 34px 14px rgba(0, 245, 255, 0.4), 0 0 56px 20px rgba(0, 245, 255, 0.18);
}
.methode-connector--1 .methode-connector__line::after {
  box-shadow: 0 0 6px 4px rgb(255, 120, 50), 0 0 16px 8px rgba(255, 107, 53, 0.75), 0 0 34px 14px rgba(255, 107, 53, 0.4), 0 0 56px 20px rgba(255, 107, 53, 0.18);
}

.methode-connector--2 .methode-connector__line::before {
  box-shadow: 0 0 6px 4px rgb(255, 120, 50), 0 0 16px 8px rgba(255, 107, 53, 0.75), 0 0 34px 14px rgba(255, 107, 53, 0.4), 0 0 56px 20px rgba(255, 107, 53, 0.18);
}
.methode-connector--2 .methode-connector__line::after {
  box-shadow: 0 0 6px 4px rgb(255, 20, 147), 0 0 16px 8px rgba(255, 20, 147, 0.78), 0 0 34px 14px rgba(255, 20, 147, 0.45), 0 0 56px 20px rgba(255, 20, 147, 0.2);
}

.methode-connector--3 .methode-connector__line::before, .methode-connector--3 .methode-connector__line::after {
  box-shadow: 0 0 7px 5px rgb(255, 20, 147), 0 0 18px 10px rgba(255, 20, 147, 0.85), 0 0 38px 16px rgba(255, 20, 147, 0.55), 0 0 64px 24px rgba(255, 20, 147, 0.25);
}

.methode-connector--4 .methode-connector__line::before {
  box-shadow: 0 0 6px 4px rgb(255, 20, 147), 0 0 16px 8px rgba(255, 20, 147, 0.75), 0 0 34px 14px rgba(255, 20, 147, 0.42), 0 0 56px 20px rgba(255, 20, 147, 0.18);
}
.methode-connector--4 .methode-connector__line::after {
  box-shadow: 0 0 6px 4px rgb(185, 95, 255), 0 0 16px 8px rgba(157, 78, 221, 0.8), 0 0 34px 14px rgba(157, 78, 221, 0.46), 0 0 56px 20px rgba(157, 78, 221, 0.2);
}

.methode-connector__line {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 1.5px;
  border-radius: 999px;
  z-index: 2;
  pointer-events: none;
}
.methode-connector__line--1 {
  background: linear-gradient(90deg, rgba(0, 245, 255, 0.95) 0%, rgba(255, 107, 53, 0.95) 100%);
}
.methode-connector__line--2 {
  background: linear-gradient(90deg, rgba(255, 107, 53, 0.95) 0%, rgba(255, 20, 147, 0.95) 100%);
}
.methode-connector__line--3 {
  background: rgba(255, 20, 147, 0.95);
}
.methode-connector__line--4 {
  background: linear-gradient(90deg, rgba(255, 20, 147, 0.95) 0%, rgba(157, 78, 221, 0.95) 100%);
}

.methode-connector__tip {
  position: absolute;
  top: 50%;
  width: 3px;
  height: 3px;
  border-radius: 9999px;
  background: transparent;
  z-index: 10;
  pointer-events: none;
}
.methode-connector__tip--l {
  left: 0;
  transform: translate(-50%, -50%);
}
.methode-connector__tip--r {
  right: 0;
  transform: translate(50%, -50%);
}

.methode-connector--1 .methode-connector__tip--l {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(0, 245, 255), 0 0 26px 9px rgba(0, 245, 255, 0.8), 0 0 50px 14px rgba(0, 245, 255, 0.45), 0 0 80px 20px rgba(0, 245, 255, 0.2);
}
.methode-connector--1 .methode-connector__tip--r {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(255, 120, 50), 0 0 26px 9px rgba(255, 107, 53, 0.8), 0 0 50px 14px rgba(255, 107, 53, 0.45), 0 0 80px 20px rgba(255, 107, 53, 0.2);
}

.methode-connector--2 .methode-connector__tip--l {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(255, 120, 50), 0 0 26px 9px rgba(255, 107, 53, 0.8), 0 0 50px 14px rgba(255, 107, 53, 0.45), 0 0 80px 20px rgba(255, 107, 53, 0.2);
}
.methode-connector--2 .methode-connector__tip--r {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(255, 20, 147), 0 0 26px 9px rgba(255, 20, 147, 0.82), 0 0 50px 14px rgba(255, 20, 147, 0.5), 0 0 80px 20px rgba(255, 20, 147, 0.22);
}

.methode-connector--3 .methode-connector__tip--l,
.methode-connector--3 .methode-connector__tip--r {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.6), 0 0 6px 3px rgb(255, 255, 255), 0 0 14px 6px rgb(255, 20, 147), 0 0 30px 10px rgba(255, 20, 147, 0.88), 0 0 58px 16px rgba(255, 20, 147, 0.56), 0 0 90px 22px rgba(255, 20, 147, 0.26);
}

.methode-connector--4 .methode-connector__tip--l {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(255, 20, 147), 0 0 26px 9px rgba(255, 20, 147, 0.78), 0 0 50px 14px rgba(255, 20, 147, 0.44), 0 0 80px 20px rgba(255, 20, 147, 0.2);
}
.methode-connector--4 .methode-connector__tip--r {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.55), 0 0 5px 2px rgb(255, 255, 255), 0 0 12px 5px rgb(185, 95, 255), 0 0 26px 9px rgba(157, 78, 221, 0.82), 0 0 50px 14px rgba(157, 78, 221, 0.48), 0 0 80px 20px rgba(157, 78, 221, 0.22);
}

.methode-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-width: 0;
}
.methode-step--featured {
  z-index: 10;
}
.methode-step--featured .methode-step__card {
  transform: translateY(-6px) scale(1.06);
}

.methode-step__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  flex-shrink: 0;
}
.methode-step__number span {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(26px, 2vw, 34px);
  line-height: 1;
}
.methode-step__number--cyan span {
  color: #7eefff;
  text-shadow: 0 0 14px rgba(0, 245, 255, 0.75), 0 0 30px rgba(0, 245, 255, 0.4);
}
.methode-step__number--orange span {
  color: #ff9e61;
  text-shadow: 0 0 14px rgba(255, 107, 53, 0.75), 0 0 30px rgba(255, 107, 53, 0.4);
}
.methode-step__number--rose span {
  color: #ff71c0;
  text-shadow: 0 0 16px rgba(255, 20, 147, 0.85), 0 0 34px rgba(255, 20, 147, 0.45);
}
.methode-step__number--violet span {
  color: #cf9bff;
  text-shadow: 0 0 14px rgba(157, 78, 221, 0.75), 0 0 30px rgba(157, 78, 221, 0.4);
}
.methode-step__number--gold span {
  color: #ffbb6d;
  text-shadow: 0 0 14px rgba(255, 179, 71, 0.75), 0 0 30px rgba(255, 179, 71, 0.4);
}

.methode-step__card {
  width: 100%;
  height: 100%;
  border-radius: 18px;
  padding: clamp(16px, 1.4vw, 22px);
  background: linear-gradient(180deg, rgba(15, 8, 32, 0.28) 0%, rgba(10, 6, 22, 0.34) 100%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform 250ms ease, box-shadow 250ms ease, border-color 250ms ease;
  position: relative;
  overflow: hidden;
}
.methode-step__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  border-radius: 999px;
  opacity: 1;
}
.methode-step__card:hover {
  transform: translateY(-3px);
}
.methode-step__card--cyan {
  border-color: rgba(0, 245, 255, 0.25);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 0 0 1px rgba(0, 245, 255, 0.4), 0 0 20px rgba(0, 245, 255, 0.35), 0 0 60px rgba(0, 245, 255, 0.15), 0 20px 40px rgba(0, 0, 0, 0.5);
}
.methode-step__card--cyan::before {
  background: linear-gradient(90deg, transparent, rgb(0, 245, 255), transparent);
}
.methode-step__card--cyan:hover {
  border-color: rgba(0, 245, 255, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 30px rgba(0, 245, 255, 0.18);
}
.methode-step__card--orange {
  border-color: rgba(255, 107, 53, 0.25);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 0 0 1px rgba(255, 107, 53, 0.4), 0 0 20px rgba(255, 107, 53, 0.35), 0 0 60px rgba(255, 107, 53, 0.15), 0 20px 40px rgba(0, 0, 0, 0.5);
}
.methode-step__card--orange::before {
  background: linear-gradient(90deg, transparent, rgb(255, 107, 53), transparent);
}
.methode-step__card--orange:hover {
  border-color: rgba(255, 107, 53, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 30px rgba(255, 107, 53, 0.2);
}
.methode-step__card--rose {
  border-color: rgba(255, 20, 147, 0.4);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 0 0 1px rgba(255, 20, 147, 0.55), 0 0 30px rgba(255, 20, 147, 0.5), 0 0 80px rgba(255, 20, 147, 0.25), 0 20px 40px rgba(0, 0, 0, 0.5);
}
.methode-step__card--rose::before {
  background: linear-gradient(90deg, transparent, rgb(255, 20, 147), transparent);
}
.methode-step__card--rose:hover {
  border-color: rgba(255, 20, 147, 0.4);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 30px rgba(255, 20, 147, 0.25);
}
.methode-step__card--violet {
  border-color: rgba(157, 78, 221, 0.25);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 0 0 1px rgba(157, 78, 221, 0.4), 0 0 20px rgba(157, 78, 221, 0.35), 0 0 60px rgba(157, 78, 221, 0.15), 0 20px 40px rgba(0, 0, 0, 0.5);
}
.methode-step__card--violet::before {
  background: linear-gradient(90deg, transparent, rgb(157, 78, 221), transparent);
}
.methode-step__card--violet:hover {
  border-color: rgba(157, 78, 221, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 30px rgba(157, 78, 221, 0.2);
}
.methode-step__card--gold {
  border-color: rgba(255, 179, 71, 0.25);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 0 0 1px rgba(255, 179, 71, 0.4), 0 0 20px rgba(255, 179, 71, 0.35), 0 0 60px rgba(255, 179, 71, 0.15), 0 20px 40px rgba(0, 0, 0, 0.5);
}
.methode-step__card--gold::before {
  background: linear-gradient(90deg, transparent, rgb(255, 179, 71), transparent);
}
.methode-step__card--gold:hover {
  border-color: rgba(255, 179, 71, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 30px rgba(255, 179, 71, 0.18);
}
.methode-step__card--featured {
  border-color: rgba(255, 20, 147, 0.3) !important;
  background: linear-gradient(180deg, rgba(30, 10, 34, 0.7) 0%, rgba(15, 8, 24, 0.75) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 0 0 1px rgba(255, 20, 147, 0.55), 0 0 30px rgba(255, 20, 147, 0.5), 0 0 80px rgba(255, 20, 147, 0.25), 0 20px 40px rgba(0, 0, 0, 0.5) !important;
}
.methode-step__card--featured:hover {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 0 1px rgba(255, 20, 147, 0.35), 0 0 50px rgba(255, 20, 147, 0.3), 0 0 100px rgba(255, 20, 147, 0.12) !important;
}

.methode-step__featured-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(95deg, rgba(255, 0, 110, 0.7) 0%, rgba(255, 20, 147, 0.55) 100%);
  border: 1px solid rgba(255, 72, 150, 0.5);
  border-radius: 100px;
  padding: 4px 10px;
  width: -moz-fit-content;
  width: fit-content;
  box-shadow: 0 0 10px rgba(255, 0, 110, 0.4);
}

.methode-step__header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

.methode-step__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  flex-shrink: 0;
}
.methode-step__icon--cyan {
  color: #00f5ff;
  background: radial-gradient(circle, rgba(0, 245, 255, 0.18) 0%, rgba(0, 245, 255, 0.05) 60%, transparent 100%);
  box-shadow: 0 0 0 1px rgba(0, 245, 255, 0.3), 0 0 24px rgba(0, 245, 255, 0.8), 0 0 48px rgba(0, 245, 255, 0.4);
}
.methode-step__icon--orange {
  color: #ff6b35;
  background: radial-gradient(circle, rgba(255, 107, 53, 0.18) 0%, rgba(255, 107, 53, 0.05) 60%, transparent 100%);
  box-shadow: 0 0 0 1px rgba(255, 107, 53, 0.3), 0 0 24px rgba(255, 107, 53, 0.8), 0 0 48px rgba(255, 107, 53, 0.4);
}
.methode-step__icon--rose {
  color: #ff1493;
  background: radial-gradient(circle, rgba(255, 20, 147, 0.22) 0%, rgba(255, 20, 147, 0.06) 60%, transparent 100%);
  box-shadow: 0 0 0 1px rgba(255, 20, 147, 0.4), 0 0 28px rgba(255, 20, 147, 0.9), 0 0 56px rgba(255, 20, 147, 0.45);
}
.methode-step__icon--violet {
  color: #c67aff;
  background: radial-gradient(circle, rgba(157, 78, 221, 0.2) 0%, rgba(157, 78, 221, 0.05) 60%, transparent 100%);
  box-shadow: 0 0 0 1px rgba(157, 78, 221, 0.3), 0 0 24px rgba(157, 78, 221, 0.8), 0 0 48px rgba(157, 78, 221, 0.4);
}
.methode-step__icon--gold {
  color: #ffb347;
  background: radial-gradient(circle, rgba(255, 179, 71, 0.18) 0%, rgba(255, 179, 71, 0.05) 60%, transparent 100%);
  box-shadow: 0 0 0 1px rgba(255, 179, 71, 0.3), 0 0 24px rgba(255, 179, 71, 0.8), 0 0 48px rgba(255, 179, 71, 0.4);
}

.methode-step__title {
  font-family: Montserrat, sans-serif;
  font-weight: 700;
  font-size: clamp(15px, 1.1vw, 18px);
  color: #ffffff;
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.4), 0 2px 8px rgba(0, 0, 0, 0.8);
  line-height: 1;
}

.methode-step__desc {
  font-family: Inter, sans-serif;
  font-size: clamp(13px, 0.85vw, 15px);
  color: rgba(255, 255, 255, 0.85);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.9);
  margin: 10px 0;
  line-height: 2;
  flex: 1;
}

.methode-step__badge {
  display: inline-flex;
  align-items: center;
  font-family: "Space Grotesk", sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.65);
  border-radius: 100px;
  padding: 3px 14px;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: auto;
  white-space: nowrap;
}
.methode-step__badge--cyan {
  border: 0.5px solid rgba(0, 245, 255, 0.3);
  background: rgba(0, 245, 255, 0.04);
}
.methode-step__badge--orange {
  border: 0.5px solid rgba(255, 107, 53, 0.3);
  background: rgba(255, 107, 53, 0.04);
}
.methode-step__badge--rose {
  border: 0.5px solid rgba(255, 20, 147, 0.35);
  background: rgba(255, 20, 147, 0.06);
}
.methode-step__badge--violet {
  border: 0.5px solid rgba(157, 78, 221, 0.3);
  background: rgba(157, 78, 221, 0.04);
}
.methode-step__badge--gold {
  border: 0.5px solid rgba(255, 179, 71, 0.3);
  background: rgba(255, 179, 71, 0.04);
}

@media (max-width: 767px) {
  #methode .methode-grid-perspective {
    width: 170%;
    opacity: 0.34;
  }
  .methode-timeline {
    gap: 14px;
  }
  .methode-timeline__cards {
    display: flex !important;
    flex-direction: column;
    gap: 14px !important;
  }
  .methode-step {
    padding-left: 0;
    margin: 0;
  }
  .methode-step::before {
    content: none;
  }
  .methode-step__card {
    min-height: 176px;
    border-radius: 22px;
    padding: 16px 15px 15px;
    gap: 9px;
    background: linear-gradient(155deg, rgba(24, 14, 44, 0.88) 0%, rgba(12, 8, 27, 0.95) 60%, rgba(9, 7, 22, 0.96) 100%);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 14px 28px rgba(2, 1, 9, 0.52) !important;
  }
  .methode-step__card:hover {
    transform: none;
  }
  .methode-step--featured {
    z-index: 4;
  }
  .methode-step--featured .methode-step__card {
    transform: none !important;
    border-color: rgba(255, 20, 147, 0.72) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 0 1px rgba(255, 20, 147, 0.6), 0 0 26px rgba(255, 20, 147, 0.45), 0 0 62px rgba(255, 20, 147, 0.22), 0 16px 30px rgba(1, 1, 8, 0.62) !important;
  }
  .methode-step__header {
    gap: 9px;
    margin-top: 0;
  }
  .methode-step__icon {
    width: 38px;
    height: 38px;
    border-radius: 11px;
  }
  .methode-step__title {
    font-size: 17px;
  }
  .methode-step__desc {
    margin: 6px 0 10px;
    font-size: 13.5px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.9);
  }
  .methode-step__badge {
    font-size: 11px;
    letter-spacing: 0.12em;
    padding: 6px 10px;
  }
  .methode-cards-connector {
    display: none !important;
  }
  .methode-cards-connector__dot {
    display: none;
  }
}
.avis-showcase__bg {
  background-image: url("/img/front-v2/avis-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.avis-badge-gradient {
  background: linear-gradient(95deg, #ff6b35 0%, #9d4edd 100%);
}

.avis-grid-perspective {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) perspective(400px) rotateX(60deg);
  width: 140%;
  height: 200px;
  background-image: linear-gradient(rgba(157, 78, 221, 0.15) 1px, transparent 1px), linear-gradient(90deg, rgba(157, 78, 221, 0.15) 1px, transparent 1px);
  background-size: 60px 60px;
  transform-origin: bottom center;
  opacity: 0.5;
  mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
}

.avis-layout {
  display: flex;
  align-items: flex-start;
  gap: 32px;
}

.avis-score-panel {
  flex: 0 0 280px;
  position: sticky;
  top: 2rem;
  border: 1px solid rgba(202, 134, 255, 0.3);
  background: linear-gradient(180deg, rgba(22, 13, 40, 0.7) 0%, rgba(10, 7, 22, 0.75) 100%);
  border-radius: 20px;
  padding: 28px;
  box-shadow: 0 0 0 1px rgba(202, 134, 255, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 0 40px rgba(157, 78, 221, 0.2);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.avis-score {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  line-height: 1;
  text-shadow: 0 0 40px rgba(255, 107, 53, 0.6);
}

.avis-score__number {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(56px, 4.5vw, 80px);
  background: linear-gradient(102deg, #ff6b35 0%, #ff1493 80%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 20px rgba(255, 107, 53, 0.7)) drop-shadow(0 0 40px rgba(255, 107, 53, 0.4));
}

.avis-score__suffix {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(24px, 2vw, 32px);
  align-self: flex-end;
  margin-bottom: 10px;
  color: rgba(255, 255, 255, 0.6);
}

.avis-stat {
  font-family: Inter, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.85);
  padding: 6px 0;
}

.avis-stat__highlight {
  color: #00f5ff;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.65);
}

.avis-separator {
  height: 1px;
  margin: 18px 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 107, 53, 0.7) 30%, rgba(255, 20, 147, 0.7) 70%, transparent 100%);
  opacity: 1;
}

.avis-star {
  width: 20px;
  height: 20px;
  display: inline-block;
  color: #ffb266;
  filter: drop-shadow(0 0 6px rgba(255, 107, 53, 0.8)) drop-shadow(0 0 12px rgba(255, 107, 53, 0.4));
}

.avis-star--sm {
  width: 20px !important;
  height: 20px !important;
}

.avis-qualiopi-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(157, 78, 221, 0.5);
  padding: 6px 12px;
  box-shadow: 0 0 16px rgba(157, 78, 221, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.avis-qualiopi-badge svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: #00f5ff;
  stroke-width: 1.8;
  filter: drop-shadow(0 0 6px rgba(0, 245, 255, 0.6));
}

.avis-qualiopi-badge span {
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.94);
}

.avis-see-all {
  background: linear-gradient(90deg, #ff6b35, #9d4edd);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-weight: 700;
  font-size: 14px;
}

.avis-see-all:hover {
  filter: brightness(1.3);
}

.avis-cards {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 20px;
}

.avis-card {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  padding: 22px;
  background: linear-gradient(180deg, rgba(17, 10, 34, 0.45) 0%, rgba(11, 8, 24, 0.52) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 0 20px rgba(157, 78, 221, 0.1);
  transition: all 300ms ease;
}

.avis-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(157, 78, 221, 0.6) 50%, transparent 100%);
  z-index: 2;
  pointer-events: none;
}

.avis-card:hover {
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 28px rgba(157, 78, 221, 0.22);
}

.avis-card--featured {
  border-color: rgba(255, 20, 147, 0.45);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 0 0 1px rgba(255, 20, 147, 0.2), 0 0 40px rgba(255, 20, 147, 0.3), 0 0 80px rgba(255, 20, 147, 0.12), 0 20px 40px rgba(0, 0, 0, 0.5);
}

.avis-card--featured::before {
  background: linear-gradient(90deg, transparent 0%, rgba(255, 20, 147, 0.8) 50%, transparent 100%);
}

.avis-badge-coup-de-coeur {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  align-self: flex-start;
  margin-bottom: 10px;
  z-index: 3;
  padding: 5px 12px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(95deg, rgba(255, 0, 110, 0.75), rgba(255, 20, 147, 0.6));
  border: 1px solid rgba(255, 72, 150, 0.5);
  border-radius: 100px;
  box-shadow: 0 0 14px rgba(255, 0, 110, 0.5), 0 0 28px rgba(255, 20, 147, 0.25);
  animation: methode-pulse 2.5s ease-in-out infinite;
}

.avis-avatar {
  flex: 0 0 52px;
  width: 52px;
  height: 52px;
  border-radius: 9999px;
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.3), rgba(157, 78, 221, 0.3));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 2px rgba(255, 107, 53, 0.8), 0 0 0 4px rgba(157, 78, 221, 0.4), 0 0 16px rgba(255, 107, 53, 0.6), 0 0 32px rgba(255, 20, 147, 0.4), 0 0 48px rgba(157, 78, 221, 0.2);
}

.avis-avatar__initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: 18px;
  line-height: 1;
  letter-spacing: 0.05em;
  color: #fff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.6);
}

.avis-card__header {
  display: flex;
  align-items: center;
  gap: 14px;
}

.avis-card__meta {
  min-width: 0;
  flex: 1;
  display: grid;
  grid-template-areas: "name" "formation" "stars";
  row-gap: 0;
}

.avis-card__name {
  display: block;
  grid-area: name;
  font-family: Montserrat, sans-serif;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.2;
  color: rgba(255, 255, 255, 0.95);
}

.avis-card__formation {
  display: block;
  grid-area: formation;
  margin-top: 6px;
  font-family: Inter, sans-serif;
  font-size: 13px;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.55);
}

.avis-card__stars,
.avis-stars {
  grid-area: stars;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 3px;
  margin-top: 5px;
  width: 100%;
}

.avis-result-box {
  margin-top: 14px;
  border-radius: 10px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.avis-result-box__label,
.avis-result-label {
  margin: 0 0 6px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
}

.avis-result-box__value {
  margin: 0;
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(14px, 1vw, 17px);
  line-height: 1.28;
  background: linear-gradient(102deg, #ff6b35 0%, #ff1493 60%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.avis-quote {
  position: relative;
  margin: 14px 0 0;
  padding-left: 24px;
  font-family: Inter, sans-serif;
  font-size: clamp(14px, 0.9vw, 16px);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  max-height: none;
  overflow: hidden;
}

.avis-quote::before {
  content: "“";
  position: absolute;
  top: -8px;
  left: 0;
  color: rgba(255, 20, 147, 0.35);
  font-family: Georgia, serif;
  font-size: 52px;
  line-height: 1;
}

.avis-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.avis-badge-verified {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: #00f5ff;
  border-radius: 100px;
  border: 1px solid rgba(0, 245, 255, 0.35);
  background: rgba(0, 245, 255, 0.05);
  padding: 5px 12px;
  box-shadow: 0 0 10px rgba(0, 245, 255, 0.2), inset 0 1px 0 rgba(0, 245, 255, 0.1);
}

.avis-badge-verified__check {
  color: #00f5ff;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.9);
  font-size: 12px;
}

.avis-date-check {
  color: #00f5ff;
  font-size: 13px;
  font-weight: 700;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.9), 0 0 16px rgba(0, 245, 255, 0.5);
  margin-right: 5px;
}

.avis-card__date {
  display: flex;
  align-items: center;
  font-family: Inter, sans-serif;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.45);
}

.faq-showcase__bg {
  background-image: url("/img/front-v2/faq-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.faq-badge-gradient {
  background: linear-gradient(95deg, #ff6b35 0%, #9d4edd 100%);
}

.faq-grid-perspective {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) perspective(400px) rotateX(60deg);
  width: 140%;
  height: 200px;
  background-image: linear-gradient(rgba(157, 78, 221, 0.15) 1px, transparent 1px), linear-gradient(90deg, rgba(157, 78, 221, 0.15) 1px, transparent 1px);
  background-size: 60px 60px;
  transform-origin: bottom center;
  opacity: 0.5;
  mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, transparent 100%);
}

.faq-layout {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 48px;
}

.faq-aside {
  flex: 0 0 340px;
  position: sticky;
  top: 2rem;
  border: 1px solid rgba(157, 78, 221, 0.3);
  border-radius: 20px;
  padding: 32px 28px;
  background: linear-gradient(180deg, rgba(22, 13, 40, 0.65) 0%, rgba(10, 7, 22, 0.72) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 0 40px rgba(157, 78, 221, 0.15);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.faq-aside__title {
  margin: 20px 0 0;
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: clamp(28px, 2.2vw, 38px);
  line-height: 1.18;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
}

.faq-aside__title span {
  display: inline-block;
  overflow: visible;
  padding-right: 0.12em;
  background: linear-gradient(90deg, #ff6b35, #ff1493);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-style: italic;
}

.faq-aside__subtitle {
  margin: 12px 0 0;
  font-family: Inter, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.65);
}

.faq-aside__separator {
  margin: 20px 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 107, 53, 0.6), rgba(255, 20, 147, 0.5), transparent);
}

.faq-aside__stats {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.faq-aside__stat {
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.8);
}

.faq-aside__stat strong {
  color: #ff6b35;
  font-weight: 800;
}

.faq-aside__icon {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
  flex-shrink: 0;
}

.faq-aside__icon--orange {
  filter: drop-shadow(0 0 8px rgba(255, 107, 53, 0.6));
}

.faq-aside__icon--cyan {
  filter: drop-shadow(0 0 8px rgba(0, 245, 255, 0.6));
}

.faq-aside__icon--rose {
  filter: drop-shadow(0 0 8px rgba(255, 20, 147, 0.45));
}

.faq-aside__cpf {
  color: #00f5ff;
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.6);
}

.faq-aside__cta {
  margin-top: 24px;
  border-radius: 14px;
  padding: 18px 20px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 107, 53, 0.35);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.faq-aside__cta-title {
  margin: 0 0 6px;
  font-family: Inter, sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.9);
}

.faq-aside__cta-text {
  margin: 0 0 14px;
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.55);
}

.faq-aside__cta-button {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  padding: 12px 20px;
  background: linear-gradient(95deg, #ff6b35, #ff1493);
  text-decoration: none;
  box-shadow: 0 0 20px rgba(255, 107, 53, 0.4), 0 0 40px rgba(255, 20, 147, 0.2);
  transition: transform 260ms ease, filter 260ms ease;
}

.faq-aside__cta-button span {
  font-family: Montserrat, sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
}

.faq-aside__cta-button:hover {
  filter: brightness(1.15);
  transform: translateY(-2px);
}

.faq-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.faq-item {
  position: relative;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(17, 10, 34, 0.52) 0%, rgba(11, 8, 24, 0.6) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: hidden;
  transition: border-color 300ms, box-shadow 300ms;
}

.faq-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(157, 78, 221, 0.5), transparent);
  transition: opacity 300ms;
}

.faq-item:hover {
  border-color: rgba(157, 78, 221, 0.35);
  box-shadow: 0 0 20px rgba(157, 78, 221, 0.1);
}

.faq-item--active {
  border-color: rgba(255, 107, 53, 0.4);
  box-shadow: 0 0 30px rgba(255, 107, 53, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.faq-item--active::before {
  background: linear-gradient(90deg, transparent, rgba(255, 107, 53, 0.7), rgba(255, 20, 147, 0.5), transparent);
}

.faq-item--active .faq-item__chevron {
  transform: rotate(180deg);
  color: #ff6b35;
}

.faq-item--active .faq-item__number {
  background: linear-gradient(90deg, #ff6b35, #ff1493);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 8px rgba(255, 107, 53, 0.6));
}

.faq-item__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  background: transparent;
  border: none;
  cursor: pointer;
  gap: 16px;
  text-align: left;
}

.faq-item__header {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

.faq-item__number {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.4);
  min-width: 24px;
  transition: all 300ms;
}

.faq-item__question {
  font-family: Inter, sans-serif;
  font-weight: 600;
  font-size: clamp(14px, 1vw, 16px);
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.4;
}

.faq-item__chevron {
  width: 20px;
  height: 20px;
  color: rgba(157, 78, 221, 0.7);
  flex-shrink: 0;
  transition: transform 300ms, color 300ms;
}

.faq-item__body {
  overflow: hidden;
  max-height: 0;
  transition: max-height 400ms ease;
}

.faq-item__body.is-open {
  max-height: 400px;
}

.faq-item__answer {
  padding: 0 22px 20px 56px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 16px;
}

.faq-item__answer p {
  margin: 0;
  font-family: Inter, sans-serif;
  font-size: clamp(14px, 0.9vw, 15px);
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.75;
}

.faq-proof {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.faq-proof__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #00f5ff;
  background: rgba(0, 245, 255, 0.06);
  border: 1px solid rgba(0, 245, 255, 0.4);
  border-radius: 8px;
  padding: 7px 14px;
  box-shadow: 0 0 14px rgba(0, 245, 255, 0.2), inset 0 1px 0 rgba(0, 245, 255, 0.1);
}

.faq-proof__text {
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-style: italic;
  color: rgba(255, 255, 255, 0.5);
}

#cta-final.front-v2-section {
  position: relative;
  overflow: hidden;
  padding: 0;
}

.cta-final__bg {
  background-image: url("/img/front-v2/cta-bg.webp");
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}

.cta-final__content {
  max-width: 820px !important;
  padding-top: 100px !important;
  padding-bottom: 100px !important;
  padding-right: 12px;
}

.cta-final__badge-rail {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.cta-final__trail {
  position: relative;
  display: flex;
  align-items: center;
}

.cta-final__trail-blur {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}

.cta-final__trail-blur--left-soft {
  height: 8px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 107, 53, 0.25) 100%);
  filter: blur(4px);
}

.cta-final__trail-blur--left-mid {
  height: 3px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 140, 40, 0.55) 100%);
  filter: blur(2px);
}

.cta-final__trail-blur--right-mid {
  height: 3px;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.55) 0%, rgba(255, 255, 255, 0) 100%);
  filter: blur(2px);
}

.cta-final__trail-blur--right-soft {
  height: 8px;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.25) 0%, rgba(255, 255, 255, 0) 100%);
  filter: blur(4px);
}

.cta-final__trail-core {
  width: 70px;
  height: 1.5px;
}

.cta-final__trail-core--left {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 160, 40, 0.95) 100%);
}

.cta-final__trail-core--right {
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.95) 0%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__spark {
  position: relative;
  z-index: 5;
  flex-shrink: 0;
}

.cta-final__spark-h,
.cta-final__spark-v {
  position: absolute;
  top: 50%;
  left: 50%;
}

.cta-final__spark-h {
  width: 22px;
  height: 1.5px;
}

.cta-final__spark-h--left {
  right: 50%;
  left: auto;
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 200, 80, 0.6) 50%, rgb(255, 255, 255) 100%);
}

.cta-final__spark-h--right {
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgb(255, 255, 255) 0%, rgba(200, 100, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__spark-v {
  width: 1.5px;
  height: 16px;
  transform: translate(-50%, -50%);
}

.cta-final__spark-v--left {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 180, 80, 0.5) 30%, rgba(255, 255, 255, 0.9) 50%, rgba(255, 180, 80, 0.5) 70%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__spark-v--right {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(180, 80, 255, 0.5) 30%, rgba(255, 255, 255, 0.9) 50%, rgba(180, 80, 255, 0.5) 70%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__spark-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #fff;
}

.cta-final__spark-dot--left {
  box-shadow: 0 0 4px 2px rgb(255, 210, 80), 0 0 10px 4px rgba(255, 130, 40, 0.95), 0 0 22px 7px rgba(255, 80, 120, 0.65), 0 0 38px 10px rgba(255, 107, 53, 0.4);
}

.cta-final__spark-dot--right {
  box-shadow: 0 0 4px 2px rgb(210, 100, 255), 0 0 10px 4px rgba(157, 78, 221, 0.95), 0 0 22px 7px rgba(157, 78, 221, 0.65), 0 0 38px 10px rgba(157, 78, 221, 0.4);
}

.cta-final__badge {
  display: inline-flex;
  flex-shrink: 0;
  background: linear-gradient(95deg, #ff6b35, #9d4edd);
  padding: 2px;
  border-radius: 9999px;
  box-shadow: 0 0 28px rgba(255, 107, 53, 0.8), 0 0 50px rgba(157, 78, 221, 0.6), 0 0 80px rgba(255, 107, 53, 0.3);
}

.cta-final__badge-inner {
  display: inline-flex;
  align-items: center;
  background: rgba(10, 7, 22, 0.82);
  padding: 12px 32px;
  border-radius: 9999px;
  font-size: 13px;
  letter-spacing: 0.24em;
  color: rgba(255, 255, 255, 0.98);
  font-family: Montserrat, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.cta-final__title {
  display: inline-block;
  font-size: clamp(38px, 3.8vw, 58px);
  text-shadow: 0 3px 20px rgba(0, 0, 0, 0.6);
  padding-right: 0.18em;
}

.cta-final__minutes-wrap {
  position: relative;
  display: inline-block;
  overflow: visible;
  padding-right: 0.16em;
}

.cta-final__minutes-halo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  font-style: italic;
  font-size: clamp(38px, 3.8vw, 58px);
  font-weight: 800;
  font-family: Montserrat, sans-serif;
  pointer-events: none;
  line-height: 1.08;
}

.cta-final__minutes-halo--a {
  color: #ff7a2e;
  filter: blur(9px);
  opacity: 0.32;
}

.cta-final__minutes-halo--b {
  color: #ff2e8d;
  filter: blur(4px);
  opacity: 0.24;
}

.cta-final__minutes-text {
  position: relative;
  display: inline-block;
  font-style: italic;
  z-index: 2;
  padding-right: 0.14em;
  background: linear-gradient(102deg, #ffc15c 0%, #ff7b38 42%, #ff4a76 72%, #ff2e9c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  text-shadow: none !important;
  filter: drop-shadow(0 0 4px rgba(255, 107, 53, 0.28)) drop-shadow(0 0 8px rgba(255, 20, 147, 0.2));
}

.cta-final__separator {
  position: relative;
  width: 480px;
  max-width: 100%;
  height: 40px;
  margin: 26px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cta-final__separator-layer {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.cta-final__separator-layer--1 {
  left: 10%;
  right: 10%;
  height: 16px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 60, 120, 0.1) 30%, rgba(255, 140, 40, 0.2) 50%, rgba(255, 60, 120, 0.1) 70%, rgba(255, 255, 255, 0) 100%);
  filter: blur(6px);
}

.cta-final__separator-layer--2 {
  left: 0;
  right: 0;
  height: 5px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(220, 20, 100, 0.25) 20%, rgba(255, 100, 40, 0.5) 40%, rgba(255, 160, 20, 0.65) 50%, rgba(255, 100, 40, 0.5) 60%, rgba(220, 20, 100, 0.25) 80%, rgba(255, 255, 255, 0) 100%);
  filter: blur(3px);
}

.cta-final__separator-layer--3 {
  left: 0;
  right: 0;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(220, 20, 100, 0.55) 15%, rgba(255, 80, 120, 0.9) 30%, rgba(255, 140, 40, 0.98) 45%, rgb(255, 210, 20) 50%, rgba(255, 140, 40, 0.98) 55%, rgba(255, 80, 120, 0.9) 70%, rgba(220, 20, 100, 0.55) 85%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__separator-layer--4 {
  top: calc(50% - 3px);
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 180, 80, 0.25) 35%, rgba(255, 230, 120, 0.5) 50%, rgba(255, 180, 80, 0.25) 65%, rgba(255, 255, 255, 0) 100%);
  filter: blur(0.5px);
}

.cta-final__separator-center {
  position: relative;
  z-index: 5;
}

.cta-final__separator-ray {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.cta-final__separator-ray--h {
  width: 36px;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 200, 80, 0.5) 25%, rgba(255, 255, 255, 0.95) 50%, rgba(255, 200, 80, 0.5) 75%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__separator-ray--v {
  width: 1.5px;
  height: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 180, 80, 0.4) 25%, rgba(255, 255, 255, 0.9) 50%, rgba(255, 180, 80, 0.4) 75%, rgba(255, 255, 255, 0) 100%);
}

.cta-final__separator-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 4px 3px rgb(255, 230, 100), 0 0 12px 6px rgba(255, 150, 40, 0.95), 0 0 26px 10px rgba(255, 80, 120, 0.75), 0 0 45px 14px rgba(255, 20, 147, 0.5), 0 0 70px 20px rgba(255, 107, 53, 0.3), 0 0 100px 28px rgba(255, 20, 147, 0.15);
}

.cta-final__subtitle {
  margin-top: 20px;
  max-width: 560px;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.85);
  font-family: Inter, sans-serif;
}

.cta-guarantee {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border-radius: 9999px;
  padding: 11px 22px;
  font-family: Inter, sans-serif;
  font-size: 15px;
  font-weight: 600;
  border: 1.5px solid;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.cta-guarantee__icon {
  width: 17px;
  height: 17px;
  flex-shrink: 0;
}

.cta-guarantee--cyan {
  color: #00f5ff;
  border-color: rgba(0, 245, 255, 0.5);
  background: rgba(0, 245, 255, 0.09);
  box-shadow: 0 0 20px rgba(0, 245, 255, 0.25);
}

.cta-guarantee--green {
  color: rgba(0, 245, 180, 0.98);
  border-color: rgba(0, 245, 180, 0.5);
  background: rgba(0, 245, 180, 0.09);
  box-shadow: 0 0 20px rgba(0, 245, 180, 0.25);
}

.cta-guarantee--violet {
  color: #d490ff;
  border-color: rgba(157, 78, 221, 0.55);
  background: rgba(157, 78, 221, 0.1);
  box-shadow: 0 0 20px rgba(157, 78, 221, 0.3);
}

.cta-btn-primary {
  padding: 20px 52px !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}

.cta-btn-secondary {
  padding: 20px 44px !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  border-radius: 9999px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.28) !important;
  color: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

.cta-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 9999px;
  border: 2px solid;
  font-family: Montserrat, sans-serif;
  font-weight: 700;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

.cta-avatar--overlap {
  margin-left: -10px;
}

.cta-avatar--cyan {
  background: rgba(0, 245, 255, 0.25);
  border-color: #00f5ff;
}

.cta-avatar--orange {
  background: rgba(255, 107, 53, 0.25);
  border-color: #ff6b35;
}

.cta-avatar--rose {
  background: rgba(255, 20, 147, 0.25);
  border-color: #ff1493;
}

.cta-avatar--violet {
  background: rgba(157, 78, 221, 0.25);
  border-color: #9d4edd;
}

.cta-social-proof {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.75);
  font-family: Inter, sans-serif;
}

.cta-social-proof__star {
  color: rgba(255, 179, 71, 0.95);
  text-shadow: 0 0 10px rgba(255, 107, 53, 0.6);
}

.cta-social-proof__rating {
  background: linear-gradient(90deg, #ff6b35, #ff1493);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-weight: 700;
}

.cta-final__legal {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.52);
  letter-spacing: 0.01em;
}

@media (max-width: 1024px) {
  .avis-layout {
    gap: 22px;
  }
  .avis-score-panel {
    position: static;
    flex-basis: 240px;
    top: auto;
    padding: 22px;
  }
  .faq-layout {
    gap: 28px;
  }
  .faq-aside {
    position: static;
    top: auto;
    flex-basis: 260px;
    padding: 24px 20px;
  }
  #cta-final .cta-final__content {
    max-width: 760px;
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
}
@media (max-width: 767px) {
  .avis-layout {
    flex-direction: column;
    gap: 18px;
  }
  .avis-score-panel {
    width: 100%;
    flex-basis: auto;
  }
  .avis-card {
    padding: 18px;
  }
  .avis-cards {
    flex-direction: column;
  }
  .faq-layout {
    flex-direction: column;
    gap: 16px;
  }
  .faq-aside {
    width: 100%;
    flex-basis: auto;
    padding: 22px 18px;
  }
  .faq-item__trigger {
    padding: 16px 14px;
  }
  .faq-item__header {
    align-items: flex-start;
  }
  .faq-item__answer {
    padding: 0 14px 16px 40px;
    padding-top: 14px;
  }
  #cta-final .cta-final__content {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  #cta-final .cta-guarantee {
    width: 100%;
    justify-content: center;
  }
  #cta-final .cta-btn-secondary,
  #cta-final .cta-btn-primary {
    width: 100%;
    justify-content: center;
  }
}
@media (max-width: 1180px) {
  .front-v2-nav__inner {
    width: min(1180px, 100% - 20px);
    padding: 10px 14px;
    gap: 12px;
  }
  .front-v2-nav__brand-main,
  .front-v2-nav__brand-dot {
    font-size: clamp(24px, 3vw, 30px);
  }
  .front-v2-nav__brand-sub {
    font-size: clamp(18px, 2.2vw, 22px);
  }
  .front-v2-nav__links {
    gap: clamp(10px, 1.8vw, 20px);
  }
  .front-v2-nav__links a {
    font-size: clamp(13px, 1.4vw, 15px);
  }
  .front-v2-nav__cta-btn {
    font-size: 13px;
    padding: 8px 16px;
  }
  .front-v2-nav__account-btn {
    font-size: 13px;
    padding: 8px 14px;
  }
  .front-v2-hero {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .front-v2-hero::after {
    content: none;
  }
  .front-v2-title {
    max-width: 100%;
    font-size: clamp(52px, 9vw, 74px);
  }
  .front-v2-lead {
    font-size: clamp(24px, 5.2vw, 34px);
  }
  .front-v2-subtext {
    font-size: clamp(17px, 4vw, 23px);
  }
  .front-v2-btn {
    font-size: clamp(17px, 3.3vw, 22px);
  }
  .front-v2-panel__title {
    font-size: clamp(26px, 5.4vw, 42px);
  }
  .front-v2-panel__text {
    font-size: clamp(15px, 2.9vw, 19px);
  }
  .front-v2-field__value {
    font-size: clamp(15px, 3.2vw, 20px);
  }
  .front-v2-main {
    width: min(1120px, 100%);
  }
}
@media (max-width: 760px) {
  .front-v2-nav__inner {
    width: min(760px, 100% - 14px);
    padding: 8px 10px;
    border-radius: 16px;
  }
  .front-v2-nav__links {
    display: none;
  }
  .front-v2-nav__brand-main,
  .front-v2-nav__brand-dot {
    font-size: 24px;
  }
  .front-v2-nav__brand-sub {
    font-size: 17px;
  }
  .front-v2-nav__cta-btn {
    display: none;
  }
  .front-v2-nav__account-btn {
    display: none;
  }
  .front-v2-nav__toggle {
    display: inline-flex;
  }
  .front-v2-mobile-drawer {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 60;
    pointer-events: none;
  }
  .front-v2-mobile-drawer__overlay {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(8, 6, 18, 0.62);
    opacity: 0;
    transition: opacity 200ms ease;
    pointer-events: none;
  }
  .front-v2-mobile-drawer__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: min(360px, 88vw);
    height: 100%;
    padding: 16px 14px 24px;
    border-left: 1px solid rgba(201, 149, 255, 0.45);
    background: linear-gradient(180deg, rgba(18, 12, 34, 0.95) 0%, rgba(10, 8, 20, 0.98) 100%);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: -12px 0 34px rgba(5, 4, 16, 0.44);
    transform: translateX(100%);
    transition: transform 220ms ease;
    display: flex;
    flex-direction: column;
    gap: 18px;
    pointer-events: auto;
  }
  .front-v2-mobile-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .front-v2-mobile-drawer__head p {
    margin: 0;
    font-family: "Montserrat", sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: #fff;
  }
  .front-v2-mobile-drawer__close {
    width: 34px;
    height: 34px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.04);
    color: #fff;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
  }
  .front-v2-mobile-drawer__links {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .front-v2-mobile-drawer__links a {
    display: block;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 12px;
    padding: 12px 12px;
    text-decoration: none;
    font-family: "Montserrat", sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.94);
    background: rgba(255, 255, 255, 0.04);
  }
  .front-v2-mobile-drawer__cta {
    margin-top: auto;
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .front-v2-mobile-drawer.is-open {
    pointer-events: auto;
  }
  .front-v2-mobile-drawer.is-open .front-v2-mobile-drawer__overlay {
    opacity: 1;
    pointer-events: auto;
  }
  .front-v2-mobile-drawer.is-open .front-v2-mobile-drawer__panel {
    transform: translateX(0);
  }
  .front-v2-badge {
    font-size: 12px;
    padding: 7px 14px;
  }
  .front-v2-title__line--gradient {
    white-space: normal;
  }
  .front-v2-actions {
    flex-direction: column;
  }
  .front-v2-btn {
    width: 100%;
    font-size: 18px;
    padding: 11px 16px;
  }
  .front-v2-metrics {
    grid-template-columns: 1fr;
    max-width: 100%;
  }
  .front-v2-panel::before {
    top: 52px;
  }
  .front-v2-main {
    width: min(760px, 100%);
  }
}
.formation-page {
  min-height: 100vh;
  background: radial-gradient(circle at 14% 12%, rgba(255, 107, 53, 0.12) 0%, transparent 34%), radial-gradient(circle at 86% 8%, rgba(0, 245, 255, 0.1) 0%, transparent 30%), linear-gradient(180deg, #06050f 0%, #0a0718 100%);
  color: #fff;
  overflow-x: clip;
}

.formation-hero {
  position: relative;
  isolation: isolate;
  padding-top: clamp(120px, 12vw, 160px);
  padding-bottom: clamp(66px, 8vw, 108px);
}
.formation-hero.ui-section--fade::before, .formation-hero.ui-section--fade::after {
  z-index: 1;
}
.formation-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("/img/front-v2/formation-hero-bg.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  z-index: 0;
}
.formation-hero__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7, 5, 15, 0.64) 0%, rgba(10, 7, 20, 0.3) 32%, rgba(9, 7, 20, 0.56) 100%), radial-gradient(circle at 24% 34%, rgba(255, 118, 70, 0.16) 0%, transparent 44%), radial-gradient(circle at 82% 22%, rgba(200, 88, 255, 0.2) 0%, transparent 42%);
}
.formation-hero__content {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.28fr) minmax(360px, 0.72fr);
  gap: clamp(18px, 2.4vw, 36px);
  align-items: start;
}
.formation-hero__left {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.formation-hero__eyebrow {
  align-self: flex-start;
  margin-bottom: 2px;
}
.formation-hero__title {
  margin: 2px 0 0;
  --ht-size: clamp(36px, 3.3vw, 66px);
}
.formation-hero__lead {
  margin: 6px 0 0;
  max-width: 56ch;
  font-family: var(--ui-font-body);
  font-size: clamp(16px, 0.95vw, 20px);
  line-height: 1.44;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.78);
}
.formation-hero__cta-row {
  margin-top: 4px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}
.formation-hero__cta-primary {
  min-height: 54px;
  min-width: min(300px, 100%);
  padding: 12px 24px;
  font-size: clamp(15px, 0.92vw, 17px);
  letter-spacing: -0.008em;
}
.formation-hero__cta-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  min-width: min(300px, 100%);
  border-radius: 14px;
  border: 1px solid rgba(217, 171, 255, 0.55);
  background: linear-gradient(180deg, rgba(23, 14, 45, 0.72) 0%, rgba(12, 9, 30, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16), 0 0 18px rgba(157, 78, 221, 0.24);
  padding: 12px 24px;
  font-family: var(--ui-font-heading);
  font-size: clamp(15px, 0.9vw, 17px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.95);
  text-decoration: none;
  transition: transform 240ms ease, box-shadow 240ms ease, border-color 240ms ease;
}
.formation-hero__cta-secondary:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 186, 236, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 22px rgba(255, 100, 178, 0.3), 0 0 46px rgba(157, 78, 221, 0.2);
}
.formation-hero__panel {
  margin-top: 6px;
  max-width: 530px;
  width: 100%;
  margin-left: auto;
  border-radius: 20px;
  border-color: rgba(190, 141, 255, 0.42);
  padding: clamp(20px, 2vw, 34px);
  background: linear-gradient(180deg, rgba(30, 16, 52, 0.56) 0%, rgba(13, 10, 31, 0.62) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 0 1px rgba(194, 136, 255, 0.18), 0 18px 36px rgba(2, 1, 12, 0.5), 0 0 54px rgba(157, 78, 221, 0.26);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.formation-hero__panel h2 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: clamp(28px, 1.9vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.46);
}
.formation-hero__panel p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-family: var(--ui-font-body);
  font-size: clamp(14px, 0.9vw, 17px);
  line-height: 1.42;
}
.formation-hero__panel small {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.56);
  font-family: var(--ui-font-body);
  font-size: clamp(13px, 0.84vw, 15px);
  line-height: 1.42;
}

.formation-chip-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.formation-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 13px;
  border: 1px solid rgba(212, 163, 255, 0.36);
  min-height: 42px;
  padding: 7px 14px;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-family: var(--ui-font-body);
  font-size: clamp(13px, 0.82vw, 15px);
  line-height: 1;
  background: linear-gradient(180deg, rgba(35, 20, 54, 0.54) 0%, rgba(14, 10, 34, 0.74) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 0 20px rgba(93, 57, 170, 0.24);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}
.formation-chip.is-active {
  border-color: rgba(255, 147, 89, 0.9);
  background: linear-gradient(100deg, rgba(255, 109, 53, 0.68) 0%, rgba(255, 54, 141, 0.6) 56%, rgba(161, 80, 230, 0.5) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28), 0 0 22px rgba(255, 91, 63, 0.48), 0 0 46px rgba(255, 20, 147, 0.24);
  color: #fff;
  font-weight: 700;
}
.formation-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 189, 232, 0.7);
}

.formation-proof {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 13px;
  max-width: 710px;
  align-items: stretch;
}

.formation-section-divider {
  position: relative;
  z-index: 3;
  width: 100%;
  height: clamp(34px, 4.2vw, 64px);
  margin-top: -1px;
  margin-bottom: -1px;
  background: #000;
  pointer-events: none;
  overflow: visible;
}
.formation-section-divider::before, .formation-section-divider::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: clamp(28px, 3.6vw, 52px);
  pointer-events: none;
}
.formation-section-divider::before {
  bottom: 100%;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.52) 42%, rgba(0, 0, 0, 0.86) 72%, rgb(0, 0, 0) 100%);
}
.formation-section-divider::after {
  top: 100%;
  background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0.86) 30%, rgba(0, 0, 0, 0.52) 62%, rgba(0, 0, 0, 0) 100%);
}

.formation-catalogue {
  position: relative;
  isolation: isolate;
  padding-top: clamp(34px, 4vw, 54px);
  background-image: url("/img/front-v2/catalogue-bg.webp");
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}
.formation-catalogue::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7, 5, 15, 0.48) 0%, rgba(8, 6, 18, 0.58) 24%, rgba(8, 6, 18, 0.68) 100%), radial-gradient(circle at 20% 24%, rgba(255, 107, 53, 0.2) 0%, transparent 44%), radial-gradient(circle at 82% 18%, rgba(157, 78, 221, 0.2) 0%, transparent 46%);
}
.formation-catalogue > * {
  position: relative;
  z-index: 1;
}
.formation-catalogue__layout {
  display: grid;
  grid-template-columns: minmax(250px, 280px) minmax(0, 1fr);
  gap: clamp(14px, 2vw, 24px);
  align-items: start;
}

@media (min-width: 769px) {
  .formation-catalogue > .catalogue-filters {
    z-index: 120;
  }
  .formation-catalogue > .ui-container {
    z-index: 10;
  }
}
.formation-filters {
  position: sticky;
  top: 102px;
  padding: 16px;
}

.formation-filters__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.formation-filters__head h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 20px;
}
.formation-filters__head a {
  color: rgba(255, 255, 255, 0.74);
  font-size: 13px;
  text-decoration: none;
}

.formation-filter-group:not(:last-child) {
  margin-bottom: 16px;
}
.formation-filter-group p {
  margin: 0 0 8px;
  font-family: var(--ui-font-label);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.66);
}

.formation-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.formation-filter-pill {
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  padding: 6px 10px;
  color: rgba(255, 255, 255, 0.86);
  text-decoration: none;
  font-family: var(--ui-font-body);
  font-size: 12px;
  line-height: 1;
}
.formation-filter-pill.is-active {
  border-color: rgba(0, 245, 255, 0.66);
  background: rgba(0, 245, 255, 0.16);
  color: #fff;
}

.formation-results {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.formation-results__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
}
.formation-results__head h2 {
  font-size: clamp(24px, 2vw, 34px);
}
.formation-results__head p {
  margin: 0;
  font-size: 14px;
}

.formation-featured {
  margin-bottom: 4px;
}

.formation-card {
  overflow: hidden;
}
.formation-card__media {
  display: block;
  aspect-ratio: 16/9;
  background: rgba(255, 255, 255, 0.04);
}
.formation-card__media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.formation-card__media span {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.62);
  font-family: var(--ui-font-body);
}
.formation-card__body {
  padding: 14px;
}
.formation-card__body h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 20px;
  line-height: 1.2;
}
.formation-card__body .formation-row__title-link {
  color: #fff;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}
.formation-card__body .formation-row__title-link:hover,
.formation-card__body .formation-row__title-link:focus-visible {
  color: #ffd9c7;
  opacity: 1;
}
.formation-card__body p {
  margin: 10px 0 0;
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.77);
}
.formation-card__body a {
  display: inline-flex;
  margin-top: 12px;
  color: #fff;
  text-decoration: none;
  font-family: var(--ui-font-heading);
  font-size: 14px;
}
.formation-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.formation-card__meta span {
  font-family: var(--ui-font-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.68);
}
.formation-card__meta strong {
  font-family: var(--ui-font-heading);
  font-size: 18px;
  color: #fff;
}

.formation-list {
  align-items: stretch;
}

.formation-row {
  overflow: hidden;
  display: grid;
  grid-template-columns: 180px 1fr;
}
.formation-row__media {
  background: rgba(255, 255, 255, 0.03);
}
.formation-row__media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.formation-row__media span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: rgba(255, 255, 255, 0.62);
  font-size: 13px;
  font-family: var(--ui-font-body);
}
.formation-row__body {
  padding: 14px;
  display: flex;
  flex-direction: column;
}
.formation-row__body h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 20px;
  line-height: 1.2;
}
.formation-row__body p {
  margin: 9px 0 0;
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.77);
}
.formation-row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.formation-row__meta span {
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 4px 8px;
  font-family: var(--ui-font-label);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.72);
}
.formation-row__meta-online {
  font-size: 11px !important;
  font-weight: 700;
  color: rgba(224, 245, 255, 0.95) !important;
  border-color: rgba(0, 245, 255, 0.45) !important;
  background: rgba(0, 245, 255, 0.08);
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.2);
}
.formation-row__meta-award {
  text-transform: none !important;
  letter-spacing: 0.02em !important;
  font-size: 11px !important;
  color: rgba(236, 228, 255, 0.96) !important;
  border-color: rgba(191, 142, 255, 0.46) !important;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.14) 0%, rgba(255, 107, 53, 0.12) 100%);
}
.formation-row__mentor-note {
  margin: 8px 0 0;
  font-family: var(--ui-font-body);
  font-size: 13px;
  line-height: 1.42;
  color: rgba(205, 228, 255, 0.86);
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.14);
}
.formation-row__cta {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
}
.formation-row__cta strong {
  font-family: var(--ui-font-heading);
  font-size: 20px;
}
.formation-row__cta .formation-row__price-group {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.formation-row__cta .formation-row__price-old {
  font-family: var(--ui-font-body);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.52);
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
}
.formation-row__cta a {
  color: #fff;
  text-decoration: none;
  font-family: var(--ui-font-heading);
  font-size: 14px;
}

.formation-empty {
  padding: 24px;
  display: grid;
  justify-items: start;
  gap: 10px;
}
.formation-empty h3,
.formation-empty p {
  margin: 0;
}
.formation-empty h3 {
  font-family: var(--ui-font-heading);
  font-size: 24px;
}
.formation-empty p {
  font-family: var(--ui-font-body);
  color: rgba(255, 255, 255, 0.74);
}

.formation-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
}
.formation-pagination a,
.formation-pagination span {
  font-family: var(--ui-font-body);
  font-size: 14px;
}
.formation-pagination a {
  color: #fff;
  text-decoration: none;
}
.formation-pagination .is-disabled {
  opacity: 0.4;
  pointer-events: none;
}

.formation-cta-final__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: clamp(18px, 2.3vw, 32px);
}

.formation-cta-final__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (max-width: 1100px) {
  .formation-hero__content {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .formation-hero__panel {
    margin-left: 0;
    max-width: 700px;
  }
  .formation-proof {
    max-width: 100%;
  }
  .formation-catalogue__layout {
    grid-template-columns: 1fr;
  }
  .formation-filters {
    position: static;
  }
}
@media (max-width: 860px) {
  .formation-proof {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .formation-results__head {
    flex-direction: column;
    align-items: flex-start;
  }
  .formation-row {
    grid-template-columns: 1fr;
  }
  .formation-row__media {
    aspect-ratio: 16/8;
  }
  .formation-cta-final__card {
    flex-direction: column;
    align-items: stretch;
  }
}
@media (max-width: 767px) {
  .formation-page,
  .formation-page main,
  .formation-page section {
    overflow-x: clip;
  }
  .formation-page .ui-container {
    width: min(100%, 100vw - 24px);
    margin-inline: auto;
  }
  .formation-hero {
    padding-top: 108px;
    padding-bottom: 46px;
  }
  .formation-section-divider {
    height: clamp(34px, 4.2vw, 64px);
  }
  .formation-hero__content {
    gap: 16px;
    min-width: 0;
  }
  .formation-hero__left,
  .formation-hero__panel {
    min-width: 0;
    width: 100%;
  }
  .formation-hero__left {
    align-items: center;
    text-align: center;
  }
  .formation-hero__eyebrow {
    align-self: center;
    transform: none;
    margin-inline: auto;
    margin-bottom: 14px;
  }
  .formation-hero__eyebrow .neon-badge-rail {
    width: 100%;
    justify-content: center;
  }
  .formation-hero__title {
    --ht-size: clamp(31px, 9.4vw, 43px);
    text-align: center;
    margin-inline: auto;
    margin-bottom: 16px;
  }
  .formation-hero__lead {
    max-width: 34ch;
    font-size: 15px;
    margin-inline: auto;
    text-align: center;
    margin-top: 0;
    margin-bottom: 8px;
  }
  .formation-hero__cta-row {
    width: 100%;
    gap: 10px;
    justify-content: center;
  }
  .formation-hero__cta-primary,
  .formation-hero__cta-secondary {
    width: 100%;
    min-width: 0;
    min-height: 50px;
    padding: 12px 16px;
  }
  .formation-proof {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .formation-hero__panel {
    border-radius: 18px;
    padding: 18px 16px;
  }
  .formation-hero__panel h2 {
    font-size: 27px;
  }
  .formation-hero__panel p {
    font-size: 14px;
  }
  .formation-hero__panel small {
    font-size: 13px;
  }
  .formation-chip-cloud {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 4px;
    scroll-snap-type: x proximity;
  }
  .formation-chip-cloud::-webkit-scrollbar {
    display: none;
  }
  .formation-chip {
    flex: 0 0 auto;
    scroll-snap-align: start;
    min-height: 42px;
    padding: 8px 14px;
    font-size: 13.5px;
    max-width: none;
    white-space: nowrap;
  }
  .formation-featured {
    grid-template-columns: 1fr;
  }
  .formation-list {
    grid-template-columns: 1fr;
  }
  .formation-row__body {
    min-width: 0;
  }
  .formation-row__body h3,
  .formation-row__body p {
    overflow-wrap: anywhere;
  }
  .formation-row__cta {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .formation-row__cta a {
    width: 100%;
  }
  .formation-pagination {
    gap: 8px;
    flex-direction: column;
    align-items: stretch;
  }
  .formation-pagination a,
  .formation-pagination span {
    text-align: center;
  }
}
@media (max-width: 560px) {
  .formation-hero__title {
    --ht-size: clamp(29px, 8.8vw, 40px);
  }
  .formation-results__head h2 {
    font-size: clamp(22px, 7.2vw, 30px);
  }
  .formation-results__head p {
    font-size: 13px;
  }
  .formation-row__body h3 {
    font-size: 18px;
  }
}
.path-catalogue-page .path-trust {
  padding-top: 8px;
  padding-bottom: 24px;
}
.path-catalogue-page .path-trust__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 20px;
  border-color: rgba(160, 95, 235, 0.35);
}
.path-catalogue-page .path-trust__certs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.path-catalogue-page .path-trust__cert {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  background: linear-gradient(90deg, rgba(255, 110, 60, 0.26) 0%, rgba(157, 78, 221, 0.2) 100%);
  font-family: var(--ui-font-label);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.95);
}
.path-catalogue-page .path-trust__metrics {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.path-catalogue-page .path-trust__metric {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}
.path-catalogue-page .path-trust__metric strong {
  font-family: var(--ui-font-heading);
  font-size: 20px;
  color: #fff;
}
.path-catalogue-page .path-trust__metric span {
  font-family: var(--ui-font-body);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.72);
}
.path-catalogue-page .path-section-badge {
  align-self: flex-start;
}
.path-catalogue-page .path-section-title {
  margin-top: 14px;
}
.path-catalogue-page .path-section-lead {
  margin-top: 8px;
  margin-bottom: 0;
  max-width: 66ch;
}
.path-catalogue-page .path-featured-card {
  position: relative;
}
.path-catalogue-page .path-featured-card .formation-card__meta-item:first-child {
  font-size: 13px;
  font-weight: 600;
  color: rgba(224, 245, 255, 0.95);
  text-shadow: 0 0 10px rgba(0, 245, 255, 0.2);
}
.path-catalogue-page .path-featured-card__badge {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 9999px;
  border: 1px solid rgba(255, 199, 112, 0.72);
  background: linear-gradient(90deg, rgba(255, 130, 66, 0.9) 0%, rgba(255, 20, 147, 0.82) 100%);
  font-family: var(--ui-font-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 0 18px rgba(255, 96, 64, 0.32);
}
.path-catalogue-page .path-finance,
.path-catalogue-page .path-compare,
.path-catalogue-page .path-profiles,
.path-catalogue-page .path-proof,
.path-catalogue-page .path-faq,
.path-catalogue-page .path-final-cta {
  padding-top: clamp(34px, 4vw, 54px);
  padding-bottom: clamp(34px, 4vw, 54px);
}
.path-catalogue-page .path-finance {
  background: radial-gradient(circle at 14% 24%, rgba(255, 107, 53, 0.16) 0%, transparent 42%), radial-gradient(circle at 82% 16%, rgba(157, 78, 221, 0.2) 0%, transparent 42%);
}
.path-catalogue-page .path-finance__grid {
  margin-top: 22px;
}
.path-catalogue-page .path-finance__card {
  padding: 18px;
  border-color: rgba(188, 118, 255, 0.3);
}
.path-catalogue-page .path-finance__card h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 24px;
  color: #fff;
}
.path-catalogue-page .path-finance__card ul {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.path-catalogue-page .path-finance__card li {
  position: relative;
  padding-left: 14px;
  font-family: var(--ui-font-body);
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.5;
}
.path-catalogue-page .path-finance__card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: linear-gradient(90deg, #ff6b35, #ff1493);
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.65);
}
.path-catalogue-page .path-finance__highlight {
  margin: 10px 0 0;
  font-family: var(--ui-font-heading);
  font-size: 17px;
  color: #00f5ff;
  text-shadow: 0 0 12px rgba(0, 245, 255, 0.34);
}
.path-catalogue-page .path-compare__table-wrap {
  margin-top: 22px;
  overflow-x: auto;
  border-color: rgba(162, 100, 236, 0.3);
}
.path-catalogue-page .path-compare__table {
  width: 100%;
  border-collapse: collapse;
  min-width: 900px;
}
.path-catalogue-page .path-compare__table th,
.path-catalogue-page .path-compare__table td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-family: var(--ui-font-body);
  font-size: 13px;
  color: rgba(255, 255, 255, 0.82);
  vertical-align: middle;
}
.path-catalogue-page .path-compare__table th {
  font-family: var(--ui-font-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.68);
  background: rgba(8, 8, 18, 0.38);
}
.path-catalogue-page .path-compare__table td a {
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}
.path-catalogue-page .path-profiles__grid,
.path-catalogue-page .path-proof__grid {
  margin-top: 22px;
}
.path-catalogue-page .path-profiles__card,
.path-catalogue-page .path-proof__card {
  padding: 18px;
  border-color: rgba(176, 112, 242, 0.28);
}
.path-catalogue-page .path-profiles__card h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 24px;
  color: #fff;
}
.path-catalogue-page .path-profiles__card p {
  margin: 10px 0 0;
  font-family: var(--ui-font-body);
  font-size: 14px;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.5;
}
.path-catalogue-page .path-profiles__card ul {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.path-catalogue-page .path-profiles__card li {
  font-family: var(--ui-font-body);
  font-size: 13px;
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.45;
}
.path-catalogue-page .path-profiles__card strong {
  color: #fff;
  font-weight: 600;
}
.path-catalogue-page .path-profiles__card a {
  margin-top: 14px;
  display: inline-flex;
  color: #fff;
  text-decoration: none;
  font-family: var(--ui-font-heading);
  font-size: 14px;
}
.path-catalogue-page .path-proof__head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.path-catalogue-page .path-proof__head img,
.path-catalogue-page .path-proof__head .path-proof__avatar-fallback {
  width: 42px;
  height: 42px;
  border-radius: 9999px;
  flex-shrink: 0;
}
.path-catalogue-page .path-proof__head img {
  -o-object-fit: cover;
     object-fit: cover;
}
.path-catalogue-page .path-proof__head h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 17px;
  color: #fff;
}
.path-catalogue-page .path-proof__head p {
  margin: 3px 0 0;
  font-family: var(--ui-font-body);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.68);
}
.path-catalogue-page .path-proof__avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(120deg, rgba(255, 107, 53, 0.6) 0%, rgba(157, 78, 221, 0.6) 100%);
  font-family: var(--ui-font-heading);
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.path-catalogue-page .path-proof__card blockquote {
  margin: 12px 0 0;
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.84);
}
.path-catalogue-page .path-proof__result {
  display: inline-flex;
  margin-top: 12px;
  padding: 4px 10px;
  border-radius: 9999px;
  border: 1px solid rgba(0, 245, 255, 0.42);
  background: rgba(0, 245, 255, 0.1);
  font-family: var(--ui-font-label);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 10px;
  color: #b5f9ff;
}
.path-catalogue-page .path-faq__list {
  margin-top: 22px;
  display: grid;
  gap: 10px;
}
.path-catalogue-page .path-faq__item {
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(180deg, rgba(17, 10, 34, 0.52) 0%, rgba(11, 8, 24, 0.6) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  overflow: hidden;
}
.path-catalogue-page .path-faq__item summary {
  padding: 16px 18px;
  cursor: pointer;
  list-style: none;
  font-family: var(--ui-font-heading);
  font-size: 18px;
  color: rgba(255, 255, 255, 0.94);
}
.path-catalogue-page .path-faq__item summary::-webkit-details-marker {
  display: none;
}
.path-catalogue-page .path-faq__item p {
  margin: 0;
  padding: 0 18px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.09);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
}
.path-catalogue-page .path-final-cta__card {
  padding: clamp(18px, 2.4vw, 30px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-color: rgba(195, 126, 255, 0.36);
}
.path-catalogue-page .path-final-cta__card h2 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: clamp(24px, 2.1vw, 34px);
  color: #fff;
}
.path-catalogue-page .path-final-cta__card p {
  margin: 10px 0 0;
  max-width: 54ch;
  font-family: var(--ui-font-body);
  font-size: 15px;
  color: rgba(255, 255, 255, 0.8);
}
.path-catalogue-page .path-final-cta__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.path-catalogue-page .path-final-cta__ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 13px;
  border: 1px solid rgba(188, 119, 255, 0.56);
  background: rgba(17, 11, 36, 0.66);
  text-decoration: none;
  font-family: var(--ui-font-heading);
  font-size: 15px;
  color: #fff;
}

@media (max-width: 1024px) {
  .path-catalogue-page .path-finance__grid,
  .path-catalogue-page .path-proof__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .path-catalogue-page .path-trust {
    padding-top: 2px;
    padding-bottom: 16px;
  }
  .path-catalogue-page .path-trust__inner {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
  }
  .path-catalogue-page .path-trust__metrics {
    width: 100%;
    justify-content: flex-start;
    gap: 14px;
  }
  .path-catalogue-page .path-trust__metric {
    align-items: flex-start;
  }
  .path-catalogue-page .path-finance__grid,
  .path-catalogue-page .path-profiles__grid,
  .path-catalogue-page .path-proof__grid {
    grid-template-columns: 1fr;
  }
  .path-catalogue-page .path-final-cta__card {
    flex-direction: column;
    align-items: flex-start;
  }
  .path-catalogue-page .path-final-cta__actions {
    width: 100%;
  }
  .path-catalogue-page .path-final-cta__actions .front-v2-btn-primary,
  .path-catalogue-page .path-final-cta__ghost {
    width: 100%;
    justify-content: center;
  }
}
.course-single-page .course-single-hero {
  position: relative;
  isolation: isolate;
  padding-top: clamp(118px, 11vw, 152px);
  padding-bottom: clamp(62px, 7vw, 94px);
}
.course-single-page .course-single-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: url("/img/front-v2/formation-hero-bg.webp") center/cover no-repeat;
}
.course-single-page .course-single-hero__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7, 5, 15, 0.62) 0%, rgba(9, 7, 20, 0.36) 34%, rgba(7, 6, 16, 0.72) 100%), radial-gradient(circle at 18% 28%, rgba(255, 110, 70, 0.18) 0%, transparent 46%), radial-gradient(circle at 86% 16%, rgba(157, 78, 221, 0.22) 0%, transparent 40%);
}
.course-single-page .course-single-hero__content {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(320px, 0.78fr);
  gap: clamp(18px, 2vw, 30px);
  align-items: start;
}
.course-single-page .course-single-hero__left {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.course-single-page .course-single-hero__eyebrow {
  align-self: flex-start;
  margin-bottom: 2px;
}
.course-single-page .course-single-hero__title {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: clamp(34px, 3.2vw, 58px);
  line-height: 1.06;
  letter-spacing: -0.01em;
  color: #fff;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.48);
  max-width: 18ch;
}
.course-single-page .course-single-hero__subtitle {
  margin: 0;
  font-family: var(--ui-font-body);
  font-size: clamp(17px, 1.08vw, 22px);
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.86);
  max-width: 60ch;
}
.course-single-page .course-single-hero__lead {
  margin: 2px 0 0;
  font-family: var(--ui-font-body);
  font-size: clamp(15px, 0.94vw, 19px);
  line-height: 1.48;
  color: rgba(255, 255, 255, 0.82);
  max-width: 66ch;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.74);
}
.course-single-page .course-single-hero__chips {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}
.course-single-page .course-single-hero__cta-row {
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.course-single-page .course-single-hero__buy-form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  width: 100%;
}
.course-single-page .course-single-hero__cta-primary {
  min-height: 54px;
  min-width: min(300px, 100%);
  padding-inline: 22px;
  font-size: clamp(14px, 0.92vw, 17px);
  letter-spacing: -0.008em;
}
.course-single-page .course-single-hero__cta-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  border: 1px solid rgba(215, 170, 255, 0.56);
  border-radius: 14px;
  padding: 12px 22px;
  background: linear-gradient(180deg, rgba(24, 14, 44, 0.74) 0%, rgba(11, 9, 28, 0.92) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 20px rgba(157, 78, 221, 0.2);
  color: rgba(255, 255, 255, 0.94);
  font-family: var(--ui-font-heading);
  font-weight: 600;
  font-size: clamp(14px, 0.9vw, 16px);
  cursor: pointer;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}
.course-single-page .course-single-hero__cta-secondary:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 195, 230, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 24px rgba(255, 20, 147, 0.26);
}
.course-single-page .course-single-hero__cta-advisor {
  display: inline-flex;
  min-width: min(300px, 100%);
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  border-radius: 14px;
  border: 1px solid rgba(255, 191, 126, 0.52);
  padding: 12px 16px;
  background: linear-gradient(160deg, rgba(255, 133, 74, 0.18) 0%, rgba(255, 41, 140, 0.14) 54%, rgba(157, 78, 221, 0.2) 100%), linear-gradient(180deg, rgba(17, 11, 32, 0.86) 0%, rgba(10, 8, 24, 0.94) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 0 0 1px rgba(255, 115, 70, 0.16), 0 14px 28px rgba(3, 2, 12, 0.42), 0 0 26px rgba(255, 84, 128, 0.24);
  text-decoration: none;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
.course-single-page .course-single-hero__cta-advisor span {
  font-family: var(--ui-font-heading);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: rgba(255, 248, 242, 0.98);
}
.course-single-page .course-single-hero__cta-advisor small {
  font-family: var(--ui-font-body);
  font-size: 12px;
  color: rgba(255, 214, 196, 0.9);
}
.course-single-page .course-single-hero__cta-advisor:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 212, 170, 0.78);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24), 0 0 0 1px rgba(255, 115, 70, 0.2), 0 18px 36px rgba(4, 2, 14, 0.5), 0 0 32px rgba(255, 64, 128, 0.32);
}
.course-single-page .course-single-hero__panel {
  width: 100%;
  border-radius: 20px;
  padding: 16px;
  border-color: rgba(189, 140, 255, 0.36);
  background: linear-gradient(180deg, rgba(30, 17, 52, 0.56) 0%, rgba(12, 9, 31, 0.68) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16), 0 0 0 1px rgba(194, 136, 255, 0.16), 0 16px 34px rgba(2, 1, 9, 0.52), 0 0 50px rgba(157, 78, 221, 0.2);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.course-single-page .course-single-hero__media {
  display: block;
  width: 100%;
  border-radius: 14px;
  overflow: hidden;
  min-height: 220px;
  background: rgba(9, 7, 22, 0.74);
  border: 1px solid rgba(255, 255, 255, 0.08);
  text-decoration: none;
}
.course-single-page .course-single-hero__media img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.course-single-page .course-single-hero__media span {
  min-height: 220px;
  display: grid;
  place-items: center;
  font-family: var(--ui-font-body);
  color: rgba(255, 255, 255, 0.66);
}
.course-single-page .course-single-hero__benefits {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.course-single-page .course-single-hero__benefits li {
  position: relative;
  padding-left: 18px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.4;
}
.course-single-page .course-single-hero__benefits li::before {
  content: "";
  position: absolute;
  top: 0.56em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff6b35, #ff1493, #9d4edd);
  box-shadow: 0 0 10px rgba(255, 85, 140, 0.6);
}
.course-single-page .course-single-hero__program-link {
  display: inline-flex;
  align-self: flex-start;
  color: rgba(0, 245, 255, 0.95);
  font-family: var(--ui-font-body);
  font-size: 14px;
  text-decoration: none;
  text-shadow: 0 0 12px rgba(0, 245, 255, 0.24);
  transition: opacity 180ms ease;
}
.course-single-page .course-single-hero__program-link:hover {
  opacity: 0.86;
}

.course-single-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  padding: 6px 12px;
  background: rgba(14, 9, 30, 0.72);
  color: rgba(255, 255, 255, 0.9);
  font-family: var(--ui-font-body);
  font-size: 13px;
  line-height: 1;
  white-space: nowrap;
}
.course-single-chip--orange {
  border-color: rgba(255, 130, 64, 0.66);
  box-shadow: 0 0 16px rgba(255, 107, 53, 0.24);
}
.course-single-chip--violet {
  border-color: rgba(187, 110, 255, 0.66);
  box-shadow: 0 0 16px rgba(157, 78, 221, 0.24);
}
.course-single-chip--cyan {
  border-color: rgba(0, 245, 255, 0.55);
  box-shadow: 0 0 16px rgba(0, 245, 255, 0.18);
}

.course-single-proof {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 720px;
}

.course-single-price__old {
  margin: 0;
  color: rgba(255, 255, 255, 0.56);
  text-decoration: line-through;
  font-family: var(--ui-font-body);
  font-size: 14px;
}
.course-single-price__new {
  margin: 2px 0 0;
  font-family: var(--ui-font-heading);
  font-weight: 800;
  font-size: clamp(30px, 2vw, 38px);
  color: #fff;
  line-height: 1;
  letter-spacing: -0.02em;
  text-shadow: 0 0 18px rgba(255, 83, 109, 0.34), 0 0 30px rgba(157, 78, 221, 0.24);
}

.course-single-program {
  background: radial-gradient(circle at 14% 20%, rgba(255, 107, 53, 0.08) 0%, transparent 42%), radial-gradient(circle at 82% 14%, rgba(157, 78, 221, 0.12) 0%, transparent 42%), linear-gradient(180deg, rgba(8, 6, 18, 0.88) 0%, rgba(6, 5, 16, 0.95) 100%);
}
.course-single-program__badge {
  margin-bottom: 14px;
}
.course-single-program__title {
  margin: 0;
}
.course-single-program__lead {
  margin: 10px 0 0;
  max-width: 76ch;
}
.course-single-program__layout {
  margin-top: 24px;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.55fr);
  gap: 18px;
  align-items: start;
}
.course-single-program__modules {
  display: grid;
  gap: 10px;
}
.course-single-program__aside {
  border-radius: 18px;
  padding: 18px;
  border-color: rgba(193, 150, 255, 0.3);
  background: linear-gradient(180deg, rgba(25, 15, 46, 0.58) 0%, rgba(12, 9, 29, 0.72) 100%);
}
.course-single-program__aside h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
}
.course-single-program__aside ul {
  margin: 10px 0 14px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 7px;
}
.course-single-program__aside ul li {
  position: relative;
  padding-left: 16px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.35;
}
.course-single-program__aside ul li::before {
  content: ">";
  position: absolute;
  left: 0;
  color: #ff6b35;
  text-shadow: 0 0 12px rgba(255, 107, 53, 0.48);
}
.course-single-program__advisor {
  color: rgba(0, 245, 255, 0.95);
  font-family: var(--ui-font-body);
  font-size: 14px;
  text-decoration: none;
}
.course-single-program__advisor:hover {
  opacity: 0.86;
}

.course-single-module {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(14, 10, 30, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 14px 26px rgba(2, 1, 10, 0.36);
  overflow: hidden;
}
.course-single-module summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
}
.course-single-module summary::-webkit-details-marker {
  display: none;
}
.course-single-module__title {
  font-family: var(--ui-font-heading);
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  line-height: 1.28;
}
.course-single-module__count {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(157, 78, 221, 0.5);
  padding: 4px 10px;
  color: rgba(229, 206, 255, 0.95);
  font-family: var(--ui-font-body);
  font-size: 12px;
  white-space: nowrap;
}
.course-single-module__body {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 12px 16px 14px;
}
.course-single-module__body ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 7px;
}
.course-single-module__body ul li {
  position: relative;
  padding-left: 17px;
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.35;
}
.course-single-module__body ul li::before {
  content: "";
  position: absolute;
  top: 0.52em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff6b35, #ff1493);
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.4);
}
.course-single-module--empty {
  padding: 16px;
}
.course-single-module--empty p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--ui-font-body);
}

.course-single-outcomes {
  background: radial-gradient(circle at 10% 22%, rgba(0, 245, 255, 0.08) 0%, transparent 40%), radial-gradient(circle at 88% 12%, rgba(255, 20, 147, 0.1) 0%, transparent 38%), linear-gradient(180deg, rgba(8, 6, 18, 0.9) 0%, rgba(8, 6, 16, 0.95) 100%);
}
.course-single-outcomes__badge {
  margin-bottom: 14px;
}
.course-single-outcomes__title {
  margin: 0;
  max-width: 24ch;
}
.course-single-outcomes__grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.course-single-outcomes__card {
  border-radius: 16px;
  border-color: rgba(196, 147, 255, 0.24);
  padding: 14px;
  background: linear-gradient(180deg, rgba(20, 13, 39, 0.66) 0%, rgba(11, 9, 28, 0.78) 100%);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.course-single-outcomes__card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.4;
}
.course-single-outcomes__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 5px;
  flex-shrink: 0;
  background: linear-gradient(135deg, #ff6b35, #ff1493, #9d4edd);
  box-shadow: 0 0 12px rgba(255, 80, 150, 0.55);
}
.course-single-outcomes__tags {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.course-single-outcomes__tags span {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(12, 9, 28, 0.74);
  min-height: 30px;
  padding: 5px 11px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 12px;
}

@media (max-width: 1140px) {
  .course-single-page .course-single-hero__content {
    grid-template-columns: 1fr;
  }
  .course-single-page .course-single-hero__panel {
    max-width: 620px;
  }
  .course-single-program__layout {
    grid-template-columns: 1fr;
  }
  .course-single-outcomes__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .course-single-page .course-single-hero {
    padding-top: 102px;
  }
  .course-single-page .course-single-hero__title {
    font-size: clamp(30px, 8vw, 42px);
  }
  .course-single-page .course-single-hero__subtitle {
    font-size: 16px;
  }
  .course-single-page .course-single-hero__lead {
    font-size: 14px;
  }
  .course-single-page .course-single-hero__buy-form {
    flex-direction: column;
    align-items: stretch;
  }
  .course-single-page .course-single-hero__cta-primary, .course-single-page .course-single-hero__cta-secondary {
    width: 100%;
    min-width: 100%;
  }
  .course-single-page .course-single-hero__cta-advisor {
    width: 100%;
  }
  .course-single-page .course-single-hero__media, .course-single-page .course-single-hero__media img, .course-single-page .course-single-hero__media span {
    min-height: 200px;
  }
  .course-single-proof {
    grid-template-columns: 1fr;
  }
  .course-single-program__lead {
    font-size: 14px;
  }
  .course-single-outcomes__grid {
    grid-template-columns: 1fr;
  }
}
.path-single-page {
  --path-shell-bg:
    radial-gradient(circle at 10% 6%, rgba(0, 245, 255, 0.1) 0%, transparent 36%),
    radial-gradient(circle at 88% 12%, rgba(255, 20, 147, 0.12) 0%, transparent 42%),
    linear-gradient(180deg, rgba(7, 6, 17, 0.92) 0%, rgba(8, 6, 18, 0.98) 100%);
  --path-glass-soft: linear-gradient(180deg, rgba(28, 18, 50, 0.62) 0%, rgba(14, 10, 31, 0.74) 100%);
  --path-glass-strong: linear-gradient(180deg, rgba(34, 21, 58, 0.7) 0%, rgba(16, 11, 35, 0.8) 100%);
}
.path-single-page .path-single-hero {
  position: relative;
  isolation: isolate;
  padding-top: clamp(126px, 11vw, 164px);
  padding-bottom: clamp(74px, 8vw, 110px);
}
.path-single-page .path-single-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: url("/img/front-v2/formation-hero-bg.webp") center/cover no-repeat;
}
.path-single-page .path-single-hero__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7, 5, 15, 0.56) 0%, rgba(9, 7, 20, 0.3) 36%, rgba(7, 6, 16, 0.74) 100%), radial-gradient(circle at 18% 28%, rgba(255, 110, 70, 0.24) 0%, transparent 48%), radial-gradient(circle at 86% 16%, rgba(157, 78, 221, 0.3) 0%, transparent 44%);
}
.path-single-page .path-single-hero__content {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.24fr) minmax(330px, 0.76fr);
  gap: clamp(28px, 2.8vw, 44px);
  align-items: start;
}
.path-single-page .path-single-hero__left {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.path-single-page .path-single-hero__eyebrow {
  align-self: flex-start;
  margin-bottom: 2px;
}
.path-single-page .path-single-hero__title {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: clamp(40px, 3.7vw, 66px);
  line-height: 1.02;
  letter-spacing: -0.016em;
  color: #fff;
  text-shadow: 0 6px 24px rgba(0, 0, 0, 0.42), 0 0 28px rgba(157, 78, 221, 0.18);
  max-width: 16ch;
}
.path-single-page .path-single-hero__subtitle {
  margin: 0;
  font-family: var(--ui-font-body);
  font-size: clamp(18px, 1.08vw, 24px);
  line-height: 1.42;
  color: rgba(255, 255, 255, 0.88);
  max-width: 62ch;
}
.path-single-page .path-single-hero__lead {
  margin: 2px 0 0;
  font-family: var(--ui-font-body);
  font-size: clamp(15px, 0.94vw, 19px);
  line-height: 1.48;
  color: rgba(255, 255, 255, 0.82);
  max-width: 66ch;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.74);
}
.path-single-page .path-single-hero__facts {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  width: 100%;
  max-width: 980px;
}
.path-single-page .path-single-hero__fact {
  border-radius: 16px;
  border: 1px solid rgba(188, 140, 255, 0.32);
  background: var(--path-glass-soft);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 16px 30px rgba(5, 3, 16, 0.28);
  padding: 14px 15px;
  min-height: 118px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
}
.path-single-page .path-single-hero__fact-label {
  margin: 0;
  font-family: var(--ui-font-label);
  letter-spacing: 0.11em;
  text-transform: uppercase;
  font-size: 11px;
  color: rgba(212, 196, 255, 0.86);
}
.path-single-page .path-single-hero__fact-value {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.3;
  color: rgba(255, 255, 255, 0.98);
}
.path-single-page .path-single-hero__fact-hint {
  margin: 0;
  font-family: var(--ui-font-body);
  font-size: 13px;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.66);
}
.path-single-page .path-single-hero__cta-row {
  margin-top: 12px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.path-single-page .path-single-hero__cta-primary, .path-single-page .path-single-hero__cta-secondary, .path-single-page .path-single-hero__cta-download {
  min-height: 56px;
  border-radius: 14px;
  padding: 13px 24px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ui-font-heading);
  font-size: clamp(14px, 0.94vw, 18px);
  font-weight: 600;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
.path-single-page .path-single-hero__cta-primary {
  min-width: min(300px, 100%);
  letter-spacing: -0.008em;
}
.path-single-page .path-single-hero__cta-download {
  border: 1px solid rgba(120, 221, 255, 0.5);
  background: linear-gradient(180deg, rgba(9, 33, 52, 0.78) 0%, rgba(8, 20, 39, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), 0 0 20px rgba(0, 200, 255, 0.18);
  color: rgba(230, 249, 255, 0.98);
}
.path-single-page .path-single-hero__cta-download:hover {
  transform: translateY(-1px);
  border-color: rgba(151, 230, 255, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 24px rgba(0, 245, 255, 0.25);
}
.path-single-page .path-single-hero__cta-secondary {
  border: 1px solid rgba(215, 170, 255, 0.56);
  background: linear-gradient(180deg, rgba(24, 14, 44, 0.74) 0%, rgba(11, 9, 28, 0.92) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 0 20px rgba(157, 78, 221, 0.2);
  color: rgba(255, 255, 255, 0.94);
}
.path-single-page .path-single-hero__cta-secondary:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 195, 230, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 24px rgba(255, 20, 147, 0.26);
}
.path-single-page .path-single-hero__panel {
  width: 100%;
  border-radius: 22px;
  padding: 20px;
  border-color: rgba(189, 140, 255, 0.36);
  background: var(--path-glass-strong);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16), 0 0 0 1px rgba(194, 136, 255, 0.16), 0 18px 36px rgba(2, 1, 9, 0.42), 0 0 54px rgba(157, 78, 221, 0.22);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.path-single-page .path-single-hero__media {
  display: block;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  min-height: 240px;
  background: rgba(9, 7, 22, 0.64);
  border: 1px solid rgba(255, 255, 255, 0.14);
  text-decoration: none;
}
.path-single-page .path-single-hero__media img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.path-single-page .path-single-hero__media span {
  min-height: 240px;
  display: grid;
  place-items: center;
  font-family: var(--ui-font-body);
  color: rgba(255, 255, 255, 0.66);
}
.path-single-page .path-single-hero__benefits {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.path-single-page .path-single-hero__benefits li {
  position: relative;
  padding-left: 18px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.5;
}
.path-single-page .path-single-hero__benefits li::before {
  content: "";
  position: absolute;
  top: 0.56em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff6b35, #ff1493, #9d4edd);
  box-shadow: 0 0 10px rgba(255, 85, 140, 0.6);
}
.path-single-page .path-single-hero__actions {
  display: grid;
  gap: 10px;
}
.path-single-page .path-single-hero__download, .path-single-page .path-single-hero__program-link {
  display: inline-flex;
  align-self: flex-start;
  text-decoration: none;
  font-family: var(--ui-font-body);
  font-size: 15px;
  transition: opacity 180ms ease;
}
.path-single-page .path-single-hero__download:hover, .path-single-page .path-single-hero__program-link:hover {
  opacity: 0.86;
}
.path-single-page .path-single-hero__download {
  color: rgba(255, 235, 210, 0.98);
  text-shadow: 0 0 12px rgba(255, 165, 85, 0.24);
}
.path-single-page .path-single-hero__program-link {
  color: rgba(0, 245, 255, 0.95);
  text-shadow: 0 0 12px rgba(0, 245, 255, 0.24);
}

.path-single-proof {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  max-width: 820px;
}

.path-single-price__old {
  margin: 0;
  color: rgba(255, 255, 255, 0.56);
  text-decoration: line-through;
  font-family: var(--ui-font-body);
  font-size: 14px;
}
.path-single-price__new {
  margin: 2px 0 0;
  font-family: var(--ui-font-heading);
  font-weight: 800;
  font-size: clamp(30px, 2vw, 38px);
  color: #fff;
  line-height: 1;
  letter-spacing: -0.02em;
  text-shadow: 0 0 18px rgba(255, 83, 109, 0.34), 0 0 30px rgba(157, 78, 221, 0.24);
}

.path-single-outcomes {
  background: var(--path-shell-bg);
}
.path-single-outcomes__badge {
  margin-bottom: 14px;
}
.path-single-outcomes__title {
  margin: 0;
  max-width: 26ch;
}
.path-single-outcomes__lead {
  margin: 12px 0 0;
  max-width: 74ch;
}
.path-single-outcomes__grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.path-single-outcomes__card {
  border-radius: 18px;
  border-color: rgba(196, 147, 255, 0.3);
  padding: 18px;
  background: linear-gradient(180deg, rgba(22, 14, 41, 0.62) 0%, rgba(12, 9, 28, 0.72) 100%);
  box-shadow: 0 14px 28px rgba(4, 2, 14, 0.28);
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.path-single-outcomes__card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.52;
}
.path-single-outcomes__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 5px;
  flex-shrink: 0;
  background: linear-gradient(135deg, #ff6b35, #ff1493, #9d4edd);
  box-shadow: 0 0 12px rgba(255, 80, 150, 0.55);
}

.path-single-story {
  background: var(--path-shell-bg);
}
.path-single-story__badge {
  margin-bottom: 14px;
}
.path-single-story__title {
  margin: 0;
  max-width: 28ch;
}
.path-single-story__content {
  margin-top: 24px;
  border-radius: 20px;
  border-color: rgba(191, 144, 255, 0.32);
  background: linear-gradient(180deg, rgba(22, 14, 41, 0.62) 0%, rgba(12, 9, 28, 0.72) 100%);
  padding: clamp(20px, 2.5vw, 30px);
  box-shadow: 0 16px 34px rgba(3, 2, 12, 0.28);
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  line-height: 1.65;
}
.path-single-story__content > *:first-child {
  margin-top: 0;
}
.path-single-story__content > *:last-child {
  margin-bottom: 0;
}
.path-single-story__content h1,
.path-single-story__content h2,
.path-single-story__content h3,
.path-single-story__content h4 {
  color: #fff;
  font-family: var(--ui-font-heading);
  line-height: 1.25;
}
.path-single-story__content a {
  color: rgba(0, 245, 255, 0.95);
  text-decoration: none;
}
.path-single-story__content ul,
.path-single-story__content ol {
  padding-left: 18px;
}

.path-single-program {
  background: var(--path-shell-bg);
}
.path-single-program__badge {
  margin-bottom: 14px;
}
.path-single-program__title {
  margin: 0;
}
.path-single-program__lead {
  margin: 12px 0 0;
  max-width: 78ch;
}
.path-single-program__layout {
  margin-top: 30px;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.55fr);
  gap: 24px;
  align-items: start;
}
.path-single-program__steps {
  display: grid;
  gap: 14px;
}
.path-single-program__aside {
  border-radius: 20px;
  padding: 24px;
  border-color: rgba(193, 150, 255, 0.3);
  background: linear-gradient(180deg, rgba(25, 15, 46, 0.58) 0%, rgba(12, 9, 29, 0.68) 100%);
  box-shadow: 0 16px 34px rgba(3, 2, 12, 0.28);
}
.path-single-program__aside h3 {
  margin: 0;
  font-family: var(--ui-font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
}
.path-single-program__aside ul {
  margin: 12px 0 16px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 9px;
}
.path-single-program__aside ul li {
  position: relative;
  padding-left: 16px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.45;
}
.path-single-program__aside ul li::before {
  content: "›";
  position: absolute;
  left: 0;
  color: #ff6b35;
  text-shadow: 0 0 12px rgba(255, 107, 53, 0.48);
}
.path-single-program__empty, .path-single-program__degree {
  margin: 10px 0 14px;
  color: rgba(255, 255, 255, 0.84);
  font-family: var(--ui-font-body);
  font-size: 14px;
  line-height: 1.45;
}
.path-single-program__advisor {
  color: rgba(0, 245, 255, 0.95);
  font-family: var(--ui-font-body);
  font-size: 14px;
  text-decoration: none;
}
.path-single-program__advisor:hover {
  opacity: 0.86;
}

.path-single-step {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: linear-gradient(180deg, rgba(18, 12, 36, 0.76) 0%, rgba(11, 9, 28, 0.82) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 16px 30px rgba(2, 1, 10, 0.34);
  overflow: hidden;
}
.path-single-step summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 18px 20px;
}
.path-single-step summary::-webkit-details-marker {
  display: none;
}
.path-single-step__index {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(157, 78, 221, 0.56);
  background: rgba(21, 11, 39, 0.72);
  color: rgba(231, 212, 255, 0.95);
  font-family: var(--ui-font-heading);
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.path-single-step__main {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.path-single-step__title {
  font-family: var(--ui-font-heading);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  line-height: 1.28;
}
.path-single-step__meta {
  color: rgba(255, 255, 255, 0.7);
  font-family: var(--ui-font-body);
  font-size: 13px;
}
.path-single-step__body {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 16px 20px 20px;
}
.path-single-step__body h4 {
  margin: 14px 0 8px;
  font-family: var(--ui-font-heading);
  font-size: 16px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.94);
  letter-spacing: 0.01em;
}
.path-single-step__body p {
  margin: 0;
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.52;
}
.path-single-step__body .path-single-step__intro + h4 {
  margin-top: 12px;
}
.path-single-step__body ul {
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 9px;
}
.path-single-step__body ul li {
  position: relative;
  padding-left: 17px;
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.45;
}
.path-single-step__body ul li::before {
  content: "";
  position: absolute;
  top: 0.52em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff6b35, #ff1493);
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.4);
}
.path-single-step__body ul a {
  color: #fff;
  text-decoration: none;
}
.path-single-step__body ul a:hover {
  opacity: 0.86;
}
.path-single-step__intro {
  margin: 0;
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--ui-font-body);
  font-size: 15px;
  line-height: 1.56;
}
.path-single-step__courses-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.path-single-step__course-card {
  border-radius: 12px;
  border: 1px solid rgba(189, 143, 255, 0.28);
  background: linear-gradient(180deg, rgba(20, 13, 38, 0.66) 0%, rgba(10, 8, 25, 0.76) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  padding: 12px 14px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}
.path-single-step__course-card:hover {
  transform: translateY(-1px);
  border-color: rgba(212, 174, 255, 0.56);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 10px 18px rgba(4, 2, 12, 0.35), 0 0 18px rgba(157, 78, 221, 0.2);
}
.path-single-step__course-name {
  color: #fff;
  font-family: var(--ui-font-heading);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
}
.path-single-step__course-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.path-single-step__course-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(12, 9, 27, 0.78);
  color: rgba(255, 255, 255, 0.78);
  font-family: var(--ui-font-body);
  font-size: 11px;
  line-height: 1;
  white-space: nowrap;
}
.path-single-step--empty {
  padding: 16px;
}
.path-single-step--empty p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--ui-font-body);
}

.path-single-courses {
  background: var(--path-shell-bg);
}
.path-single-courses__badge {
  margin-bottom: 14px;
}
.path-single-courses__title {
  margin: 0;
}
.path-single-courses__lead {
  margin: 12px 0 0;
  max-width: 72ch;
}
.path-single-courses__grid {
  margin-top: 26px;
}

.path-single-media {
  background: var(--path-shell-bg);
}
.path-single-media__badge {
  margin-bottom: 14px;
}
.path-single-media__title {
  margin: 0;
}
.path-single-media__frame {
  margin-top: 24px;
  border-radius: 20px;
  overflow: hidden;
  padding: 14px;
}
.path-single-media__frame video {
  display: block;
  width: 100%;
  max-height: min(62vh, 620px);
  border-radius: 14px;
  background: rgba(3, 2, 10, 0.9);
}

@media (max-width: 1140px) {
  .path-single-page .path-single-hero__content {
    grid-template-columns: 1fr;
  }
  .path-single-page .path-single-hero__panel {
    max-width: 620px;
  }
  .path-single-page .path-single-hero__facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .path-single-program__layout {
    grid-template-columns: 1fr;
  }
  .path-single-outcomes__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .path-single-courses__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .path-single-step__courses-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .path-single-page .path-single-hero {
    padding-top: 102px;
  }
  .path-single-page .path-single-hero__title {
    font-size: clamp(30px, 8vw, 42px);
  }
  .path-single-page .path-single-hero__subtitle {
    font-size: 16px;
  }
  .path-single-page .path-single-hero__lead {
    font-size: 14px;
  }
  .path-single-page .path-single-hero__cta-row {
    flex-direction: column;
    align-items: stretch;
  }
  .path-single-page .path-single-hero__cta-primary, .path-single-page .path-single-hero__cta-secondary, .path-single-page .path-single-hero__cta-download {
    width: 100%;
    min-width: 100%;
  }
  .path-single-page .path-single-hero__facts {
    grid-template-columns: 1fr;
  }
  .path-single-page .path-single-hero__media, .path-single-page .path-single-hero__media img, .path-single-page .path-single-hero__media span {
    min-height: 200px;
  }
  .path-single-proof {
    grid-template-columns: 1fr;
  }
  .path-single-outcomes__grid {
    grid-template-columns: 1fr;
  }
  .path-single-courses__grid {
    grid-template-columns: 1fr;
  }
}
.formation-card {
  --card-domain-rgb: 0, 245, 255;
  position: relative;
  display: flex;
  flex-direction: column;
  background: rgba(10, 5, 22, 0.52);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  border-radius: 18px;
  overflow: hidden;
  border: none;
  box-shadow: none;
  transition: transform 0.28s ease;
}
.formation-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1.5px;
  background: linear-gradient(145deg, rgb(255, 120, 40) 0%, rgba(255, 80, 50, 0.95) 10%, rgba(255, 40, 80, 0.65) 22%, rgba(var(--card-domain-rgb), 0.7) 38%, rgba(var(--card-domain-rgb), 0.35) 62%, rgba(var(--card-domain-rgb), 0.15) 80%, rgba(var(--card-domain-rgb), 0.06) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 3;
  opacity: 0.65;
  transition: opacity 0.28s ease;
}
.formation-card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 19px;
  pointer-events: none;
  z-index: -1;
  box-shadow: 0 0 18px 6px rgba(var(--card-domain-rgb), 0.5), 0 0 40px 16px rgba(var(--card-domain-rgb), 0.3), 0 0 80px 32px rgba(var(--card-domain-rgb), 0.14), 0 0 130px 55px rgba(var(--card-domain-rgb), 0.06);
  opacity: 0.15;
  transition: opacity 0.28s ease, box-shadow 0.28s ease;
}
.formation-card:hover {
  transform: translateY(-5px);
}
.formation-card:hover::before {
  opacity: 1;
}
.formation-card:hover::after {
  opacity: 0.7;
  box-shadow: 0 0 22px 8px rgba(var(--card-domain-rgb), 0.65), 0 0 50px 20px rgba(var(--card-domain-rgb), 0.4), 0 0 95px 36px rgba(var(--card-domain-rgb), 0.2), 0 0 150px 58px rgba(var(--card-domain-rgb), 0.09);
}
.formation-card:hover .formation-card__hotspot {
  opacity: 1;
  box-shadow: 0 0 8px 4px rgba(var(--card-domain-rgb), 0.95), 0 0 20px 9px rgba(var(--card-domain-rgb), 0.7), 0 0 40px 16px rgba(var(--card-domain-rgb), 0.4), 0 0 70px 28px rgba(var(--card-domain-rgb), 0.18);
}
.formation-card:hover .formation-card__img {
  transform: scale(1.05);
}
.formation-card--certifying::before {
  background: linear-gradient(145deg, rgb(255, 140, 50) 0%, rgba(255, 80, 50, 0.98) 10%, rgba(255, 40, 80, 0.8) 22%, rgba(157, 78, 221, 0.9) 38%, rgba(157, 78, 221, 0.55) 62%, rgba(255, 107, 53, 0.25) 80%, rgba(255, 107, 53, 0.1) 100%);
  opacity: 0.9;
}

.formation-card__hotspot {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 1px;
  border-radius: 9999px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
  opacity: 0.25;
  box-shadow: 0 0 8px 4px rgba(var(--card-domain-rgb), 0.95), 0 0 20px 9px rgba(var(--card-domain-rgb), 0.7), 0 0 40px 16px rgba(var(--card-domain-rgb), 0.4), 0 0 70px 28px rgba(var(--card-domain-rgb), 0.18);
  transition: opacity 0.28s ease, box-shadow 0.28s ease;
}

.formation-card__img-wrap {
  position: relative;
  width: 100%;
  height: 260px;
  overflow: hidden;
  flex-shrink: 0;
  background: #0E0E1A;
}

.formation-card__img-link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.formation-card__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  transition: transform 0.45s ease;
}

.formation-card__img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #12121C 0%, #1A1A2E 100%);
  color: rgba(0, 245, 255, 0.3);
}

.formation-card__img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(10, 5, 22, 0.7) 75%, rgba(10, 5, 22, 0.96) 100%);
  pointer-events: none;
  z-index: 1;
}

.formation-card__img-certifying {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(157, 78, 221, 0.25) 0%, rgba(255, 107, 53, 0.15) 50%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}

.formation-card__badge-status {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 9px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #FFFFFF;
  background: rgba(var(--badge-rgb), 0.22);
  border: 1px solid rgba(var(--badge-rgb), 0.55);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.7);
  box-shadow: 0 0 8px rgba(var(--badge-rgb), 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.formation-card__badge-duration {
  position: absolute;
  bottom: 10px;
  left: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 22px;
  padding: 0 9px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 500;
  font-size: 11px;
  color: #FFFFFF;
  background: rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8);
}

.formation-card__badge-level-top {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #FFFFFF;
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8);
}

.formation-card__badge-promo {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #FFFFFF;
  background: linear-gradient(90deg, #FF6B35 0%, #FF1493 100%);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 0 10px rgba(255, 107, 53, 0.55), 0 0 18px rgba(255, 20, 147, 0.35);
}

.formation-card__badge-rncp {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 9px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.5), rgba(255, 107, 53, 0.4));
  border: 1px solid rgba(157, 78, 221, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 0 12px rgba(157, 78, 221, 0.4);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8);
}

.formation-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 16px 18px 18px;
  min-height: 360px;
  position: relative;
  z-index: 2;
}

.formation-card__badges {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.formation-card__badge-domain {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.03em;
  color: rgb(var(--badge-rgb, var(--card-domain-rgb)));
  background: rgba(var(--badge-rgb, var(--card-domain-rgb)), 0.1);
  border: 1px solid rgba(var(--badge-rgb, var(--card-domain-rgb)), 0.35);
  --badge-rgb: var(--card-domain-rgb);
}

.formation-card__badge-cpf {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: #FF6B35;
  background: rgba(255, 107, 53, 0.1);
  border: 1px solid rgba(255, 107, 53, 0.4);
}

.formation-card__badge-award {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.02em;
  color: rgba(234, 226, 255, 0.96);
  background: linear-gradient(90deg, rgba(157, 78, 221, 0.22) 0%, rgba(255, 107, 53, 0.2) 100%);
  border: 1px solid rgba(191, 142, 255, 0.45);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.65);
}

.formation-card__title {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 15px;
  line-height: 1.4;
  color: #FFFFFF;
  margin-bottom: 7px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8);
}

.formation-card__title-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.formation-card:hover .formation-card__title-link,
.formation-card__title-link:focus-visible {
  color: #FFD9C7;
  opacity: 1;
}

.formation-card__title--compact {
  font-size: 14px;
  line-height: 1.3;
  letter-spacing: -0.005em;
}

.formation-card__excerpt {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 13px;
  line-height: 1.5;
  color: #80809A;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.formation-card__sep {
  width: 100%;
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
  margin: 10px 0;
  flex-shrink: 0;
}

.formation-card__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.formation-card__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #80809A;
}

.formation-card__mentor-note {
  margin: 0 0 6px;
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 12px;
  line-height: 1.4;
  color: rgba(205, 228, 255, 0.88);
  text-shadow: 0 0 8px rgba(0, 245, 255, 0.18);
}

.formation-card__meta-dot {
  color: #3A3A4A;
  font-size: 12px;
}

.formation-card__badge-level {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 50px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: #C0C0D0;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.formation-card__rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  line-height: 1;
}

.formation-card__stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  line-height: 1;
}
.formation-card__stars svg {
  display: block;
  transform: translateY(-0.5px);
}

.formation-card__rating-value {
  display: inline-flex;
  align-items: center;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #FFFFFF;
  line-height: 1;
  letter-spacing: -0.01em;
}

.formation-card__price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 0;
}

.formation-card__price-old {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: #7A7A92;
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
}

.formation-card__price-new {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 20px;
  line-height: 1;
  letter-spacing: -0.01em;
  background: linear-gradient(95deg, #FF6B35 0%, #FF1493 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 10px rgba(255, 107, 53, 0.35));
}

.formation-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  width: 100%;
  height: 44px;
  border-radius: 10px;
  font-size: 13px;
  letter-spacing: 0.02em;
  text-decoration: none;
}
.formation-card__cta:hover .formation-card__cta-arrow {
  transform: translateX(4px);
}

.formation-card__cta-label {
  position: relative;
  z-index: 2;
}

.formation-card__cta-arrow {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  margin-left: 7px;
  transition: transform 0.22s ease;
}
.formation-card__cta-arrow svg {
  display: block;
}

.formation-card__advisor-link {
  margin-top: 9px;
  text-align: center;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #50506A;
}

.formation-card__advisor-btn {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: #00F5FF;
  text-decoration: underline;
  text-decoration-color: rgba(0, 245, 255, 0.3);
  text-underline-offset: 2px;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}
.formation-card__advisor-btn:hover {
  color: #FFFFFF;
  text-decoration-color: rgba(255, 255, 255, 0.5);
}
