/* ============================================================
   GLASRRISUM - Financial Literacy | Complete Stylesheet
   Design Concept: Asymmetric Balance
   ============================================================ */


:root {
  
  --color-background-primary: #f7f5f0;
  --color-background-secondary: #edeae2;
  --color-background-dark: #1a1f2e;
  --color-background-deeper: #111520;
  --color-surface-card: #ffffff;
  --color-surface-tinted: #f0ede6;

  --color-text-primary: #1a1f2e;
  --color-text-secondary: #4a5168;
  --color-text-muted: #7a8099;
  --color-text-inverse: #f7f5f0;
  --color-text-inverse-muted: #b0b8cc;

  --color-accent-primary: #c8622a;
  --color-accent-secondary: #e8873f;
  --color-accent-tertiary: #f5a86e;
  --color-accent-cool: #2a6b8a;
  --color-accent-cool-light: #3d8fab;

  --color-gradient-start: #c8622a;
  --color-gradient-end: #e8873f;
  --color-gradient-cool: #2a6b8a;

  --color-border-light: #e0dbd0;
  --color-border-medium: #c8c2b5;

  
  --font-family-primary: 'Albert Sans', sans-serif;

  --font-size-xs: clamp(0.7rem, 0.65rem + 0.25vw, 0.8rem);
  --font-size-sm: clamp(0.85rem, 0.8rem + 0.25vw, 0.95rem);
  --font-size-base: clamp(1rem, 0.95rem + 0.25vw, 1.1rem);
  --font-size-md: clamp(1.1rem, 1rem + 0.5vw, 1.25rem);
  --font-size-lg: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
  --font-size-xl: clamp(1.5rem, 1.3rem + 1vw, 2rem);
  --font-size-2xl: clamp(2rem, 1.6rem + 2vw, 3rem);
  --font-size-3xl: clamp(2.5rem, 2rem + 2.5vw, 4rem);
  --font-size-4xl: clamp(3rem, 2.4rem + 3vw, 5.5rem);
  --font-size-display: clamp(3.5rem, 2.8rem + 3.5vw, 7rem);

  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;

  --line-height-tight: 1.1;
  --line-height-snug: 1.3;
  --line-height-normal: 1.6;
  --line-height-relaxed: 1.75;
  --line-height-loose: 1.9;

  --letter-spacing-tight: -0.03em;
  --letter-spacing-snug: -0.02em;
  --letter-spacing-normal: 0em;
  --letter-spacing-wide: 0.05em;
  --letter-spacing-wider: 0.1em;
  --letter-spacing-widest: 0.15em;

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

  
  --radius-xs: 2px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --radius-2xl: 32px;
  --radius-full: 9999px;

  
  --shadow-xs: 0 1px 2px rgba(26, 31, 46, 0.04), 0 1px 1px rgba(26, 31, 46, 0.02);
  --shadow-sm: 0 2px 4px rgba(26, 31, 46, 0.06), 0 1px 2px rgba(26, 31, 46, 0.04);
  --shadow-md: 0 4px 12px rgba(26, 31, 46, 0.08), 0 2px 4px rgba(26, 31, 46, 0.05), 0 1px 2px rgba(26, 31, 46, 0.03);
  --shadow-lg: 0 8px 24px rgba(26, 31, 46, 0.1), 0 4px 8px rgba(26, 31, 46, 0.06), 0 2px 4px rgba(26, 31, 46, 0.04);
  --shadow-xl: 0 16px 48px rgba(26, 31, 46, 0.12), 0 8px 16px rgba(26, 31, 46, 0.07), 0 2px 6px rgba(26, 31, 46, 0.04);
  --shadow-2xl: 0 24px 64px rgba(26, 31, 46, 0.15), 0 12px 24px rgba(26, 31, 46, 0.08), 0 4px 8px rgba(26, 31, 46, 0.05);
  --shadow-accent: 0 8px 24px rgba(200, 98, 42, 0.25), 0 4px 8px rgba(200, 98, 42, 0.12);
  --shadow-accent-lg: 0 16px 48px rgba(200, 98, 42, 0.3), 0 8px 16px rgba(200, 98, 42, 0.15);
  --shadow-inset: inset 0 2px 4px rgba(26, 31, 46, 0.06);

  
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-spring: 500ms cubic-bezier(0.34, 1.56, 0.64, 1);

  
  --container-max: 1280px;
  --content-max: 800px;
  --content-narrow: 640px;
  --nav-height: 72px;
}


*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

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

body {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--color-text-primary);
  background-color: var(--color-background-primary);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img {
  max-inline-size: 100%;
  block-size: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

input, textarea, select {
  font-family: inherit;
}


.site-container {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.content-container {
  max-inline-size: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.narrow-container {
  max-inline-size: var(--content-narrow);
  margin-inline: auto;
  padding-inline: var(--space-8);
}


h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-primary);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-snug);
  color: var(--color-text-primary);
}

h1 { font-size: var(--font-size-4xl); font-weight: var(--font-weight-extrabold); }
h2 { font-size: var(--font-size-3xl); font-weight: var(--font-weight-bold); }
h3 { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); }
h4 { font-size: var(--font-size-xl); font-weight: var(--font-weight-semibold); }
h5 { font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); }
h6 { font-size: var(--font-size-md); font-weight: var(--font-weight-medium); }

p { margin-block-end: var(--space-4); }
p:last-child { margin-block-end: 0; }

.text-accent-gradient {
  background: linear-gradient(135deg, var(--color-gradient-start), var(--color-gradient-end));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
}

/* ============================================================
   NAVIGATION
   ============================================================ */

.main-navigation-wrapper {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 1000;
  transition: background-color var(--transition-base), box-shadow var(--transition-base), backdrop-filter var(--transition-base);
}

.main-navigation-wrapper.nav-transparent {
  background-color: transparent;
  box-shadow: none;
}

.main-navigation-wrapper.nav-solid {
  background-color: rgba(247, 245, 240, 0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--shadow-sm);
}

.main-navigation-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  block-size: var(--nav-height);
}

.main-navigation-logo-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
  transition: opacity var(--transition-fast);
}

.main-navigation-logo-link:hover { opacity: 0.8; }

.main-navigation-logo-image {
  block-size: 36px;
  inline-size: auto;
}

.main-navigation-logo-text {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
  line-height: 1.2;
}

.main-navigation-logo-text span {
  display: block;
  font-weight: var(--font-weight-light);
  font-size: var(--font-size-xs);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-text-secondary);
}

.main-navigation-links-list {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}

.main-navigation-link-item {}

.main-navigation-link {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  transition: color var(--transition-fast);
  position: relative;
  padding-block: var(--space-2);
}

.main-navigation-link::after {
  content: '';
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  inline-size: 0;
  block-size: 2px;
  background: linear-gradient(90deg, var(--color-gradient-start), var(--color-gradient-end));
  transition: inline-size var(--transition-base);
  border-radius: var(--radius-full);
}

.main-navigation-link:hover { color: var(--color-text-primary); }
.main-navigation-link:hover::after { inline-size: 100%; }

.main-navigation-link.nav-link-active {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
}

.main-navigation-link.nav-link-active::after { inline-size: 100%; }

.main-navigation-actions-group {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.language-switcher-container {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  background: rgba(26, 31, 46, 0.06);
  border-radius: var(--radius-full);
}

.language-switcher-button {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.language-switcher-button:hover { color: var(--color-text-primary); }

.language-switcher-button.active {
  color: var(--color-accent-primary);
  background: rgba(200, 98, 42, 0.1);
}

.language-switcher-divider {
  color: var(--color-border-medium);
  font-size: var(--font-size-xs);
  user-select: none;
}

.navigation-button-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  border: 1.5px solid var(--color-border-medium);
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
}

.navigation-button-ghost:hover {
  border-color: var(--color-accent-primary);
  color: var(--color-accent-primary);
  background: rgba(200, 98, 42, 0.06);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.navigation-button-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
  background: linear-gradient(135deg, var(--color-gradient-start), var(--color-gradient-end));
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-accent);
}

.navigation-button-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-accent-lg);
  filter: brightness(1.05);
}

.navigation-button-primary:active { transform: translateY(0); }


.mobile-menu-toggle-button {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--space-2);
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.mobile-menu-toggle-button:hover { background: rgba(26, 31, 46, 0.06); }

.mobile-menu-toggle-line {
  display: block;
  inline-size: 24px;
  block-size: 2px;
  background: var(--color-text-primary);
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
  transform-origin: center;
}

.mobile-menu-toggle-button.menu-open .mobile-menu-toggle-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.mobile-menu-toggle-button.menu-open .mobile-menu-toggle-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.mobile-menu-toggle-button.menu-open .mobile-menu-toggle-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}


.mobile-menu-dropdown-panel {
  max-block-size: 0;
  overflow: hidden;
  background: rgba(247, 245, 240, 0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-block-end: 1px solid var(--color-border-light);
  transition: max-block-size var(--transition-slow);
}

.mobile-menu-dropdown-panel.panel-open {
  max-block-size: 600px;
}

.mobile-menu-dropdown-inner {
  padding: var(--space-6) var(--space-8) var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.mobile-menu-nav-link {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  padding: var(--space-3) 0;
  border-block-end: 1px solid var(--color-border-light);
  transition: color var(--transition-fast), padding-inline-start var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mobile-menu-nav-link:hover {
  color: var(--color-accent-primary);
  padding-inline-start: var(--space-3);
}

.mobile-menu-nav-link.nav-link-active { color: var(--color-accent-primary); font-weight: var(--font-weight-semibold); }

.mobile-menu-actions-row {
  display: flex;
  gap: var(--space-3);
  margin-block-start: var(--space-4);
  flex-wrap: wrap;
}

.mobile-menu-lang-switcher {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-block-start: var(--space-4);
  padding-block-start: var(--space-4);
  border-block-start: 1px solid var(--color-border-light);
}

.mobile-menu-lang-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* ============================================================
   BUTTONS
   ============================================================ */

.button-primary-large {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
  background: linear-gradient(135deg, var(--color-gradient-start), var(--color-gradient-end));
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-accent);
  letter-spacing: var(--letter-spacing-normal);
}

.button-primary-large:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-accent-lg);
  filter: brightness(1.05);
}

.button-primary-large:active { transform: translateY(0); }

.button-secondary-outline {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  border: 2px solid var(--color-border-medium);
  border-radius: var(--radius-full);
  transition: all var(--transition-base);
}

.button-secondary-outline:hover {
  border-color: var(--color-accent-primary);
  color: var(--color-accent-primary);
  background: rgba(200, 98, 42, 0.05);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.button-text-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent-primary);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.button-text-link:hover {
  color: var(--color-gradient-end);
  gap: var(--space-3);
}

.button-text-link-inverse {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
  opacity: 0.8;
  transition: gap var(--transition-fast), opacity var(--transition-fast);
}

.button-text-link-inverse:hover {
  opacity: 1;
  gap: var(--space-3);
}

/* ============================================================
   HERO SECTION
   ============================================================ */

.homepage-hero-section {
  position: relative;
  min-block-size: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block-start: var(--nav-height);
  overflow: hidden;
  background: var(--color-background-primary);
}

.homepage-hero-background-elements {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.hero-background-circle-large {
  position: absolute;
  inset-block-start: -20%;
  inset-inline-end: -10%;
  inline-size: 70vw;
  block-size: 70vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200, 98, 42, 0.06) 0%, transparent 70%);
}

.hero-background-circle-small {
  position: absolute;
  inset-block-end: 10%;
  inset-inline-start: -5%;
  inline-size: 40vw;
  block-size: 40vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(42, 107, 138, 0.08) 0%, transparent 70%);
}

.hero-background-line {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 62%;
  inline-size: 1px;
  block-size: 100%;
  background: linear-gradient(to bottom, transparent, rgba(200, 98, 42, 0.15), transparent);
}

.homepage-hero-content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  padding-block: var(--space-20);
}

.homepage-hero-text-column {
  max-inline-size: 620px;
}

.homepage-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  margin-block-end: var(--space-6);
}

.homepage-hero-eyebrow-tag {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  background: rgba(200, 98, 42, 0.1);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
  border: 1px solid rgba(200, 98, 42, 0.2);
}

.homepage-hero-eyebrow-line {
  inline-size: 40px;
  block-size: 1px;
  background: linear-gradient(90deg, var(--color-gradient-start), transparent);
}

.homepage-hero-heading {
  font-size: var(--font-size-display);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
  margin-block-end: var(--space-6);
}

.homepage-hero-heading-accent {
  position: relative;
  display: inline-block;
}

.homepage-hero-heading-accent .text-gradient-fill {
  background: linear-gradient(135deg, var(--color-gradient-start) 0%, var(--color-gradient-end) 50%, var(--color-accent-cool) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.homepage-hero-description {
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  margin-block-end: var(--space-10);
  max-inline-size: 520px;
}

.homepage-hero-cta-group {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  flex-wrap: wrap;
}

.homepage-hero-trust-note {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-block-start: var(--space-8);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.homepage-hero-trust-icon {
  color: var(--color-accent-cool);
  font-size: var(--font-size-sm);
}

.homepage-hero-visual-column {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}


.homepage-hero-atropos-wrapper {
  inline-size: 100%;
  max-inline-size: 480px;
}

.homepage-hero-card-inner {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background: var(--color-background-dark);
  box-shadow: var(--shadow-2xl);
  aspect-ratio: 4/5;
}

.homepage-hero-card-image-container {
  position: absolute;
  inset: 0;
}

.homepage-hero-card-image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.85;
}

.homepage-hero-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(17, 21, 32, 0.9) 0%, rgba(17, 21, 32, 0.4) 50%, transparent 100%);
}

.homepage-hero-card-content {
  position: absolute;
  inset-block-end: 0;
  inset-inline: 0;
  padding: var(--space-8);
}

.homepage-hero-card-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-tertiary);
  margin-block-end: var(--space-2);
}

.homepage-hero-card-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-inverse);
  line-height: var(--line-height-snug);
  margin-block-end: var(--space-4);
}

.homepage-hero-card-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: rgba(200, 98, 42, 0.9);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: white;
}

.homepage-hero-card-floating-tag {
  position: absolute;
  inset-block-start: var(--space-6);
  inset-inline-end: var(--space-6);
  background: rgba(247, 245, 240, 0.95);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-lg);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

.homepage-hero-card-floating-tag span {
  display: block;
  font-weight: var(--font-weight-light);
  color: var(--color-text-muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* ============================================================
   SECTION COMPONENTS
   ============================================================ */

.section-label-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-block-end: var(--space-6);
}

.section-label-line {
  flex: 1;
  block-size: 1px;
  background: var(--color-border-light);
  max-inline-size: 60px;
}

/* ============================================================
   MISSION STRIP
   ============================================================ */

.homepage-mission-strip-section {
  background: var(--color-background-dark);
  padding-block: var(--space-16);
  overflow: hidden;
  position: relative;
}

.homepage-mission-strip-section::before {
  content: '';
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 4px;
  block-size: 100%;
  background: linear-gradient(to bottom, var(--color-gradient-start), var(--color-gradient-end));
}

.homepage-mission-content-wrapper {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-16);
  align-items: center;
}

.homepage-mission-label-column {}

.homepage-mission-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-tertiary);
  margin-block-end: var(--space-4);
}

.homepage-mission-heading-small {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-text-inverse);
  line-height: var(--line-height-snug);
}

.homepage-mission-text-column {
  border-inline-start: 1px solid rgba(247, 245, 240, 0.1);
  padding-inline-start: var(--space-16);
}

.homepage-mission-statement {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-inverse-muted);
  font-weight: var(--font-weight-light);
}

.homepage-mission-statement strong {
  color: var(--color-text-inverse);
  font-weight: var(--font-weight-semibold);
}

/* ============================================================
   WHAT WE DO / SERVICES SECTION
   ============================================================ */

.homepage-services-section {
  padding-block: var(--space-32);
  background: var(--color-background-primary);
}

.homepage-services-layout-grid {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.homepage-services-header-row {
  display: grid;
  grid-template-columns: 5fr 4fr;
  gap: var(--space-16);
  align-items: end;
  margin-block-end: var(--space-16);
}

.homepage-services-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.homepage-services-intro-text {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

.homepage-services-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.service-card-wrapper {
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

.service-card-wrapper:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
  border-color: transparent;
}

.service-card-image-container {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
}

.service-card-image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform var(--transition-slow);
}

.service-card-wrapper:hover .service-card-image { transform: scale(1.05); }

.service-card-image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(17, 21, 32, 0.5), transparent);
}

.service-card-number {
  position: absolute;
  inset-block-end: var(--space-4);
  inset-inline-start: var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--letter-spacing-wider);
  color: var(--color-text-inverse);
  opacity: 0.7;
}

.service-card-body {
  padding: var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.service-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 44px;
  block-size: 44px;
  border-radius: var(--radius-md);
  background: rgba(200, 98, 42, 0.1);
  color: var(--color-accent-primary);
  font-size: var(--font-size-lg);
  margin-block-end: var(--space-4);
  transition: all var(--transition-base);
}

.service-card-wrapper:hover .service-card-icon {
  background: var(--color-accent-primary);
  color: white;
}

.service-card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-3);
  line-height: var(--line-height-snug);
}

.service-card-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  flex: 1;
  margin-block-end: var(--space-5);
}

.service-card-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent-primary);
  transition: gap var(--transition-fast), color var(--transition-fast);
  margin-block-start: auto;
}

.service-card-link:hover {
  gap: var(--space-3);
  color: var(--color-accent-secondary);
}

/* ============================================================
   APPROACH / HOW IT WORKS SECTION
   ============================================================ */

.homepage-approach-section {
  padding-block: var(--space-32);
  background: var(--color-background-secondary);
  position: relative;
  overflow: hidden;
}

.homepage-approach-section::after {
  content: '';
  position: absolute;
  inset-block-end: 0;
  inset-inline-end: 0;
  inline-size: 40%;
  block-size: 2px;
  background: linear-gradient(to left, var(--color-gradient-start), transparent);
}

.homepage-approach-content-wrapper {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.homepage-approach-layout-split {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: var(--space-20);
  align-items: start;
}

.homepage-approach-sidebar {}

.homepage-approach-sidebar-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
}

.homepage-approach-sidebar-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-6);
}

.homepage-approach-sidebar-text {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  margin-block-end: var(--space-8);
}

.homepage-approach-steps-column {}

.approach-step-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-6);
  padding-block: var(--space-8);
  border-block-end: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
}

.approach-step-item:last-child { border-block-end: none; }

.approach-step-item:hover { padding-inline-start: var(--space-4); }

.approach-step-number-block {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  inline-size: 48px;
  block-size: 48px;
  border-radius: var(--radius-md);
  background: var(--color-background-primary);
  border: 1px solid var(--color-border-light);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent-primary);
  padding-block-start: var(--space-3);
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.approach-step-item:hover .approach-step-number-block {
  background: var(--color-accent-primary);
  color: white;
  border-color: var(--color-accent-primary);
}

.approach-step-content {}

.approach-step-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-2);
}

.approach-step-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

/* ============================================================
   FEATURED IMAGE SECTION (EDITORIAL BREAK)
   ============================================================ */

.homepage-editorial-break-section {
  position: relative;
  block-size: 60vh;
  overflow: hidden;
}

.homepage-editorial-image-full {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center 30%;
}

.homepage-editorial-image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(17, 21, 32, 0.8) 0%, rgba(17, 21, 32, 0.3) 60%, transparent 100%);
}

.homepage-editorial-caption-block {
  position: absolute;
  inset-block-end: var(--space-12);
  inset-inline-start: var(--space-16);
  max-inline-size: 500px;
}

.homepage-editorial-caption-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-tertiary);
  margin-block-end: var(--space-3);
}

.homepage-editorial-caption-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-inverse);
  line-height: var(--line-height-snug);
  margin-block-end: var(--space-4);
}

.homepage-editorial-caption-text {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-inverse-muted);
}

/* ============================================================
   PRINCIPLES / VALUES SECTION
   ============================================================ */

.homepage-principles-section {
  padding-block: var(--space-32);
  background: var(--color-background-primary);
}

.homepage-principles-content-container {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.homepage-principles-header {
  max-inline-size: 600px;
  margin-block-end: var(--space-16);
}

.homepage-principles-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
}

.homepage-principles-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-4);
}

.homepage-principles-intro {
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

.homepage-principles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.principle-card-item {
  padding: var(--space-8);
  background: var(--color-surface-tinted);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.principle-card-item::before {
  content: '';
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 3px;
  background: linear-gradient(90deg, var(--color-gradient-start), var(--color-gradient-end));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-base);
}

.principle-card-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  background: var(--color-surface-card);
}

.principle-card-item:hover::before { transform: scaleX(1); }

.principle-card-icon {
  font-size: var(--font-size-2xl);
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
  display: block;
  transition: transform var(--transition-spring);
}

.principle-card-item:hover .principle-card-icon { transform: scale(1.1) rotate(-5deg); }

.principle-card-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-3);
}

.principle-card-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

/* ============================================================
   BLOG SECTION
   ============================================================ */

.homepage-blog-section {
  padding-block: var(--space-32);
  background: var(--color-background-secondary);
}

.homepage-blog-layout-container {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.homepage-blog-header-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  margin-block-end: var(--space-12);
  gap: var(--space-8);
}

.homepage-blog-header-left {}

.homepage-blog-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-3);
}

.homepage-blog-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

.homepage-blog-cards-grid {
  display: grid;
  grid-template-columns: 5fr 4fr 4fr;
  gap: var(--space-6);
  align-items: start;
}

.blog-article-card {
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-xs);
  cursor: pointer;
}

.blog-article-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
  border-color: transparent;
}

.blog-article-card--featured {
  grid-row: span 1;
}

.blog-article-card-image-container {
  position: relative;
  overflow: hidden;
}

.blog-article-card--featured .blog-article-card-image-container { aspect-ratio: 16/10; }
.blog-article-card:not(.blog-article-card--featured) .blog-article-card-image-container { aspect-ratio: 16/9; }

.blog-article-card-image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.blog-article-card:hover .blog-article-card-image { transform: scale(1.04); }

.blog-article-card-body {
  padding: var(--space-6);
}

.blog-article-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-block-end: var(--space-3);
}

.blog-article-card-category {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-accent-primary);
}

.blog-article-card-date {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.blog-article-card-dot {
  inline-size: 4px;
  block-size: 4px;
  border-radius: 50%;
  background: var(--color-border-medium);
  flex-shrink: 0;
}

.blog-article-card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-text-primary);
  margin-block-end: var(--space-3);
  transition: color var(--transition-fast);
}

.blog-article-card--featured .blog-article-card-title { font-size: var(--font-size-xl); }

.blog-article-card:hover .blog-article-card-title { color: var(--color-accent-primary); }

.blog-article-card-excerpt {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  margin-block-end: var(--space-4);
}

.blog-article-card-read-more {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent-primary);
  transition: gap var(--transition-fast);
}

.blog-article-card:hover .blog-article-card-read-more { gap: var(--space-3); }


.blog-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(17, 21, 32, 0.8);
  backdrop-filter: blur(8px);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
}

.blog-modal-overlay.modal-visible {
  opacity: 1;
  pointer-events: all;
}

.blog-modal-content-panel {
  background: var(--color-surface-card);
  border-radius: var(--radius-2xl);
  max-inline-size: 700px;
  inline-size: 100%;
  max-block-size: 85vh;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
  transform: translateY(20px);
  transition: transform var(--transition-base);
}

.blog-modal-overlay.modal-visible .blog-modal-content-panel {
  transform: translateY(0);
}

.blog-modal-image-header {
  position: relative;
  aspect-ratio: 16/7;
  overflow: hidden;
}

.blog-modal-header-image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.blog-modal-close-button {
  position: absolute;
  inset-block-start: var(--space-4);
  inset-inline-end: var(--space-4);
  inline-size: 40px;
  block-size: 40px;
  border-radius: 50%;
  background: rgba(247, 245, 240, 0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-lg);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-md);
}

.blog-modal-close-button:hover {
  background: white;
  transform: scale(1.1);
}

.blog-modal-body-content {
  padding: var(--space-10);
}

.blog-modal-category-tag {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
}

.blog-modal-article-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-snug);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-6);
}

.blog-modal-article-body {
  font-size: var(--font-size-base);
  line-height: var(--line-height-loose);
  color: var(--color-text-secondary);
}

.blog-modal-article-body p { margin-block-end: var(--space-5); }
.blog-modal-article-body p:last-child { margin-block-end: 0; }

/* ============================================================
   LOCATION SECTION
   ============================================================ */

.homepage-location-section {
  padding-block: var(--space-32);
  background: var(--color-background-dark);
  position: relative;
  overflow: hidden;
}

.homepage-location-section::before {
  content: '';
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  inline-size: 50%;
  block-size: 100%;
  background: radial-gradient(ellipse at right center, rgba(42, 107, 138, 0.15), transparent 70%);
  pointer-events: none;
}

.homepage-location-content-wrapper {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.homepage-location-info-column {}

.homepage-location-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-tertiary);
  margin-block-end: var(--space-4);
}

.homepage-location-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-text-inverse);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-8);
}

.location-contact-detail-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding-block: var(--space-5);
  border-block-end: 1px solid rgba(247, 245, 240, 0.08);
  transition: padding-inline-start var(--transition-fast);
}

.location-contact-detail-item:hover { padding-inline-start: var(--space-3); }
.location-contact-detail-item:last-child { border-block-end: none; }

.location-contact-detail-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 40px;
  block-size: 40px;
  border-radius: var(--radius-md);
  background: rgba(200, 98, 42, 0.15);
  color: var(--color-accent-tertiary);
  font-size: var(--font-size-base);
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.location-contact-detail-item:hover .location-contact-detail-icon {
  background: var(--color-accent-primary);
  color: white;
}

.location-contact-detail-text {}

.location-contact-detail-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-text-inverse-muted);
  margin-block-end: var(--space-1);
}

.location-contact-detail-value {
  font-size: var(--font-size-base);
  color: var(--color-text-inverse);
  font-weight: var(--font-weight-medium);
}

.location-contact-detail-value a {
  color: var(--color-text-inverse);
  transition: color var(--transition-fast);
}

.location-contact-detail-value a:hover { color: var(--color-accent-tertiary); }

.homepage-location-map-column {}

.homepage-location-map-frame {
  border-radius: var(--radius-xl);
  overflow: hidden;
  block-size: 400px;
  box-shadow: var(--shadow-2xl);
  border: 1px solid rgba(247, 245, 240, 0.1);
}

.homepage-location-map-frame iframe {
  inline-size: 100%;
  block-size: 100%;
  border: none;
  display: block;
}

/* ============================================================
   INNER PAGE HERO
   ============================================================ */

.inner-page-hero-section {
  padding-block-start: calc(var(--nav-height) + var(--space-20));
  padding-block-end: var(--space-20);
  background: var(--color-background-primary);
  position: relative;
  overflow: hidden;
}

.inner-page-hero-section::before {
  content: '';
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  inline-size: 40%;
  block-size: 100%;
  background: radial-gradient(ellipse at right top, rgba(200, 98, 42, 0.06), transparent 70%);
}

.inner-page-hero-content {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: var(--space-16);
  align-items: end;
}

.inner-page-hero-text-block {}

.inner-page-hero-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-block-end: var(--space-6);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.inner-page-hero-breadcrumb-link {
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.inner-page-hero-breadcrumb-link:hover { color: var(--color-accent-primary); }

.inner-page-hero-breadcrumb-sep {
  color: var(--color-border-medium);
}

.inner-page-hero-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
}

.inner-page-hero-heading {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-6);
}

.inner-page-hero-description {
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  max-inline-size: 520px;
}

.inner-page-hero-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-8);
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-md);
  align-self: center;
}

.inner-page-hero-aside-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.inner-page-hero-aside-icon {
  color: var(--color-accent-primary);
  font-size: var(--font-size-base);
  margin-block-start: 2px;
  flex-shrink: 0;
}

.inner-page-hero-aside-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-snug);
}

.inner-page-hero-aside-text strong {
  display: block;
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  margin-block-end: var(--space-1);
}

/* ============================================================
   GENERAL PAGE CONTENT SECTIONS
   ============================================================ */

.page-content-section {
  padding-block: var(--space-24);
}

.page-content-section--alternate {
  background: var(--color-background-secondary);
}

.page-content-section--dark {
  background: var(--color-background-dark);
}

.page-section-container {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.page-section-heading {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-6);
}

.page-section-subheading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-4);
}

.page-section-body-text {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  max-inline-size: 700px;
  margin-block-end: var(--space-6);
}

.page-section-body-text:last-child { margin-block-end: 0; }


.two-column-content-layout {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: var(--space-16);
  align-items: start;
}

.two-column-content-layout--reversed {
  grid-template-columns: 2fr 3fr;
}

.content-image-block {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}

.content-image-block img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  display: block;
}


.feature-list-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-block: var(--space-8);
}

.feature-list-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-surface-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
}

.feature-list-item:hover {
  border-color: rgba(200, 98, 42, 0.3);
  box-shadow: var(--shadow-md);
  transform: translateX(4px);
}

.feature-list-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 40px;
  block-size: 40px;
  border-radius: var(--radius-md);
  background: rgba(200, 98, 42, 0.1);
  color: var(--color-accent-primary);
  font-size: var(--font-size-base);
  flex-shrink: 0;
  transition: all var(--transition-base);
}

.feature-list-item:hover .feature-list-item-icon {
  background: var(--color-accent-primary);
  color: white;
}

.feature-list-item-text {}

.feature-list-item-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-1);
}

.feature-list-item-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}


.workshop-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-block-start: var(--space-8);
}

.workshop-detail-card {
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
}

.workshop-detail-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.workshop-card-image-container {
  aspect-ratio: 16/9;
  overflow: hidden;
}

.workshop-card-image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.workshop-detail-card:hover .workshop-card-image { transform: scale(1.04); }

.workshop-card-body {
  padding: var(--space-6);
}

.workshop-card-tag {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  background: rgba(200, 98, 42, 0.1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  margin-block-end: var(--space-4);
}

.workshop-card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-3);
  line-height: var(--line-height-snug);
}

.workshop-card-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

/* ============================================================
   DARK CALLOUT SECTION
   ============================================================ */

.dark-callout-section {
  padding-block: var(--space-24);
  background: var(--color-background-dark);
  position: relative;
  overflow: hidden;
}

.dark-callout-section::before {
  content: '';
  position: absolute;
  inset-block-start: -50%;
  inset-inline-start: -20%;
  inline-size: 60%;
  block-size: 200%;
  background: radial-gradient(ellipse, rgba(200, 98, 42, 0.1) 0%, transparent 60%);
  pointer-events: none;
}

.dark-callout-content-wrapper {
  max-inline-size: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  text-align: center;
}

.dark-callout-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-tertiary);
  margin-block-end: var(--space-5);
}

.dark-callout-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  color: var(--color-text-inverse);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-6);
}

.dark-callout-text {
  font-size: var(--font-size-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-inverse-muted);
  margin-block-end: var(--space-10);
}

.dark-callout-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  flex-wrap: wrap;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-page-layout-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: var(--space-16);
  align-items: start;
}

.contact-form-section-wrapper {
  background: var(--color-surface-card);
  border-radius: var(--radius-2xl);
  padding: var(--space-10);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border-light);
}

.contact-form-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-extrabold);
  margin-block-end: var(--space-3);
}

.contact-form-subtitle {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  margin-block-end: var(--space-8);
  line-height: var(--line-height-relaxed);
}

.contact-form-fields-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact-form-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-form-row-double {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

.contact-form-field-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

.contact-form-required-indicator {
  color: var(--color-accent-primary);
  margin-inline-start: var(--space-1);
}

.contact-form-text-input,
.contact-form-email-input,
.contact-form-phone-input,
.contact-form-textarea-input {
  padding: var(--space-4);
  border: 1.5px solid var(--color-border-light);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background: var(--color-background-primary);
  transition: all var(--transition-fast);
  outline: none;
  inline-size: 100%;
}

.contact-form-text-input:focus,
.contact-form-email-input:focus,
.contact-form-phone-input:focus,
.contact-form-textarea-input:focus {
  border-color: var(--color-accent-primary);
  background: white;
  box-shadow: 0 0 0 3px rgba(200, 98, 42, 0.1);
}

.contact-form-text-input:hover,
.contact-form-email-input:hover,
.contact-form-phone-input:hover,
.contact-form-textarea-input:hover {
  border-color: var(--color-border-medium);
}

.contact-form-textarea-input {
  min-block-size: 140px;
  resize: vertical;
  line-height: var(--line-height-relaxed);
}

.contact-form-privacy-checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-background-secondary);
  border-radius: var(--radius-md);
}

.contact-form-privacy-checkbox {
  inline-size: 18px;
  block-size: 18px;
  border: 1.5px solid var(--color-border-medium);
  border-radius: var(--radius-xs);
  cursor: pointer;
  flex-shrink: 0;
  margin-block-start: 2px;
  accent-color: var(--color-accent-primary);
}

.contact-form-privacy-label-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
  cursor: pointer;
}

.contact-form-privacy-label-text a {
  color: var(--color-accent-primary);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

.contact-form-privacy-label-text a:hover { color: var(--color-accent-secondary); }

.contact-form-submit-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  inline-size: 100%;
  padding: var(--space-5);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: white;
  background: linear-gradient(135deg, var(--color-gradient-start), var(--color-gradient-end));
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-accent);
  cursor: pointer;
  border: none;
}

.contact-form-submit-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-accent-lg);
  filter: brightness(1.05);
}

.contact-form-submit-button:active { transform: translateY(0); }

.contact-sidebar-info-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.contact-sidebar-card {
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  border: 1px solid var(--color-border-light);
  box-shadow: var(--shadow-sm);
}

.contact-sidebar-card-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  margin-block-end: var(--space-4);
}

.contact-sidebar-detail-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding-block: var(--space-3);
  border-block-end: 1px solid var(--color-border-light);
}

.contact-sidebar-detail-item:last-child { border-block-end: none; }

.contact-sidebar-detail-icon {
  color: var(--color-accent-primary);
  font-size: var(--font-size-base);
  margin-block-start: 2px;
  flex-shrink: 0;
  inline-size: 20px;
}

.contact-sidebar-detail-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

.contact-sidebar-detail-text strong {
  display: block;
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
  margin-block-end: var(--space-1);
}

.contact-sidebar-detail-text a {
  color: var(--color-accent-primary);
  transition: color var(--transition-fast);
}

.contact-sidebar-detail-text a:hover { color: var(--color-accent-secondary); }

.contact-map-container {
  border-radius: var(--radius-xl);
  overflow: hidden;
  block-size: 260px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border-light);
}

.contact-map-container iframe {
  inline-size: 100%;
  block-size: 100%;
  border: none;
  display: block;
}

/* ============================================================
   THANKS PAGE
   ============================================================ */

.thanks-page-full-section {
  min-block-size: calc(100vh - var(--nav-height) - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: var(--space-32);
  padding-block-start: calc(var(--nav-height) + var(--space-32));
}

.thanks-page-content-center {
  text-align: center;
  max-inline-size: 560px;
  padding-inline: var(--space-8);
}

.thanks-page-icon-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 72px;
  block-size: 72px;
  border-radius: 50%;
  background: rgba(200, 98, 42, 0.1);
  color: var(--color-accent-primary);
  font-size: var(--font-size-2xl);
  margin-block-end: var(--space-8);
  border: 1px solid rgba(200, 98, 42, 0.2);
}

.thanks-page-heading {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-extrabold);
  letter-spacing: var(--letter-spacing-tight);
  line-height: var(--line-height-tight);
  margin-block-end: var(--space-6);
}

.thanks-page-support-text {
  font-size: var(--font-size-md);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
  margin-block-end: var(--space-12);
}

/* ============================================================
   LEGAL PAGES
   ============================================================ */

.legal-page-hero-section {
  padding-block-start: calc(var(--nav-height) + var(--space-16));
  padding-block-end: var(--space-12);
  background: var(--color-background-primary);
  border-block-end: 1px solid var(--color-border-light);
}

.legal-page-hero-content {
  max-inline-size: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.legal-page-hero-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-3);
}

.legal-page-hero-heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  letter-spacing: var(--letter-spacing-tight);
  margin-block-end: var(--space-4);
}

.legal-page-hero-date {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.legal-page-content-section {
  padding-block: var(--space-16);
}

.legal-content-container {
  max-inline-size: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
}

.legal-section-block {
  margin-block-end: var(--space-10);
  padding-block-end: var(--space-10);
  border-block-end: 1px solid var(--color-border-light);
}

.legal-section-block:last-child {
  border-block-end: none;
}

.legal-section-number {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--color-accent-primary);
  margin-block-end: var(--space-2);
}

.legal-section-heading {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-5);
  line-height: var(--line-height-snug);
}

.legal-section-body {
  font-size: var(--font-size-base);
  line-height: var(--line-height-loose);
  color: var(--color-text-secondary);
}

.legal-section-body p { margin-block-end: var(--space-4); }
.legal-section-body p:last-child { margin-block-end: 0; }

.legal-section-body ul {
  list-style: disc;
  padding-inline-start: var(--space-6);
  margin-block: var(--space-4);
}

.legal-section-body li {
  margin-block-end: var(--space-2);
  line-height: var(--line-height-relaxed);
}

.legal-section-body a {
  color: var(--color-accent-primary);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

.legal-section-body a:hover { color: var(--color-accent-secondary); }

/* ============================================================
   ABOUT PAGE SPECIFIC
   ============================================================ */

.team-values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

.team-value-card {
  padding: var(--space-8);
  background: var(--color-surface-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
}

.team-value-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

.team-value-icon {
  font-size: var(--font-size-2xl);
  color: var(--color-accent-primary);
  margin-block-end: var(--space-4);
}

.team-value-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-block-end: var(--space-3);
}

.team-value-description {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

.about-image-offset-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: start;
}

.about-image-primary {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  aspect-ratio: 3/4;
}

.about-image-primary img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.about-image-secondary {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  margin-block-start: var(--space-12);
  aspect-ratio: 4/5;
}

.about-image-secondary img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

/* ============================================================
   ENTREPRENEURS PAGE SPECIFIC
   ============================================================ */

.entrepreneurs-highlight-strip {
  padding: var(--space-8);
  background: linear-gradient(135deg, rgba(200, 98, 42, 0.06), rgba(42, 107, 138, 0.06));
  border-radius: var(--radius-xl);
  border: 1px solid rgba(200, 98, 42, 0.15);
  margin-block: var(--space-8);
}

.entrepreneurs-highlight-heading {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-block-end: var(--space-3);
}

.entrepreneurs-highlight-text {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

.entrepreneurs-module-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  margin-block-start: var(--space-8);
}

.entrepreneurs-module-card {
  padding: var(--space-6);
  background: var(--color-surface-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  transition: all var(--transition-base);
}

.entrepreneurs-module-card:hover {
  border-color: rgba(200, 98, 42, 0.3);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.entrepreneurs-module-card-icon {
  font-size: var(--font-size-xl);
  color: var(--color-accent-cool);
  margin-block-end: var(--space-3);
}

.entrepreneurs-module-card-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  margin-block-end: var(--space-2);
}

.entrepreneurs-module-card-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
}

/* ============================================================
   FOOTER
   ============================================================ */

.main-site-footer {
  background: var(--color-background-deeper);
  border-block-start: 1px solid rgba(247, 245, 240, 0.06);
}

.main-footer-primary-row {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  padding-block: var(--space-8);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-8);
}

.main-footer-logo-block {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  transition: opacity var(--transition-fast);
}

.main-footer-logo-block:hover { opacity: 0.8; }

.main-footer-logo-image {
  block-size: 32px;
  inline-size: auto;
  filter: brightness(0) invert(1);
  opacity: 0.7;
}

.main-footer-logo-text {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-inverse);
  opacity: 0.7;
}

.main-footer-navigation-links {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
}

.main-footer-nav-link {
  font-size: var(--font-size-sm);
  color: var(--color-text-inverse-muted);
  transition: color var(--transition-fast);
  white-space: nowrap;
}

.main-footer-nav-link:hover { color: var(--color-text-inverse); }

.main-footer-contact-block {
  text-align: end;
}

.main-footer-contact-item {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-inverse-muted);
  margin-block-end: var(--space-2);
}

.main-footer-contact-item:last-child { margin-block-end: 0; }

.main-footer-contact-item a {
  color: var(--color-text-inverse-muted);
  transition: color var(--transition-fast);
}

.main-footer-contact-item a:hover { color: var(--color-accent-tertiary); }

.main-footer-contact-icon {
  color: var(--color-accent-tertiary);
  font-size: var(--font-size-xs);
}

.main-footer-legal-bar {
  border-block-start: 1px solid rgba(247, 245, 240, 0.06);
  padding-block: var(--space-4);
}

.main-footer-legal-bar-inner {
  max-inline-size: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.main-footer-copyright-text {
  font-size: var(--font-size-xs);
  color: var(--color-text-inverse-muted);
  opacity: 0.6;
}

.main-footer-legal-links-group {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.main-footer-legal-link {
  font-size: var(--font-size-xs);
  color: var(--color-text-inverse-muted);
  opacity: 0.6;
  transition: opacity var(--transition-fast), color var(--transition-fast);
}

.main-footer-legal-link:hover {
  opacity: 1;
  color: var(--color-accent-tertiary);
}

/* ============================================================
   COOKIE CONSENT
   ============================================================ */

.cookie-consent-trigger-link {
  position: fixed;
  inset-block-end: var(--space-6);
  inset-inline-start: var(--space-6);
  z-index: 900;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  background: rgba(247, 245, 240, 0.92);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-4);
  backdrop-filter: blur(8px);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  cursor: pointer;
  text-decoration: none;
}

.cookie-consent-trigger-link:hover {
  color: var(--color-text-primary);
  border-color: var(--color-accent-primary);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}

.cookie-consent-trigger-link.pulse-animation {
  animation: cookie-pulse 2s ease-in-out 3;
}

@keyframes cookie-pulse {
  0%, 100% { transform: scale(1); box-shadow: var(--shadow-md); }
  50% { transform: scale(1.05); box-shadow: var(--shadow-accent); }
}

.cookie-consent-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(17, 21, 32, 0.7);
  backdrop-filter: blur(6px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
}

.cookie-consent-modal-overlay.cookie-modal-open {
  opacity: 1;
  pointer-events: all;
}

.cookie-consent-modal-panel {
  background: var(--color-surface-card);
  border-radius: var(--radius-2xl);
  max-inline-size: 520px;
  inline-size: 100%;
  box-shadow: var(--shadow-2xl);
  transform: translateY(20px) scale(0.98);
  transition: transform var(--transition-base);
  overflow: hidden;
}

.cookie-consent-modal-overlay.cookie-modal-open .cookie-consent-modal-panel {
  transform: translateY(0) scale(1);
  max-height: 90%;
  overflow-y: auto;
}

.cookie-modal-header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-6) var(--space-8);
  border-block-end: 1px solid var(--color-border-light);
  background: var(--color-surface-tinted);
}

.cookie-modal-header-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.cookie-modal-close-btn {
  inline-size: 32px;
  block-size: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.cookie-modal-close-btn:hover {
  background: var(--color-border-light);
  color: var(--color-text-primary);
}

.cookie-modal-body {
  padding: var(--space-8);
}

.cookie-modal-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
  margin-block-end: var(--space-6);
}

.cookie-category-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-block-end: var(--space-8);
}

.cookie-category-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--color-background-secondary);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-light);
}

.cookie-category-info {}

.cookie-category-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-block-end: var(--space-1);
}

.cookie-category-description {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  line-height: var(--line-height-relaxed);
}

.cookie-toggle-switch {
  position: relative;
  inline-size: 44px;
  block-size: 24px;
  flex-shrink: 0;
}

.cookie-toggle-switch input {
  opacity: 0;
  inline-size: 0;
  block-size: 0;
  position: absolute;
}

.cookie-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--color-border-medium);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.cookie-toggle-slider::before {
  content: '';
  position: absolute;
  inline-size: 18px;
  block-size: 18px;
  inset-inline-start: 3px;
  inset-block-start: 3px;
  background: white;
  border-radius: 50%;
  transition: transform var(--transition-fast);
  box-shadow: var(--shadow-xs);
}

.cookie-toggle-switch input:checked + .cookie-toggle-slider {
  background: var(--color-accent-primary);
}

.cookie-toggle-switch input:checked + .cookie-toggle-slider::before {
  transform: translateX(20px);
}

.cookie-toggle-switch input:disabled + .cookie-toggle-slider {
  opacity: 0.6;
  cursor: not-allowed;
}

.cookie-modal-actions-row {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.cookie-action-accept-all {
  flex: 1;
  padding: var(--space-3) var(--space-5);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: white;
  background: linear-gradient(135deg, var(--color-gradient-start), var(--color-gradient-end));
  border-radius: var(--radius-md);
  cursor: pointer;
  border: none;
  transition: all var(--transition-base);
  box-shadow: var(--shadow-accent);
}

.cookie-action-accept-all:hover {
  filter: brightness(1.05);
  box-shadow: var(--shadow-accent-lg);
  transform: translateY(-1px);
}

.cookie-action-save-preferences {
  flex: 1;
  padding: var(--space-3) var(--space-5);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  background: transparent;
  border: 1.5px solid var(--color-border-medium);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
}

.cookie-action-save-preferences:hover {
  border-color: var(--color-accent-primary);
  color: var(--color-accent-primary);
}

.cookie-action-reject-all {
  inline-size: 100%;
  padding: var(--space-2) var(--space-5);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color var(--transition-fast);
  text-decoration: underline;
}

.cookie-action-reject-all:hover { color: var(--color-text-secondary); }

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */

.animate-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

.animate-on-scroll.animation-visible {
  opacity: 1;
  transform: translateY(0);
}

.animate-delay-1 { transition-delay: 100ms; }
.animate-delay-2 { transition-delay: 200ms; }
.animate-delay-3 { transition-delay: 300ms; }
.animate-delay-4 { transition-delay: 400ms; }

/* ============================================================
   INTL TEL INPUT OVERRIDE
   ============================================================ */

.iti, #phone { inline-size: 100%; }

.iti__flag-container { z-index: 100; }

/* ============================================================
   RESPONSIVE - TABLET
   ============================================================ */

@media (max-width: 1024px) {
  .homepage-hero-content-grid {
    grid-template-columns: 1fr;
    gap: var(--space-12);
    padding-block: var(--space-16);
  }

  .homepage-hero-visual-column { justify-content: center; }

  .homepage-hero-atropos-wrapper { max-inline-size: 380px; }

  .homepage-mission-content-wrapper { grid-template-columns: 1fr; gap: var(--space-8); }
  .homepage-mission-text-column { border-inline-start: none; padding-inline-start: 0; border-block-start: 1px solid rgba(247, 245, 240, 0.1); padding-block-start: var(--space-8); }

  .homepage-services-header-row { grid-template-columns: 1fr; gap: var(--space-6); }
  .homepage-services-cards-grid { grid-template-columns: repeat(2, 1fr); }

  .homepage-approach-layout-split { grid-template-columns: 1fr; gap: var(--space-12); }

  .homepage-principles-grid { grid-template-columns: repeat(2, 1fr); }

  .homepage-blog-cards-grid { grid-template-columns: 1fr 1fr; }
  .blog-article-card--featured { grid-column: span 2; }

  .homepage-location-content-wrapper { grid-template-columns: 1fr; gap: var(--space-10); }

  .inner-page-hero-content { grid-template-columns: 1fr; gap: var(--space-8); }
  .inner-page-hero-aside { display: grid; grid-template-columns: repeat(2, 1fr); }

  .two-column-content-layout,
  .two-column-content-layout--reversed {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .contact-page-layout-grid { grid-template-columns: 1fr; }

  .main-footer-primary-row { grid-template-columns: 1fr 1fr; }
  .main-footer-contact-block { text-align: start; }
  .main-footer-contact-item { justify-content: flex-start; }
  .main-footer-navigation-links { grid-column: span 2; justify-content: flex-start; }

  .workshop-cards-grid { grid-template-columns: 1fr; }

  .entrepreneurs-module-grid { grid-template-columns: 1fr; }

  .team-values-grid { grid-template-columns: 1fr; }

  .about-image-offset-layout { grid-template-columns: 1fr; }
  .about-image-secondary { margin-block-start: 0; }
}

/* ============================================================
   RESPONSIVE - MOBILE
   ============================================================ */

@media (max-width: 768px) {
  :root { --nav-height: 64px; }

  .main-navigation-links-list { display: none; }
  .main-navigation-actions-group .navigation-button-ghost,
  .main-navigation-actions-group .navigation-button-primary { display: none; }
  .main-navigation-actions-group .language-switcher-container { display: none; }
  .mobile-menu-toggle-button { display: flex; }

  .homepage-hero-content-grid {
    padding-block: var(--space-12);
    gap: var(--space-10);
  }

  .homepage-hero-heading { letter-spacing: -0.04em; }

  .homepage-hero-atropos-wrapper { max-inline-size: 100%; }

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

  .homepage-principles-grid { grid-template-columns: 1fr 1fr; }

  .homepage-blog-cards-grid { grid-template-columns: 1fr; }
  .blog-article-card--featured { grid-column: span 1; }

  .homepage-blog-header-row { flex-direction: column; align-items: flex-start; }

  .homepage-editorial-break-section { block-size: 50vh; }
  .homepage-editorial-caption-block { inset-inline-start: var(--space-8); inset-block-end: var(--space-8); }

  .main-footer-primary-row {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding-block: var(--space-6);
  }

  .main-footer-contact-block { text-align: start; }
  .main-footer-contact-item { justify-content: flex-start; }

  .main-footer-legal-bar-inner { flex-direction: column; align-items: flex-start; gap: var(--space-3); }

  .inner-page-hero-section { padding-block-start: calc(var(--nav-height) + var(--space-12)); }
  .inner-page-hero-aside { grid-template-columns: 1fr; }

  .contact-form-row-double { grid-template-columns: 1fr; }

  .homepage-editorial-caption-heading { font-size: var(--font-size-xl); }

  .dark-callout-heading { font-size: var(--font-size-2xl); }
  .dark-callout-actions { flex-direction: column; align-items: stretch; text-align: center; }

  .homepage-hero-cta-group { flex-direction: column; align-items: flex-start; }

  .page-content-section { padding-block: var(--space-16); }

  .homepage-mission-strip-section { padding-block: var(--space-12); }
  .homepage-services-section { padding-block: var(--space-16); }
  .homepage-approach-section { padding-block: var(--space-16); }
  .homepage-principles-section { padding-block: var(--space-16); }
  .homepage-blog-section { padding-block: var(--space-16); }
  .homepage-location-section { padding-block: var(--space-16); }

  .workshop-cards-grid { grid-template-columns: 1fr; }
  .entrepreneurs-module-grid { grid-template-columns: 1fr; }

  .site-container,
  .content-container,
  .narrow-container,
  .page-section-container,
  .homepage-services-layout-grid,
  .homepage-approach-content-wrapper,
  .homepage-principles-content-container,
  .homepage-blog-layout-container,
  .homepage-location-content-wrapper,
  .homepage-mission-content-wrapper,
  .homepage-hero-content-grid,
  .inner-page-hero-content,
  .legal-content-container,
  .main-footer-primary-row,
  .main-footer-legal-bar-inner,
  .dark-callout-content-wrapper {
    padding-inline: var(--space-5);
  }

  .contact-form-section-wrapper { padding: var(--space-6); }

  .blog-modal-body-content { padding: var(--space-6); }

  .cookie-consent-trigger-link { inset-block-end: var(--space-4); inset-inline-start: var(--space-4); }
}

@media (max-width: 480px) {
  .homepage-principles-grid { grid-template-columns: 1fr; }
  .mobile-menu-actions-row { flex-direction: column; }
  .mobile-menu-actions-row .button-primary-large,
  .mobile-menu-actions-row .button-secondary-outline {
    inline-size: 100%;
    justify-content: center;
  }
  .homepage-hero-trust-note { flex-wrap: wrap; }
  .cookie-modal-actions-row { flex-direction: column; }
}