/* ============================================================
   VISPANTE — Complete Stylesheet
   Elevated Cards Design System
   ============================================================ */


@import url('https://fonts.googleapis.com/css2?family=Crimson+Pro:wght@500;600;700&family=Albert+Sans:wght@400;500;600&display=swap');

/* ============================================================
   CUSTOM PROPERTIES
   ============================================================ */
:root {
  
  --clr-base-deep: #1a2340;
  --clr-base-warm: #c8a96e;
  --clr-base-light: #f4f1eb;

  
  --clr-primary: var(--clr-base-deep);
  --clr-primary-light: color-mix(in oklch, var(--clr-base-deep), white 30%);
  --clr-primary-lighter: color-mix(in oklch, var(--clr-base-deep), white 55%);
  --clr-primary-subtle: color-mix(in oklch, var(--clr-base-deep), white 80%);
  --clr-primary-ghost: color-mix(in oklch, var(--clr-base-deep), white 92%);

  --clr-accent: var(--clr-base-warm);
  --clr-accent-light: color-mix(in oklch, var(--clr-base-warm), white 35%);
  --clr-accent-lighter: color-mix(in oklch, var(--clr-base-warm), white 60%);
  --clr-accent-deep: color-mix(in oklch, var(--clr-base-warm), black 25%);

  --clr-surface: var(--clr-base-light);
  --clr-surface-warm: color-mix(in oklch, var(--clr-base-light), var(--clr-base-warm) 8%);
  --clr-surface-card: color-mix(in oklch, white, var(--clr-base-light) 40%);
  --clr-surface-dark: color-mix(in oklch, var(--clr-base-deep), black 15%);

  --clr-text-primary: color-mix(in oklch, var(--clr-base-deep), black 10%);
  --clr-text-secondary: color-mix(in oklch, var(--clr-base-deep), white 25%);
  --clr-text-muted: color-mix(in oklch, var(--clr-base-deep), white 45%);
  --clr-text-on-dark: color-mix(in oklch, var(--clr-base-light), white 20%);
  --clr-text-on-accent: color-mix(in oklch, var(--clr-base-deep), black 5%);

  --clr-border: color-mix(in oklch, var(--clr-base-deep), white 78%);
  --clr-border-light: color-mix(in oklch, var(--clr-base-deep), white 88%);

  
  --shadow-0: none;
  --shadow-1:
    0 1px 2px color-mix(in oklch, var(--clr-base-deep), transparent 88%),
    0 2px 4px color-mix(in oklch, var(--clr-base-deep), transparent 92%);
  --shadow-2:
    0 2px 4px color-mix(in oklch, var(--clr-base-deep), transparent 85%),
    0 6px 12px color-mix(in oklch, var(--clr-base-deep), transparent 88%),
    0 1px 2px color-mix(in oklch, var(--clr-base-warm), transparent 90%);
  --shadow-3:
    0 4px 8px color-mix(in oklch, var(--clr-base-deep), transparent 82%),
    0 12px 24px color-mix(in oklch, var(--clr-base-deep), transparent 85%),
    0 2px 4px color-mix(in oklch, var(--clr-base-warm), transparent 88%);
  --shadow-4:
    0 8px 16px color-mix(in oklch, var(--clr-base-deep), transparent 78%),
    0 20px 40px color-mix(in oklch, var(--clr-base-deep), transparent 82%),
    0 4px 8px color-mix(in oklch, var(--clr-base-warm), transparent 85%);
  --shadow-hover:
    0 12px 24px color-mix(in oklch, var(--clr-base-deep), transparent 74%),
    0 28px 48px color-mix(in oklch, var(--clr-base-deep), transparent 78%),
    0 6px 12px color-mix(in oklch, var(--clr-base-warm), transparent 82%);

  
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --sp-32: 8rem;

  
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 18px;
  --radius-xl: 28px;
  --radius-full: 9999px;

  
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;

  
  --font-heading: 'Crimson Pro', Georgia, serif;
  --font-body: 'Albert Sans', system-ui, sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--clr-text-primary);
  background-color: var(--clr-surface);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

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

ul, ol {
  list-style: none;
}

button {
  font-family: var(--font-body);
  cursor: pointer;
  border: none;
  background: none;
}

input, textarea, select {
  font-family: var(--font-body);
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: 1.2;
  color: var(--clr-text-primary);
}

h1 { font-size: clamp(2.4rem, 6vw, 4.5rem); }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.9rem); }
h4 { font-size: clamp(1.1rem, 2vw, 1.4rem); }

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

.Text--lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  line-height: 1.6;
  color: var(--clr-text-secondary);
}

.Text--small {
  font-size: 0.875rem;
  color: var(--clr-text-muted);
}

.Text--accent {
  color: var(--clr-accent-deep);
  font-weight: 600;
}

.Text--onDark {
  color: var(--clr-text-on-dark);
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.Container {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: var(--sp-6);
}

.Container--narrow {
  max-width: 800px;
}

.Container--wide {
  max-width: 1400px;
}

.Grid--2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}

.Grid--3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}

.Grid--4 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
}

@media (min-width: 768px) {
  .Grid--2 { grid-template-columns: 1fr 1fr; }
  .Grid--3 { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
  .Grid--4 { grid-template-columns: repeat(4, 1fr); }
}

.FlexRow {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.FlexBetween {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ============================================================
   SITE HEADER
   ============================================================ */
.SiteHeader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background: color-mix(in oklch, var(--clr-surface), transparent 8%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: background var(--transition-base);
}

.SiteHeader-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
  padding-inline: var(--sp-6);
  max-width: 1300px;
  margin-inline: auto;
  position: relative;
}

.SiteHeader-border {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 100%;
  height: 1px;
  background: var(--clr-border);
  transform-origin: center;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.SiteHeader.is-scrolled .SiteHeader-border {
  transform: translateX(-50%) scaleX(1);
}

.SiteHeader-logo {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  text-decoration: none;
  flex-shrink: 0;
}

.SiteHeader-logoImg {
  height: 38px;
  width: auto;
}

.SiteHeader-logoText {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--clr-primary);
  letter-spacing: -0.02em;
}

.SiteHeader-nav {
  display: none;
  align-items: center;
  gap: var(--sp-8);
}

.SiteHeader-navLink {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--clr-text-secondary);
  letter-spacing: 0.01em;
  position: relative;
  padding-bottom: 2px;
  transition: color var(--transition-base);
}

.SiteHeader-navLink::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--clr-accent);
  transition: width var(--transition-base);
}

.SiteHeader-navLink:hover {
  color: var(--clr-primary);
}

.SiteHeader-navLink:hover::after,
.SiteHeader-navLink.is-active::after {
  width: 100%;
}

.SiteHeader-navLink.is-active {
  color: var(--clr-primary);
  font-weight: 600;
}

.SiteHeader-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
}

.SiteHeader-hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: var(--sp-2);
  cursor: pointer;
  background: none;
  border: none;
  min-width: 44px;
  min-height: 44px;
  justify-content: center;
  align-items: center;
}

.SiteHeader-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--clr-primary);
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
}

@media (min-width: 1024px) {
  .SiteHeader-nav { display: flex; }
  .SiteHeader-hamburger { display: none; }
}


.LangSwitcher {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--clr-primary-ghost);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-full);
  padding: 4px 10px;
}

.LangSwitcher-btn {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--clr-text-muted);
  padding: 2px 4px;
  border-radius: var(--radius-sm);
  transition: all var(--transition-base);
  min-height: 28px;
  display: flex;
  align-items: center;
}

.LangSwitcher-btn:hover {
  color: var(--clr-primary);
}

.LangSwitcher-btn.active {
  color: var(--clr-primary);
  background: var(--clr-surface-card);
  box-shadow: var(--shadow-1);
}

.LangSwitcher-divider {
  color: var(--clr-border);
  font-size: 0.75rem;
}

/* ============================================================
   MOBILE MENU OVERLAY
   ============================================================ */
.MobileMenu {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: linear-gradient(
    135deg,
    var(--clr-primary) 0%,
    var(--clr-surface-dark) 100%
  );
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}

.MobileMenu.is-open {
  opacity: 1;
  pointer-events: all;
}

.MobileMenu-close {
  position: absolute;
  top: var(--sp-6);
  right: var(--sp-6);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-text-on-dark);
  font-size: 1.5rem;
  cursor: pointer;
  border-radius: var(--radius-full);
  transition: background var(--transition-base);
}

.MobileMenu-close:hover {
  background: color-mix(in oklch, white, transparent 85%);
}

.MobileMenu-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-8);
  text-align: center;
}

.MobileMenu-link {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 6vw, 2.8rem);
  font-weight: 600;
  color: var(--clr-text-on-dark);
  opacity: 0.85;
  transition: all var(--transition-base);
  letter-spacing: -0.01em;
}

.MobileMenu-link:hover {
  opacity: 1;
  color: var(--clr-accent-light);
}

.MobileMenu-lang {
  margin-top: var(--sp-10);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.MobileMenu-langBtn {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 30%);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-full);
  border: 1px solid color-mix(in oklch, white, transparent 70%);
  transition: all var(--transition-base);
  min-height: 44px;
  display: flex;
  align-items: center;
}

.MobileMenu-langBtn.active {
  color: var(--clr-text-on-dark);
  background: color-mix(in oklch, white, transparent 85%);
  border-color: color-mix(in oklch, white, transparent 60%);
}

.MobileMenu-langDivider {
  color: color-mix(in oklch, white, transparent 60%);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.Btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: all var(--transition-base);
  min-height: 48px;
  text-decoration: none;
  border: 2px solid transparent;
}

.Btn--primary {
  background: var(--clr-primary);
  color: var(--clr-text-on-dark);
  box-shadow: var(--shadow-2);
}

.Btn--primary:hover {
  background: color-mix(in oklch, var(--clr-primary), white 10%);
  box-shadow: var(--shadow-3);
  transform: translateY(-2px);
  color: var(--clr-text-on-dark);
}

.Btn--accent {
  background: var(--clr-accent);
  color: var(--clr-text-on-accent);
  box-shadow: var(--shadow-2);
}

.Btn--accent:hover {
  background: var(--clr-accent-deep);
  box-shadow: var(--shadow-3);
  transform: translateY(-2px);
  color: var(--clr-text-on-accent);
}

.Btn--outline {
  background: transparent;
  color: var(--clr-primary);
  border-color: var(--clr-primary);
}

.Btn--outline:hover {
  background: var(--clr-primary);
  color: var(--clr-text-on-dark);
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}

.Btn--outlineLight {
  background: transparent;
  color: var(--clr-text-on-dark);
  border-color: color-mix(in oklch, white, transparent 55%);
}

.Btn--outlineLight:hover {
  background: color-mix(in oklch, white, transparent 85%);
  border-color: color-mix(in oklch, white, transparent 40%);
  color: var(--clr-text-on-dark);
}

.Btn--sm {
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  min-height: 40px;
}

/* ============================================================
   CARDS
   ============================================================ */
.ContentCard {
  background: var(--clr-surface-card);
  border-radius: var(--radius-lg);
  padding: var(--sp-8);
  box-shadow: var(--shadow-2);
  border: 1px solid var(--clr-border-light);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.ContentCard:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.ContentCard--elevated {
  box-shadow: var(--shadow-3);
}

.ContentCard--elevated:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-6px);
}

.ContentCard--flat {
  box-shadow: var(--shadow-1);
}

.ContentCard--dark {
  background: var(--clr-primary);
  border-color: color-mix(in oklch, var(--clr-primary), white 15%);
}

.ContentCard--accent {
  background: linear-gradient(135deg, var(--clr-accent-lighter) 0%, color-mix(in oklch, var(--clr-accent-light), white 20%) 100%);
  border-color: var(--clr-accent-light);
}

.ContentCard-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  margin-bottom: var(--sp-5);
  background: var(--clr-primary-ghost);
  color: var(--clr-primary);
  flex-shrink: 0;
  transition: background var(--transition-base), color var(--transition-base);
}

.ContentCard:hover .ContentCard-icon {
  background: var(--clr-accent-lighter);
  color: var(--clr-accent-deep);
}

.ContentCard-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  margin-bottom: var(--sp-3);
}

.ContentCard-title {
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-3);
  line-height: 1.3;
}

.ContentCard-body {
  color: var(--clr-text-secondary);
  line-height: 1.65;
  font-size: 0.95rem;
}

/* ============================================================
   SECTION STYLES
   ============================================================ */
.PageSection {
  padding-block: var(--sp-24);
}

.PageSection--sm {
  padding-block: var(--sp-16);
}

.PageSection--lg {
  padding-block: var(--sp-32);
}

.PageSection--alt {
  background: var(--clr-surface-warm);
}

.PageSection--dark {
  background: var(--clr-primary);
}

.PageSection--gradient {
  background: linear-gradient(
    150deg,
    color-mix(in oklch, var(--clr-primary), var(--clr-base-warm) 12%) 0%,
    var(--clr-primary) 45%,
    color-mix(in oklch, var(--clr-primary), black 15%) 100%
  );
}

.SectionHeader {
  margin-bottom: var(--sp-12);
}

.SectionHeader--centered {
  text-align: center;
  max-width: 680px;
  margin-inline: auto;
  margin-bottom: var(--sp-12);
}

.SectionHeader-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  margin-bottom: var(--sp-4);
  padding: var(--sp-1) var(--sp-3);
  background: var(--clr-accent-lighter);
  border-radius: var(--radius-full);
}

.SectionHeader-eyebrow--light {
  color: var(--clr-accent-light);
  background: color-mix(in oklch, var(--clr-accent), transparent 75%);
}

.SectionHeader-title {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  color: var(--clr-text-primary);
  line-height: 1.2;
  margin-bottom: var(--sp-4);
}

.SectionHeader-title--light {
  color: var(--clr-text-on-dark);
}

.SectionHeader-body {
  color: var(--clr-text-secondary);
  font-size: 1.05rem;
  line-height: 1.7;
}

.SectionHeader-body--light {
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 20%);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.PageHero {
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  padding-top: 72px;
  padding-bottom: var(--sp-20);
  position: relative;
  overflow: hidden;
  background: var(--clr-surface);
}

.PageHero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.PageHero-bgImg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.12;
}

.PageHero-bgShape {
  position: absolute;
  top: -10%;
  right: -5%;
  width: 55%;
  height: 80%;
  background: linear-gradient(
    135deg,
    color-mix(in oklch, var(--clr-accent), transparent 70%) 0%,
    color-mix(in oklch, var(--clr-primary-subtle), transparent 40%) 100%
  );
  border-radius: 40% 60% 50% 70% / 50% 40% 60% 50%;
  filter: blur(60px);
  opacity: 0.6;
}

.PageHero-bgDot {
  position: absolute;
  bottom: 20%;
  left: 5%;
  width: 300px;
  height: 300px;
  background: radial-gradient(
    circle,
    color-mix(in oklch, var(--clr-accent), transparent 75%) 0%,
    transparent 70%
  );
  opacity: 0.5;
}

.PageHero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1300px;
  margin-inline: auto;
  padding-inline: var(--sp-6);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: end;
}

.PageHero-content {
  max-width: 100%;
}

.PageHero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  margin-bottom: var(--sp-6);
  padding: var(--sp-2) var(--sp-4);
  background: var(--clr-accent-lighter);
  border-radius: var(--radius-full);
  border: 1px solid var(--clr-accent-light);
}

.PageHero-heading {
  font-family: var(--font-heading);
  font-size: clamp(2.6rem, 7vw, 5.5rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-6);
}

.PageHero-heading em {
  font-style: normal;
  color: var(--clr-accent-deep);
}

.PageHero-aside {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.PageHero-description {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  line-height: 1.7;
  color: var(--clr-text-secondary);
  max-width: 420px;
}

.PageHero-ctas {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.PageHero-scroll {
  position: absolute;
  bottom: var(--sp-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  color: var(--clr-text-muted);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  animation: scrollBounce 2s ease-in-out infinite;
}

.PageHero-scroll i {
  font-size: 1rem;
}

@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(6px); }
}

@media (min-width: 900px) {
  .PageHero-inner {
    grid-template-columns: 60% 1fr;
    align-items: end;
  }

  .PageHero-ctas {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

/* ============================================================
   VALUES SECTION
   ============================================================ */
.ValuesSection {
  padding-block: var(--sp-24);
  background: var(--clr-surface-warm);
}

.ValuesSection-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}

@media (min-width: 640px) {
  .ValuesSection-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .ValuesSection-grid { grid-template-columns: repeat(4, 1fr); }
}

.ValueCard {
  background: var(--clr-surface-card);
  border-radius: var(--radius-lg);
  padding: var(--sp-8) var(--sp-6);
  box-shadow: var(--shadow-2);
  border: 1px solid var(--clr-border-light);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.ValueCard::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-accent), var(--clr-accent-light));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-base);
}

.ValueCard:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-5px);
}

.ValueCard:hover::before {
  transform: scaleX(1);
}

.ValueCard-icon {
  width: 54px;
  height: 54px;
  border-radius: var(--radius-md);
  background: var(--clr-primary-ghost);
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: var(--sp-5);
  transition: all var(--transition-base);
}

.ValueCard:hover .ValueCard-icon {
  background: var(--clr-primary);
  color: var(--clr-text-on-dark);
}

.ValueCard-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-3);
}

.ValueCard-body {
  font-size: 0.93rem;
  color: var(--clr-text-secondary);
  line-height: 1.65;
}

/* ============================================================
   FEATURES SECTION (TWO COLUMNS)
   ============================================================ */
.FeaturesSection {
  padding-block: var(--sp-24);
}

.FeaturesSection-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-16);
  align-items: start;
}

@media (min-width: 900px) {
  .FeaturesSection-layout { grid-template-columns: 1fr 1fr; gap: var(--sp-12); }
}

.FeaturesSection-intro {
  position: sticky;
  top: 100px;
}

.FeaturesSection-introImg {
  margin-top: var(--sp-8);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-4);
  aspect-ratio: 4/3;
}

.FeaturesSection-introImg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.FeaturesSection-introImg:hover img {
  transform: scale(1.03);
}

.FeatureItem {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--sp-5);
  padding-block: var(--sp-6);
  border-bottom: 1px solid var(--clr-border-light);
  transition: background var(--transition-base);
}

.FeatureItem:last-child {
  border-bottom: none;
}

.FeatureItem-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--clr-primary-ghost);
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.FeatureItem:hover .FeatureItem-icon {
  background: var(--clr-accent-lighter);
  color: var(--clr-accent-deep);
}

.FeatureItem-title {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}

.FeatureItem-body {
  font-size: 0.92rem;
  color: var(--clr-text-secondary);
  line-height: 1.65;
}

/* ============================================================
   GRADIENT SECTION
   ============================================================ */
.GradientSection {
  padding-block: var(--sp-24);
  background: linear-gradient(
    135deg,
    color-mix(in oklch, var(--clr-primary), var(--clr-base-warm) 18%) 0%,
    var(--clr-primary) 40%,
    color-mix(in oklch, var(--clr-primary), black 20%) 100%
  );
  position: relative;
  overflow: hidden;
}

.GradientSection::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -10%;
  width: 60%;
  height: 160%;
  background: radial-gradient(
    ellipse,
    color-mix(in oklch, var(--clr-accent), transparent 65%) 0%,
    transparent 70%
  );
  pointer-events: none;
}

.GradientSection::after {
  content: '';
  position: absolute;
  bottom: -20%;
  left: -5%;
  width: 40%;
  height: 100%;
  background: radial-gradient(
    ellipse,
    color-mix(in oklch, var(--clr-accent-light), transparent 75%) 0%,
    transparent 70%
  );
  pointer-events: none;
}

.GradientSection-inner {
  position: relative;
  z-index: 1;
}

.GradientSection-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}

@media (min-width: 768px) {
  .GradientSection-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .GradientSection-grid { grid-template-columns: repeat(3, 1fr); }
}

.GradientCard {
  background: color-mix(in oklch, white, transparent 88%);
  border: 1px solid color-mix(in oklch, white, transparent 75%);
  border-radius: var(--radius-lg);
  padding: var(--sp-8);
  backdrop-filter: blur(8px);
  transition: all var(--transition-base);
}

.GradientCard:hover {
  background: color-mix(in oklch, white, transparent 82%);
  transform: translateY(-4px);
  box-shadow: var(--shadow-3);
}

.GradientCard-icon {
  font-size: 2rem;
  color: var(--clr-accent-light);
  margin-bottom: var(--sp-4);
}

.GradientCard-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--clr-text-on-dark);
  margin-bottom: var(--sp-3);
}

.GradientCard-body {
  font-size: 0.93rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 25%);
  line-height: 1.65;
}

/* ============================================================
   CAROUSEL / SPLIDE
   ============================================================ */
.CarouselSection {
  padding-block: var(--sp-24);
  background: var(--clr-surface-warm);
  overflow: hidden;
}

.splide__slide {
  height: auto;
}

.splide__pagination__page {
  background: var(--clr-border);
  transition: all var(--transition-base);
}

.splide__pagination__page.is-active {
  background: var(--clr-primary);
  transform: scale(1.3);
}

.splide__arrow {
  background: var(--clr-surface-card);
  box-shadow: var(--shadow-2);
  border: 1px solid var(--clr-border-light);
  width: 44px;
  height: 44px;
  transition: all var(--transition-base);
}

.splide__arrow:hover {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  box-shadow: var(--shadow-3);
}

.splide__arrow svg {
  fill: var(--clr-primary);
  transition: fill var(--transition-base);
}

.splide__arrow:hover svg {
  fill: var(--clr-text-on-dark);
}

/* ============================================================
   PAGE INNER HERO (sub-pages)
   ============================================================ */
.InnerHero {
  padding-top: calc(72px + var(--sp-20));
  padding-bottom: var(--sp-16);
  background: var(--clr-surface);
  border-bottom: 1px solid var(--clr-border-light);
}

.InnerHero-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  margin-bottom: var(--sp-4);
  padding: var(--sp-1) var(--sp-3);
  background: var(--clr-accent-lighter);
  border-radius: var(--radius-full);
}

.InnerHero-heading {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: var(--clr-text-primary);
  max-width: 720px;
  line-height: 1.15;
  margin-bottom: var(--sp-5);
}

.InnerHero-body {
  font-size: 1.05rem;
  color: var(--clr-text-secondary);
  max-width: 600px;
  line-height: 1.7;
}

/* ============================================================
   ABOUT / TRAJECTORY PAGE
   ============================================================ */
.TimelineItem {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
  padding-block: var(--sp-8);
  border-bottom: 1px solid var(--clr-border-light);
}

@media (min-width: 768px) {
  .TimelineItem { grid-template-columns: 180px 1fr; gap: var(--sp-10); }
}

.TimelineItem:last-child { border-bottom: none; }

.TimelineItem-year {
  font-family: var(--font-heading);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--clr-accent-deep);
  line-height: 1;
}

.TimelineItem-label {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
}

.TimelineItem-title {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-3);
}

.TimelineItem-body {
  font-size: 0.95rem;
  color: var(--clr-text-secondary);
  line-height: 1.7;
}

/* ============================================================
   TEAM / PROFILE CARDS
   ============================================================ */
.ProfileCard {
  background: var(--clr-surface-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  border: 1px solid var(--clr-border-light);
  transition: all var(--transition-base);
}

.ProfileCard:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-5px);
}

.ProfileCard-image {
  aspect-ratio: 4/3;
  overflow: hidden;
}

.ProfileCard-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.ProfileCard:hover .ProfileCard-image img {
  transform: scale(1.04);
}

.ProfileCard-body {
  padding: var(--sp-6);
}

.ProfileCard-role {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  margin-bottom: var(--sp-2);
}

.ProfileCard-name {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-3);
}

.ProfileCard-bio {
  font-size: 0.92rem;
  color: var(--clr-text-secondary);
  line-height: 1.65;
}

/* ============================================================
   PROGRAM CARDS (Lo que hacemos)
   ============================================================ */
.ProgramCard {
  background: var(--clr-surface-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  border: 1px solid var(--clr-border-light);
  transition: all var(--transition-base);
}

.ProgramCard:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-6px);
}

.ProgramCard-image {
  aspect-ratio: 16/9;
  overflow: hidden;
}

.ProgramCard-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.ProgramCard:hover .ProgramCard-image img {
  transform: scale(1.04);
}

.ProgramCard-body {
  padding: var(--sp-8);
}

.ProgramCard-tag {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-accent-deep);
  background: var(--clr-accent-lighter);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-4);
}

.ProgramCard-title {
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-3);
  line-height: 1.25;
}

.ProgramCard-body-text {
  font-size: 0.93rem;
  color: var(--clr-text-secondary);
  line-height: 1.65;
}

/* ============================================================
   PYMES PAGE
   ============================================================ */
.PymesHero-image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-4);
  aspect-ratio: 16/9;
}

.PymesHero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.BenefitItem {
  display: flex;
  gap: var(--sp-5);
  padding-block: var(--sp-5);
  border-bottom: 1px solid var(--clr-border-light);
}

.BenefitItem:last-child { border-bottom: none; }

.BenefitItem-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--clr-accent-lighter);
  color: var(--clr-accent-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.BenefitItem-title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-1);
}

.BenefitItem-body {
  font-size: 0.92rem;
  color: var(--clr-text-secondary);
  line-height: 1.6;
}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.ContactSection {
  padding-block: var(--sp-24);
}

.ContactSection-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-12);
}

@media (min-width: 900px) {
  .ContactSection-layout { grid-template-columns: 1fr 1.3fr; }
}

.ContactInfo-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  padding-block: var(--sp-5);
  border-bottom: 1px solid var(--clr-border-light);
}

.ContactInfo-item:last-child { border-bottom: none; }

.ContactInfo-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--clr-primary-ghost);
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.ContactInfo-label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-1);
}

.ContactInfo-value {
  font-size: 0.95rem;
  color: var(--clr-text-secondary);
  line-height: 1.5;
}

.ContactInfo-value a {
  color: var(--clr-text-secondary);
  transition: color var(--transition-base);
}

.ContactInfo-value a:hover {
  color: var(--clr-primary);
}


.ContactForm {
  background: var(--clr-surface-card);
  border-radius: var(--radius-xl);
  padding: var(--sp-10);
  box-shadow: var(--shadow-3);
  border: 1px solid var(--clr-border-light);
}

.FormProgress {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
}

.FormProgress-step {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--clr-border-light);
  color: var(--clr-text-muted);
  transition: all var(--transition-base);
}

.FormProgress-step.is-active {
  background: var(--clr-primary);
  color: var(--clr-text-on-dark);
  box-shadow: var(--shadow-2);
}

.FormProgress-step.is-done {
  background: var(--clr-accent);
  color: var(--clr-text-on-accent);
}

.FormProgress-line {
  flex: 1;
  height: 2px;
  background: var(--clr-border-light);
  border-radius: var(--radius-full);
  position: relative;
  overflow: hidden;
}

.FormProgress-line::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--clr-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-slow);
}

.FormProgress-line.is-filled::after {
  transform: scaleX(1);
}

.FormStep {
  display: none;
}

.FormStep.is-active {
  display: block;
}

.FormGroup {
  margin-bottom: var(--sp-6);
}

.FormLabel {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}

.FormInput,
.FormTextarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--clr-text-primary);
  background: var(--clr-surface);
  transition: all var(--transition-base);
  min-height: 48px;
}

.FormInput:focus,
.FormTextarea:focus {
  outline: none;
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--clr-primary), transparent 85%);
}

.FormTextarea {
  min-height: 140px;
  resize: vertical;
}

.FormCheckbox {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  cursor: pointer;
  font-size: 0.88rem;
  color: var(--clr-text-secondary);
  line-height: 1.5;
}

.FormCheckbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--clr-primary);
  cursor: pointer;
}

.FormActions {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}

/* ============================================================
   MAPS
   ============================================================ */
.MapSection {
  padding-block: var(--sp-12);
}

.MapWrapper {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-3);
  border: 1px solid var(--clr-border-light);
  height: 400px;
}

.MapWrapper iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* ============================================================
   THANKS PAGE
   ============================================================ */
.ThanksPage {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-16) var(--sp-6);
  text-align: center;
}

.ThanksPage-inner {
  max-width: 500px;
}

.ThanksPage-dot {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--clr-accent), var(--clr-accent-light));
  margin-inline: auto;
  margin-bottom: var(--sp-8);
  box-shadow: var(--shadow-3);
  animation: dotReveal 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.ThanksPage-heading {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-4);
  animation: fadeInUp 0.6s ease 0.5s both;
}

.ThanksPage-body {
  color: var(--clr-text-secondary);
  font-size: 1.05rem;
  margin-bottom: var(--sp-8);
  animation: fadeInUp 0.6s ease 0.7s both;
  line-height: 1.7;
}

.ThanksPage-link {
  animation: fadeInUp 0.6s ease 0.9s both;
  display: inline-block;
}

@keyframes dotReveal {
  from { transform: scale(0); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.LegalPage {
  padding-block: var(--sp-24);
}

.LegalPage-content {
  max-width: 760px;
}

.LegalPage h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-top: var(--sp-10);
  margin-bottom: var(--sp-4);
}

.LegalPage h3 {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-top: var(--sp-6);
  margin-bottom: var(--sp-3);
}

.LegalPage p {
  margin-bottom: var(--sp-4);
  font-size: 0.95rem;
  line-height: 1.75;
}

.LegalPage a {
  color: var(--clr-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.LegalPage a:hover {
  color: var(--clr-accent-deep);
}

.LegalDate {
  font-size: 0.85rem;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-10);
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-primary-ghost);
  border-radius: var(--radius-md);
  display: inline-block;
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.SiteFooter {
  background: var(--clr-surface-dark);
  padding-top: var(--sp-16);
  padding-bottom: var(--sp-8);
}

.SiteFooter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  margin-bottom: var(--sp-12);
}

@media (min-width: 640px) {
  .SiteFooter-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .SiteFooter-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

.SiteFooter-brand {
  max-width: 300px;
}

.SiteFooter-logoImg {
  height: 36px;
  width: auto;
  margin-bottom: var(--sp-4);
  filter: brightness(0) invert(1) opacity(0.9);
}

.SiteFooter-tagline {
  font-size: 0.9rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 30%);
  line-height: 1.6;
  margin-bottom: var(--sp-5);
}

.SiteFooter-colTitle {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--clr-text-on-dark);
  margin-bottom: var(--sp-5);
  letter-spacing: 0.01em;
}

.SiteFooter-links {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.SiteFooter-link {
  font-size: 0.88rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 35%);
  transition: color var(--transition-base);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}

.SiteFooter-link:hover {
  color: var(--clr-accent-light);
}

.SiteFooter-contact {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.SiteFooter-contactItem {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: 0.88rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 30%);
}

.SiteFooter-contactItem i {
  color: var(--clr-accent-light);
  margin-top: 3px;
  flex-shrink: 0;
}

.SiteFooter-contactItem a {
  color: inherit;
  transition: color var(--transition-base);
}

.SiteFooter-contactItem a:hover {
  color: var(--clr-accent-light);
}

.SiteFooter-divider {
  border: none;
  border-top: 1px solid color-mix(in oklch, var(--clr-text-on-dark), transparent 80%);
  margin-bottom: var(--sp-6);
}

.SiteFooter-legal {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 768px) {
  .SiteFooter-legal { grid-template-columns: 1fr 1fr; }
}

.SiteFooter-legalInfo {
  font-size: 0.78rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 50%);
  line-height: 1.8;
}

.SiteFooter-legalInfo strong {
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 25%);
}

.SiteFooter-legalLinks {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  align-items: flex-start;
}

@media (min-width: 768px) {
  .SiteFooter-legalLinks { justify-content: flex-end; }
}

.SiteFooter-legalLink {
  font-size: 0.78rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 45%);
  transition: color var(--transition-base);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.SiteFooter-legalLink:hover {
  color: var(--clr-accent-light);
}

.SiteFooter-copy {
  font-size: 0.78rem;
  color: color-mix(in oklch, var(--clr-text-on-dark), transparent 55%);
  margin-top: var(--sp-4);
}

/* ============================================================
   COOKIE CONSENT
   ============================================================ */
.CookieConsent {
  position: fixed;
  top: var(--sp-6);
  left: var(--sp-6);
  z-index: 9999;
  width: 320px;
  max-width: calc(100vw - var(--sp-12));
  background: var(--clr-surface-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-4);
  border: 1px solid var(--clr-border-light);
  padding: var(--sp-5);
  transform: translateX(calc(-100% - var(--sp-6)));
  transition: transform 0.5s cubic-bezier(0.34, 1.2, 0.64, 1);
  opacity: 0;
}

.CookieConsent.is-visible {
  transform: translateX(0);
  opacity: 1;
}

.CookieConsent-header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}

.CookieConsent-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  background: var(--clr-primary-ghost);
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.CookieConsent-title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--clr-text-primary);
}

.CookieConsent-text {
  font-size: 0.82rem;
  color: var(--clr-text-secondary);
  line-height: 1.55;
  margin-bottom: var(--sp-4);
}

.CookieConsent-text a {
  color: var(--clr-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.CookieConsent-actions {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.CookieConsent-btn {
  flex: 1;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-base);
  min-height: 36px;
  border: 1.5px solid transparent;
  text-align: center;
}

.CookieConsent-btn--accept {
  background: var(--clr-primary);
  color: var(--clr-text-on-dark);
}

.CookieConsent-btn--accept:hover {
  background: color-mix(in oklch, var(--clr-primary), white 10%);
}

.CookieConsent-btn--reject {
  background: transparent;
  color: var(--clr-text-muted);
  border-color: var(--clr-border);
}

.CookieConsent-btn--reject:hover {
  border-color: var(--clr-text-muted);
  color: var(--clr-text-secondary);
}

.CookieConsent-btn--settings {
  width: 100%;
  flex: none;
  background: transparent;
  color: var(--clr-text-muted);
  font-size: 0.78rem;
  border-color: transparent;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.CookieConsent-btn--settings:hover {
  color: var(--clr-primary);
}


.CookieModal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-6);
  background: color-mix(in oklch, var(--clr-primary), transparent 60%);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
}

.CookieModal.is-open {
  opacity: 1;
  pointer-events: all;
}

.CookieModal-box {
  background: var(--clr-surface-card);
  border-radius: var(--radius-xl);
  padding: var(--sp-8);
  max-width: 520px;
  width: 100%;
  box-shadow: var(--shadow-hover);
  max-height: 80vh;
  overflow-y: auto;
}

.CookieModal-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-6);
}

.CookieCategory {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-block: var(--sp-4);
  border-bottom: 1px solid var(--clr-border-light);
  gap: var(--sp-4);
}

.CookieCategory:last-of-type { border-bottom: none; }

.CookieCategory-info {}

.CookieCategory-name {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-1);
}

.CookieCategory-desc {
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  line-height: 1.5;
}

.CookieToggle {
  position: relative;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}

.CookieToggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.CookieToggle-slider {
  position: absolute;
  inset: 0;
  background: var(--clr-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background var(--transition-base);
}

.CookieToggle-slider::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: white;
  border-radius: var(--radius-full);
  transition: transform var(--transition-base);
  box-shadow: var(--shadow-1);
}

.CookieToggle input:checked + .CookieToggle-slider {
  background: var(--clr-primary);
}

.CookieToggle input:checked + .CookieToggle-slider::after {
  transform: translateX(20px);
}

.CookieToggle input:disabled + .CookieToggle-slider {
  opacity: 0.5;
  cursor: not-allowed;
}

.CookieModal-actions {
  display: flex;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}

/* ============================================================
   UTILITIES
   ============================================================ */
.u-mb4 { margin-bottom: var(--sp-4); }
.u-mb6 { margin-bottom: var(--sp-6); }
.u-mb8 { margin-bottom: var(--sp-8); }
.u-mb12 { margin-bottom: var(--sp-12); }
.u-mt4 { margin-top: var(--sp-4); }
.u-mt8 { margin-top: var(--sp-8); }
.u-textCenter { text-align: center; }
.u-hidden { display: none !important; }

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
.js-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.js-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.js-reveal-delay-1 { transition-delay: 0.1s; }
.js-reveal-delay-2 { transition-delay: 0.2s; }
.js-reveal-delay-3 { transition-delay: 0.3s; }
.js-reveal-delay-4 { transition-delay: 0.4s; }

/* ============================================================
   RESPONSIVE ADJUSTMENTS
   ============================================================ */
@media (max-width: 640px) {
  .ContactForm { padding: var(--sp-6); }
  .PageHero { padding-bottom: var(--sp-16); }
  .PageSection { padding-block: var(--sp-16); }
  .ValuesSection { padding-block: var(--sp-16); }
  .FeaturesSection { padding-block: var(--sp-16); }
  .GradientSection { padding-block: var(--sp-16); }
  .CarouselSection { padding-block: var(--sp-16); }
}

@media (min-width: 1200px) {
  .Container { padding-inline: var(--sp-8); }
}