:root {
  --primary: #5c7a5c;
  --secondary: #c4a882;
  --accent: #e8d5b7;
  --primary-dark: color-mix(in oklch, var(--primary), black 25%);
  --primary-light: color-mix(in oklch, var(--primary), white 40%);
  --primary-xlight: color-mix(in oklch, var(--primary), white 65%);
  --secondary-dark: color-mix(in oklch, var(--secondary), black 20%);
  --secondary-light: color-mix(in oklch, var(--secondary), white 45%);
  --accent-dark: color-mix(in oklch, var(--accent), black 15%);
  --accent-light: color-mix(in oklch, var(--accent), white 50%);
  --surface: color-mix(in oklch, var(--accent), white 60%);
  --surface-alt: color-mix(in oklch, var(--primary), white 72%);
  --text-dark: #2a2a28;
  --text-mid: #4a4a47;
  --text-light: color-mix(in oklch, var(--primary-dark), white 30%);
  --text-muted: color-mix(in oklch, var(--text-mid), white 30%);
  --bg-base: #f9f7f4;
  --white-tinted: #fefefc;
  --nav-height: 72px;
  --radius-xs: 6px;
  --radius-sm: 12px;
  --radius-md: 24px;
  --radius-lg: 40px;
  --radius-xl: 60px;
  --radius-pill: 100px;
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 2rem;
  --space-lg: 4rem;
  --space-xl: 6rem;
  --space-2xl: 9rem;
  --shadow-sm: 0 2px 8px color-mix(in oklch, var(--primary), transparent 85%), 0 1px 3px color-mix(in oklch, var(--secondary), transparent 80%);
  --shadow-md: 0 8px 24px color-mix(in oklch, var(--primary), transparent 80%), 0 2px 8px color-mix(in oklch, var(--secondary), transparent 75%);
  --shadow-lg: 0 20px 48px color-mix(in oklch, var(--primary), transparent 75%), 0 8px 16px color-mix(in oklch, var(--secondary), transparent 70%);
  --shadow-xl: 0 32px 72px color-mix(in oklch, var(--primary), transparent 70%), 0 12px 24px color-mix(in oklch, var(--secondary), transparent 65%);
  --shadow-inset: inset 0 2px 6px color-mix(in oklch, var(--primary), transparent 88%);
  --transition-fast: 0.2s ease-out;
  --transition-mid: 0.35s ease-out;
  --transition-slow: 0.5s ease-out;
  --transition-spring: 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-family: 'Commissioner', sans-serif;
  background: var(--bg-base);
  color: var(--text-dark);
  line-height: 1.65;
  overflow-x: hidden;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

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

a {
  color: var(--primary);
  transition: color var(--transition-fast);
}

a:hover { color: var(--primary-dark); }

p { color: var(--text-mid); margin-bottom: 1.1em; }
p:last-child { margin-bottom: 0; }

h1, h2, h3, h4, h5 {
  color: var(--text-dark);
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.02em;
}

h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); margin-bottom: 1rem; }
h3 { font-size: clamp(1.15rem, 2vw, 1.4rem); margin-bottom: 0.6rem; }

ul { list-style: none; }



.main-navigation-wrapper {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-height);
  background: color-mix(in oklch, var(--white-tinted), transparent 10%);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  transition: background var(--transition-mid), box-shadow var(--transition-mid);
}

.main-navigation-wrapper::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 100%; height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, var(--secondary) 20%, var(--primary) 50%, var(--secondary) 80%, transparent 100%);
  transform-origin: center;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.main-navigation-wrapper.nav-scrolled::after {
  transform: translateX(-50%) scaleX(1);
}

.main-navigation-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 2rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.main-navigation-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none;
}

.main-navigation-logo img {
  height: 38px;
  width: auto;
}

.main-navigation-logo-text {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--primary-dark);
  letter-spacing: -0.02em;
}

.main-navigation-links {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  list-style: none;
}

.main-navigation-links a {
  text-decoration: none;
  color: var(--text-mid);
  font-size: 0.9rem;
  font-weight: 500;
  padding: 0.5rem 0.9rem;
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast), background var(--transition-fast);
}

.main-navigation-links a:hover {
  color: var(--primary-dark);
  background: color-mix(in oklch, var(--primary), transparent 88%);
}

.main-navigation-cta-button {
  background: var(--primary) !important;
  color: var(--white-tinted) !important;
  padding: 0.55rem 1.3rem !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 600 !important;
  transition: background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast) !important;
  box-shadow: var(--shadow-sm);
}

.main-navigation-cta-button:hover {
  background: var(--primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md) !important;
}

.main-navigation-hamburger-button {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: var(--radius-sm);
  color: var(--primary-dark);
  font-size: 1.4rem;
  min-height: 44px;
  min-width: 44px;
  align-items: center;
  justify-content: center;
  transition: color var(--transition-fast), background var(--transition-fast);
}

.main-navigation-hamburger-button:hover {
  color: var(--primary);
  background: color-mix(in oklch, var(--primary), transparent 90%);
}



.fullscreen-mobile-menu-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: linear-gradient(145deg, var(--primary-dark) 0%, var(--primary) 55%, color-mix(in oklch, var(--primary), var(--secondary) 40%) 100%);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.35s ease;
}

.fullscreen-mobile-menu-overlay.menu-open {
  display: flex;
  opacity: 1;
}

.fullscreen-mobile-menu-close-button {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background: color-mix(in oklch, var(--white-tinted), transparent 75%);
  border: none;
  color: var(--white-tinted);
  font-size: 1.4rem;
  cursor: pointer;
  padding: 0.6rem;
  border-radius: var(--radius-sm);
  min-height: 44px;
  min-width: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--transition-fast), background var(--transition-fast);
}

.fullscreen-mobile-menu-close-button:hover {
  transform: rotate(90deg);
  background: color-mix(in oklch, var(--white-tinted), transparent 60%);
}

.fullscreen-mobile-menu-links {
  list-style: none;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.fullscreen-mobile-menu-links a {
  text-decoration: none;
  color: var(--white-tinted);
  font-size: clamp(1.6rem, 5vw, 2.4rem);
  font-weight: 700;
  padding: 0.5rem 1.5rem;
  display: block;
  border-radius: var(--radius-md);
  transition: background var(--transition-fast), transform var(--transition-fast), letter-spacing var(--transition-fast);
  letter-spacing: -0.01em;
  min-height: 44px;
}

.fullscreen-mobile-menu-links a:hover {
  background: color-mix(in oklch, var(--white-tinted), transparent 82%);
  transform: scale(1.03);
  letter-spacing: 0.01em;
}



.homepage-hero-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding-top: var(--nav-height);
  background: linear-gradient(160deg, var(--bg-base) 0%, color-mix(in oklch, var(--accent), white 50%) 40%, color-mix(in oklch, var(--primary-light), white 55%) 100%);
}

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

.homepage-hero-icon-grid-inner {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 3rem;
  padding: 2rem;
  opacity: 0.065;
  transform: rotate(-5deg) scale(1.2);
  position: absolute;
  inset: -10%;
  color: var(--primary);
  font-size: 2rem;
  align-items: center;
  justify-items: center;
}

.homepage-hero-blob-one {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--primary-light), transparent 55%) 0%, transparent 70%);
  border-radius: 63% 37% 54% 46% / 55% 48% 52% 45%;
  top: -100px;
  right: -150px;
  animation: blobFloat1 12s ease-in-out infinite;
  pointer-events: none;
}

.homepage-hero-blob-two {
  position: absolute;
  width: 400px;
  height: 400px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--secondary-light), transparent 60%) 0%, transparent 70%);
  border-radius: 37% 63% 46% 54% / 48% 55% 45% 52%;
  bottom: -80px;
  left: -100px;
  animation: blobFloat2 15s ease-in-out infinite;
  pointer-events: none;
}

@keyframes blobFloat1 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); border-radius: 63% 37% 54% 46% / 55% 48% 52% 45%; }
  33% { transform: translate(30px, -20px) rotate(5deg); border-radius: 50% 50% 40% 60% / 45% 60% 40% 55%; }
  66% { transform: translate(-20px, 30px) rotate(-3deg); border-radius: 70% 30% 60% 40% / 55% 40% 60% 45%; }
}

@keyframes blobFloat2 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); border-radius: 37% 63% 46% 54% / 48% 55% 45% 52%; }
  50% { transform: translate(20px, -30px) rotate(8deg); border-radius: 55% 45% 60% 40% / 50% 60% 40% 50%; }
}

.homepage-hero-content-wrapper {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 780px;
  padding: 3rem 2rem;
}

.homepage-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: color-mix(in oklch, var(--white-tinted), transparent 20%);
  backdrop-filter: blur(10px);
  border: 1px solid color-mix(in oklch, var(--secondary), transparent 60%);
  color: var(--primary-dark);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.45rem 1.1rem;
  border-radius: var(--radius-pill);
  margin-bottom: 1.5rem;
  box-shadow: var(--shadow-sm);
  letter-spacing: 0.02em;
}

.homepage-hero-main-heading {
  font-size: clamp(2.6rem, 6.5vw, 5rem);
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 1.5rem;
  color: var(--text-dark);
  letter-spacing: -0.03em;
}

.homepage-hero-main-heading em {
  font-style: normal;
  color: var(--primary);
  position: relative;
}

.homepage-hero-main-heading em::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  border-radius: 2px;
}

.homepage-hero-subtext {
  font-size: clamp(1rem, 2vw, 1.15rem);
  color: var(--text-mid);
  line-height: 1.75;
  max-width: 620px;
  margin: 0 auto 2rem;
}

.homepage-hero-action-group {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}

.homepage-hero-primary-button {
  background: var(--primary);
  color: var(--white-tinted);
  text-decoration: none;
  padding: 0.9rem 2.2rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 1rem;
  transition: background var(--transition-fast), transform var(--transition-spring), box-shadow var(--transition-fast);
  box-shadow: 0 4px 16px color-mix(in oklch, var(--primary), transparent 60%), 0 1px 4px color-mix(in oklch, var(--primary), transparent 70%);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.homepage-hero-primary-button:hover {
  background: var(--primary-dark);
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 8px 28px color-mix(in oklch, var(--primary), transparent 50%), 0 2px 8px color-mix(in oklch, var(--primary), transparent 60%);
  color: var(--white-tinted);
}

.homepage-hero-secondary-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--primary-dark);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.9rem 1.5rem;
  border-radius: var(--radius-pill);
  border: 1.5px solid color-mix(in oklch, var(--primary), transparent 55%);
  transition: all var(--transition-fast);
  min-height: 44px;
  background: color-mix(in oklch, var(--white-tinted), transparent 30%);
}

.homepage-hero-secondary-button:hover {
  background: color-mix(in oklch, var(--primary), transparent 88%);
  border-color: var(--primary);
  transform: translateY(-2px);
  color: var(--primary-dark);
}

.homepage-hero-trust-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  font-size: 0.83rem;
  color: var(--text-mid);
  font-weight: 500;
}

.homepage-hero-trust-row span {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.homepage-hero-trust-row i {
  color: var(--primary);
  font-size: 0.9rem;
}

.homepage-hero-scroll-indicator {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.homepage-hero-scroll-dot {
  width: 6px;
  height: 6px;
  background: var(--primary);
  border-radius: 50%;
  animation: scrollBounce 2s ease-in-out infinite;
  opacity: 0.6;
}

@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50% { transform: translateY(10px); opacity: 1; }
}



.homepage-intro-section {
  background: var(--white-tinted);
  position: relative;
  padding-bottom: var(--space-xl);
}

.homepage-intro-wave-top {
  margin-top: -2px;
  line-height: 0;
}

.homepage-intro-wave-top svg { width: 100%; display: block; }

.homepage-intro-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-lg) 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.homepage-intro-text-block h2 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  margin-bottom: 1.2rem;
}

.homepage-intro-learn-more-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
  font-size: 0.95rem;
  margin-top: 0.5rem;
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.homepage-intro-learn-more-link:hover {
  gap: 0.7rem;
  color: var(--primary-dark);
}

.homepage-intro-image-frame {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: visible;
}

.homepage-intro-main-image {
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}

.homepage-intro-image-frame:hover .homepage-intro-main-image {
  transform: scale(1.02);
  box-shadow: var(--shadow-xl);
}

.homepage-intro-image-badge {
  position: absolute;
  bottom: -1.5rem;
  left: 2rem;
  background: var(--white-tinted);
  border-radius: var(--radius-md);
  padding: 0.75rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  box-shadow: var(--shadow-md);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--primary-dark);
}

.homepage-intro-image-badge i {
  color: var(--secondary);
  font-size: 1.1rem;
}



.homepage-benefits-section {
  background: var(--bg-base);
  padding: var(--space-xl) 0;
  position: relative;
  overflow: hidden;
}

.homepage-benefits-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
}

.homepage-benefits-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 3.5rem;
}

.homepage-benefits-main-heading { margin-bottom: 1rem; }

.homepage-benefits-intro-text {
  font-size: 1.05rem;
  color: var(--text-mid);
}

.homepage-benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
}

.homepage-benefit-item-card {
  background: var(--white-tinted);
  border-radius: var(--radius-md);
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow-sm);
  border: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
  transition: transform var(--transition-mid), box-shadow var(--transition-mid), border-color var(--transition-mid);
}

.homepage-benefit-item-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: color-mix(in oklch, var(--primary-light), transparent 30%);
}

.homepage-benefit-icon-wrapper {
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, color-mix(in oklch, var(--primary), transparent 75%), color-mix(in oklch, var(--secondary), transparent 75%));
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--primary-dark);
  margin-bottom: 1.2rem;
  transition: background var(--transition-mid), transform var(--transition-spring);
}

.homepage-benefit-item-card:hover .homepage-benefit-icon-wrapper {
  background: linear-gradient(135deg, color-mix(in oklch, var(--primary), transparent 55%), color-mix(in oklch, var(--secondary), transparent 55%));
  transform: scale(1.1) rotate(5deg);
}

.homepage-benefit-item-card h3 {
  font-size: 1.05rem;
  margin-bottom: 0.6rem;
  color: var(--text-dark);
}

.homepage-benefit-item-card p {
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--text-mid);
  margin: 0;
}

.homepage-benefits-blob-decoration {
  position: absolute;
  width: 500px;
  height: 500px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--accent), transparent 50%) 0%, transparent 70%);
  border-radius: 40% 60% 55% 45% / 45% 55% 45% 55%;
  bottom: -200px;
  right: -150px;
  pointer-events: none;
}



.homepage-sticky-storytelling-section {
  background: var(--bg-base);
  padding: var(--space-xl) 0;
  overflow: hidden;
}

.homepage-sticky-storytelling-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}

.homepage-sticky-visual-panel {
  position: sticky;
  top: calc(var(--nav-height) + 2rem);
  align-self: start;
}

.homepage-sticky-visual-inner {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.homepage-sticky-main-image {
  width: 100%;
  height: 520px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  transition: transform var(--transition-slow);
}

.homepage-sticky-visual-inner:hover .homepage-sticky-main-image {
  transform: scale(1.02);
}

.homepage-sticky-visual-overlay-card {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  background: color-mix(in oklch, var(--white-tinted), transparent 15%);
  backdrop-filter: blur(12px);
  border: 1px solid color-mix(in oklch, var(--white-tinted), transparent 40%);
  border-radius: var(--radius-md);
  padding: 0.8rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--primary-dark);
  font-weight: 600;
  font-size: 0.9rem;
  box-shadow: var(--shadow-md);
}

.homepage-sticky-visual-overlay-card i { font-size: 1.1rem; color: var(--secondary-dark); }

.homepage-sticky-scroll-content-panel {
  padding: var(--space-lg) 0;
  display: flex;
  flex-direction: column;
  gap: 3.5rem;
}

.homepage-sticky-text-step {
  position: relative;
  padding-left: 1.5rem;
  border-left: 2px solid color-mix(in oklch, var(--accent), transparent 30%);
  transition: border-color var(--transition-mid);
}

.homepage-sticky-text-step:hover {
  border-left-color: var(--primary);
}

.homepage-sticky-step-number {
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--secondary-dark);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.homepage-sticky-text-step h2,
.homepage-sticky-text-step h3 {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  margin-bottom: 0.8rem;
}

.homepage-sticky-text-step p {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--text-mid);
}



.homepage-services-cards-section {
  background: color-mix(in oklch, var(--primary), white 82%);
  position: relative;
  padding: 1rem 0;
}

.homepage-services-wave-top,
.homepage-services-wave-bottom { line-height: 0; }
.homepage-services-wave-top svg,
.homepage-services-wave-bottom svg { width: 100%; display: block; }

.homepage-services-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-xl) 2rem;
}

.homepage-services-header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 3.5rem;
}

.homepage-services-main-heading { margin-bottom: 0.75rem; }

.homepage-services-intro-text {
  font-size: 1.05rem;
  color: var(--text-mid);
}

.homepage-services-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  align-items: start;
}

.homepage-service-comparison-card {
  background: var(--white-tinted);
  border-radius: var(--radius-lg);
  padding: 2.5rem 2rem;
  box-shadow: var(--shadow-md);
  border: 1.5px solid color-mix(in oklch, var(--accent), transparent 40%);
  transition: transform var(--transition-mid), box-shadow var(--transition-mid);
  position: relative;
  overflow: hidden;
}

.homepage-service-comparison-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.homepage-service-card-featured {
  background: linear-gradient(160deg, var(--white-tinted) 0%, color-mix(in oklch, var(--primary-xlight), white 30%) 100%);
  border-color: color-mix(in oklch, var(--primary), transparent 40%);
  transform: scale(1.03);
}

.homepage-service-card-featured:hover { transform: scale(1.03) translateY(-8px); }

.homepage-service-card-featured-badge {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  background: var(--secondary);
  color: var(--white-tinted);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.3rem 0.8rem;
  border-radius: var(--radius-pill);
  letter-spacing: 0.03em;
}

.homepage-service-card-icon-area {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, color-mix(in oklch, var(--primary), transparent 70%), color-mix(in oklch, var(--secondary), transparent 70%));
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--primary-dark);
  margin-bottom: 1.5rem;
  transition: transform var(--transition-spring);
}

.homepage-service-comparison-card:hover .homepage-service-card-icon-area {
  transform: rotate(-5deg) scale(1.1);
}

.homepage-service-card-title {
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
  color: var(--text-dark);
}

.homepage-service-card-description {
  font-size: 0.9rem;
  line-height: 1.65;
  color: var(--text-mid);
  margin-bottom: 1.5rem;
}

.homepage-service-card-feature-list {
  list-style: none;
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.homepage-service-card-feature-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.87rem;
  color: var(--text-mid);
  line-height: 1.5;
}

.homepage-service-card-feature-list i {
  color: var(--primary);
  font-size: 0.85rem;
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.homepage-service-card-cta-button {
  display: inline-block;
  text-decoration: none;
  color: var(--primary-dark);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.7rem 1.4rem;
  border-radius: var(--radius-pill);
  border: 1.5px solid color-mix(in oklch, var(--primary), transparent 50%);
  transition: all var(--transition-fast);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.homepage-service-card-cta-button:hover {
  background: color-mix(in oklch, var(--primary), transparent 85%);
  border-color: var(--primary);
  color: var(--primary-dark);
  transform: translateX(3px);
}

.homepage-service-cta-primary {
  background: var(--primary);
  color: var(--white-tinted) !important;
  border-color: var(--primary) !important;
  box-shadow: var(--shadow-sm);
}

.homepage-service-cta-primary:hover {
  background: var(--primary-dark) !important;
  color: var(--white-tinted) !important;
  transform: translateX(3px);
  box-shadow: var(--shadow-md) !important;
}



.homepage-key-advantages-section {
  background: var(--white-tinted);
  padding: var(--space-xl) 0;
}

.homepage-key-advantages-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.homepage-key-advantages-photo {
  width: 100%;
  height: 500px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  transition: transform var(--transition-slow);
}

.homepage-key-advantages-image-col:hover .homepage-key-advantages-photo {
  transform: scale(1.02);
}

.homepage-key-advantages-image-col {
  position: relative;
  overflow: visible;
}

.homepage-key-advantages-floating-badge {
  position: absolute;
  bottom: -1.5rem;
  right: -1rem;
  background: var(--white-tinted);
  border-radius: var(--radius-md);
  padding: 1rem 1.4rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  box-shadow: var(--shadow-lg);
}

.homepage-key-advantages-floating-badge i {
  font-size: 1.5rem;
  color: var(--primary);
}

.homepage-key-advantages-floating-badge strong {
  display: block;
  font-size: 0.9rem;
  color: var(--text-dark);
  font-weight: 700;
}

.homepage-key-advantages-floating-badge span {
  font-size: 0.78rem;
  color: var(--text-muted);
}

.homepage-key-advantages-content-col h2 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  margin-bottom: 2rem;
}

.homepage-key-advantage-row {
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  padding: 1.2rem 0;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
  transition: padding-left var(--transition-fast);
}

.homepage-key-advantage-row:last-child { border-bottom: none; }

.homepage-key-advantage-row:hover {
  padding-left: 0.5rem;
}

.homepage-key-advantage-icon-circle {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: color-mix(in oklch, var(--primary-xlight), transparent 20%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--primary-dark);
  flex-shrink: 0;
  transition: background var(--transition-fast), transform var(--transition-spring);
}

.homepage-key-advantage-row:hover .homepage-key-advantage-icon-circle {
  background: color-mix(in oklch, var(--primary), transparent 70%);
  transform: scale(1.1);
}

.homepage-key-advantage-row h3 { font-size: 1rem; margin-bottom: 0.35rem; }
.homepage-key-advantage-row p { font-size: 0.88rem; margin: 0; }



.homepage-gallery-section {
  background: var(--surface);
  position: relative;
  padding: 1rem 0;
}

.homepage-gallery-wave-top,
.homepage-gallery-wave-bottom { line-height: 0; }
.homepage-gallery-wave-top svg,
.homepage-gallery-wave-bottom svg { width: 100%; display: block; }

.homepage-gallery-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-lg) 2rem;
}

.homepage-gallery-heading {
  text-align: center;
  margin-bottom: 0.75rem;
}

.homepage-gallery-subtext {
  text-align: center;
  max-width: 580px;
  margin: 0 auto 2.5rem;
  font-size: 1rem;
}

.homepage-gallery-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 1rem;
}

.homepage-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  cursor: pointer;
}

.homepage-gallery-item img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  transition: transform 0.55s ease-out;
  display: block;
}

.homepage-gallery-item-large img {
  height: 460px;
  grid-row: span 2;
}

.homepage-gallery-item-large {
  grid-row: span 2;
}

.homepage-gallery-item:hover img { transform: scale(1.06); }

.homepage-gallery-item-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, color-mix(in oklch, var(--primary-dark), transparent 30%) 0%, transparent 60%);
  display: flex;
  align-items: flex-end;
  padding: 1.2rem;
  opacity: 0;
  transition: opacity var(--transition-mid);
}

.homepage-gallery-item:hover .homepage-gallery-item-overlay { opacity: 1; }

.homepage-gallery-item-overlay span {
  color: var(--white-tinted);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}



.homepage-process-overview-section {
  background: var(--bg-base);
  padding: var(--space-xl) 0;
  position: relative;
  overflow: hidden;
}

.homepage-process-content-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
}

.homepage-process-header {
  text-align: center;
  max-width: 580px;
  margin: 0 auto 3.5rem;
}

.homepage-process-header p { font-size: 1.05rem; }

.homepage-process-steps-row {
  display: flex;
  align-items: flex-start;
  gap: 0;
}

.homepage-process-step-item {
  flex: 1;
  text-align: center;
  padding: 0 1.5rem;
  position: relative;
}

.homepage-process-step-circle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), color-mix(in oklch, var(--primary), var(--secondary) 35%));
  color: var(--white-tinted);
  font-size: 1.2rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.2rem;
  box-shadow: 0 4px 16px color-mix(in oklch, var(--primary), transparent 55%);
  transition: transform var(--transition-spring), box-shadow var(--transition-fast);
}

.homepage-process-step-item:hover .homepage-process-step-circle {
  transform: scale(1.12);
  box-shadow: 0 8px 24px color-mix(in oklch, var(--primary), transparent 45%);
}

.homepage-process-step-item h3 {
  font-size: 1rem;
  margin-bottom: 0.5rem;
  color: var(--text-dark);
}

.homepage-process-step-item p {
  font-size: 0.87rem;
  color: var(--text-mid);
  margin: 0;
}

.homepage-process-step-connector {
  flex: 0 0 auto;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--primary-light), color-mix(in oklch, var(--secondary-light), transparent 20%));
  margin-top: 28px;
  border-radius: 2px;
}

.homepage-process-blob-accent {
  position: absolute;
  width: 400px;
  height: 400px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--primary-xlight), transparent 40%) 0%, transparent 70%);
  border-radius: 60% 40% 45% 55% / 40% 60% 40% 60%;
  top: -100px;
  left: -100px;
  pointer-events: none;
}



.main-footer-wrapper {
  background: color-mix(in oklch, var(--text-dark), white 8%);
  color: color-mix(in oklch, var(--white-tinted), transparent 20%);
  margin-top: auto;
}

.footer-large-cta-block {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 60%, color-mix(in oklch, var(--primary), var(--secondary) 30%) 100%);
  padding: var(--space-xl) 2rem;
  text-align: center;
}

.footer-cta-blob-bg {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--secondary), transparent 65%) 0%, transparent 70%);
  border-radius: 45% 55% 60% 40% / 50% 45% 55% 50%;
  top: -200px;
  right: -150px;
  pointer-events: none;
  animation: blobFloat1 14s ease-in-out infinite;
}

.footer-cta-content {
  position: relative;
  z-index: 1;
  max-width: 680px;
  margin: 0 auto;
}

.footer-cta-headline {
  font-size: clamp(1.9rem, 4vw, 3rem);
  color: var(--white-tinted);
  margin-bottom: 1rem;
  font-weight: 800;
}

.footer-cta-description {
  color: color-mix(in oklch, var(--white-tinted), transparent 20%);
  font-size: 1.05rem;
  margin-bottom: 2rem;
  line-height: 1.7;
}

.footer-cta-main-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--white-tinted);
  color: var(--primary-dark);
  text-decoration: none;
  padding: 1rem 2.4rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 1rem;
  transition: all var(--transition-fast);
  box-shadow: 0 4px 20px color-mix(in oklch, black, transparent 70%);
  min-height: 44px;
}

.footer-cta-main-button:hover {
  background: var(--accent-light);
  color: var(--primary-dark);
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 8px 32px color-mix(in oklch, black, transparent 60%);
}

.footer-main-content-area {
  padding: var(--space-lg) 2rem var(--space-md);
  max-width: 1200px;
  margin: 0 auto;
}

.footer-columns-wrapper {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid color-mix(in oklch, var(--white-tinted), transparent 80%);
  margin-bottom: var(--space-md);
}

.footer-brand-logo-link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none;
  margin-bottom: 1rem;
}

.footer-logo-image { height: 34px; width: auto; filter: brightness(0) invert(1); opacity: 0.9; }
.footer-brand-name { color: var(--white-tinted); font-size: 1.05rem; font-weight: 700; }

.footer-brand-description {
  font-size: 0.87rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 35%);
  line-height: 1.65;
  margin-bottom: 1.2rem;
}

.footer-contact-address {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.footer-contact-address p {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 30%);
  margin: 0;
}

.footer-contact-address i {
  color: var(--secondary);
  font-size: 0.85rem;
  margin-top: 0.2rem;
  flex-shrink: 0;
}

.footer-contact-address a {
  color: color-mix(in oklch, var(--white-tinted), transparent 25%);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-contact-address a:hover { color: var(--secondary-light); }

.footer-column-heading {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--secondary);
  font-weight: 700;
  margin-bottom: 1.2rem;
}

.footer-nav-links-list,
.footer-legal-links-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.footer-nav-links-list a,
.footer-legal-links-list a {
  color: color-mix(in oklch, var(--white-tinted), transparent 30%);
  text-decoration: none;
  font-size: 0.88rem;
  transition: color var(--transition-fast), padding-left var(--transition-fast);
  padding-left: 0;
  display: inline-block;
}

.footer-nav-links-list a:hover,
.footer-legal-links-list a:hover {
  color: var(--secondary-light);
  padding-left: 0.35rem;
}

.footer-legal-info-block {
  margin-bottom: 1.5rem;
  padding: 1rem 1.5rem;
  background: color-mix(in oklch, var(--white-tinted), transparent 90%);
  border-radius: var(--radius-sm);
}

.footer-legal-info-block p {
  font-size: 0.78rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 45%);
  margin: 0;
  line-height: 1.7;
}

.footer-bottom-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid color-mix(in oklch, var(--white-tinted), transparent 85%);
}

.footer-copyright-text {
  font-size: 0.8rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 50%);
  margin: 0;
}

.footer-compliance-text {
  font-size: 0.8rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 50%);
  margin: 0;
}

.footer-compliance-text a {
  color: var(--secondary);
  text-decoration: none;
}

.footer-compliance-text a:hover { color: var(--secondary-light); }

.footer-accessibility-section {
  background: color-mix(in oklch, var(--primary), black 30%);
  padding: var(--space-md) 2rem;
}

.footer-accessibility-content {
  max-width: 900px;
  margin: 0 auto;
}

.footer-accessibility-content h2 {
  font-size: 1.1rem;
  color: var(--secondary-light);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.footer-accessibility-content p {
  font-size: 0.85rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 35%);
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

.footer-accessibility-content a {
  color: var(--secondary-light);
}



.inner-page-hero-section {
  padding: calc(var(--nav-height) + 4rem) 2rem 4rem;
  background: linear-gradient(160deg, var(--bg-base) 0%, color-mix(in oklch, var(--accent), white 50%) 50%, color-mix(in oklch, var(--primary-xlight), white 40%) 100%);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.inner-page-hero-blob-bg {
  position: absolute;
  width: 500px;
  height: 500px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--primary-light), transparent 55%) 0%, transparent 70%);
  border-radius: 60% 40% 55% 45% / 45% 55% 45% 55%;
  top: -150px;
  right: -100px;
  pointer-events: none;
  animation: blobFloat1 12s ease-in-out infinite;
}

.inner-page-hero-content-wrapper {
  max-width: 780px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.inner-page-hero-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-bottom: 1.5rem;
}

.inner-page-hero-breadcrumb a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}

.inner-page-hero-breadcrumb a:hover { color: var(--primary-dark); }
.inner-page-hero-breadcrumb i { font-size: 0.65rem; }

.inner-page-hero-section h1 {
  margin-bottom: 1rem;
}

.inner-page-hero-section p {
  font-size: clamp(1rem, 2vw, 1.15rem);
  color: var(--text-mid);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.75;
}



.story-intro-section { padding: var(--space-xl) 0; background: var(--white-tinted); }
.story-content-container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }

.story-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.story-intro-text-block h2 { margin-bottom: 1.2rem; }

.story-intro-photo {
  width: 100%;
  height: 460px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
}

.story-values-section {
  background: var(--surface);
  position: relative;
  padding: 1rem 0;
}

.story-values-wave-top,
.story-values-wave-bottom { line-height: 0; }
.story-values-wave-top svg,
.story-values-wave-bottom svg { width: 100%; display: block; }

.story-values-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-xl) 2rem;
  text-align: center;
}

.story-values-content-container > h2 { margin-bottom: 0.75rem; }

.story-values-intro {
  font-size: 1.05rem;
  max-width: 580px;
  margin: 0 auto 3rem;
}

.story-values-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
  text-align: left;
}

.story-value-card {
  background: var(--white-tinted);
  border-radius: var(--radius-lg);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-mid), box-shadow var(--transition-mid);
}

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

.story-value-card > i {
  font-size: 1.6rem;
  color: var(--primary);
  margin-bottom: 1rem;
  display: block;
}

.story-value-card h3 { margin-bottom: 0.6rem; }
.story-value-card p { font-size: 0.9rem; margin: 0; }

.story-team-section {
  padding: var(--space-xl) 0;
  background: var(--white-tinted);
}

.story-team-content-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.story-team-text-col h2 { margin-bottom: 1.2rem; }

.story-team-photo {
  width: 100%;
  height: 440px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
}

.story-mission-section {
  padding: var(--space-xl) 0;
  background: var(--bg-base);
}

.story-mission-content-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 2rem;
}

.story-mission-inner-card {
  background: linear-gradient(135deg, var(--white-tinted), color-mix(in oklch, var(--accent), white 55%));
  border-radius: var(--radius-xl);
  padding: 3.5rem;
  text-align: center;
  box-shadow: var(--shadow-lg);
  border: 1px solid color-mix(in oklch, var(--accent), transparent 30%);
}

.story-mission-inner-card > i {
  font-size: 2.5rem;
  color: var(--primary);
  margin-bottom: 1.2rem;
  display: block;
}

.story-mission-inner-card h2 { margin-bottom: 1rem; }
.story-mission-inner-card p { font-size: 1.05rem; margin-bottom: 2rem; max-width: 580px; margin-left: auto; margin-right: auto; }

.story-mission-cta-button {
  display: inline-flex;
  align-items: center;
  background: var(--primary);
  color: var(--white-tinted);
  text-decoration: none;
  padding: 0.9rem 2rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-sm);
  min-height: 44px;
}

.story-mission-cta-button:hover {
  background: var(--primary-dark);
  color: var(--white-tinted);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}



.services-detail-section { padding: var(--space-xl) 0; background: var(--white-tinted); }
.services-detail-container { max-width: 1100px; margin: 0 auto; padding: 0 2rem; }

.services-detail-item {
  background: var(--bg-base);
  border-radius: var(--radius-xl);
  padding: 3rem;
  margin-bottom: 3rem;
  border: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
  transition: box-shadow var(--transition-mid);
}

.services-detail-item:hover { box-shadow: var(--shadow-lg); }

.services-detail-item-featured {
  background: linear-gradient(160deg, var(--white-tinted), color-mix(in oklch, var(--primary-xlight), white 35%));
  border-color: color-mix(in oklch, var(--primary), transparent 55%);
  position: relative;
}

.services-detail-featured-label {
  position: absolute;
  top: -1rem;
  left: 3rem;
  background: var(--primary);
  color: var(--white-tinted);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.3rem 1rem;
  border-radius: var(--radius-pill);
  letter-spacing: 0.04em;
}

.services-detail-item-header {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.services-detail-item-icon {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, color-mix(in oklch, var(--primary), transparent 70%), color-mix(in oklch, var(--secondary), transparent 70%));
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  color: var(--primary-dark);
  flex-shrink: 0;
  transition: transform var(--transition-spring);
}

.services-detail-item:hover .services-detail-item-icon { transform: rotate(-5deg) scale(1.08); }

.services-detail-icon-featured {
  background: linear-gradient(135deg, color-mix(in oklch, var(--primary), transparent 50%), color-mix(in oklch, var(--secondary), transparent 50%));
}

.services-detail-item-header h2 { margin-bottom: 0.3rem; }

.services-detail-item-subtitle {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0;
}

.services-detail-item-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}

.services-detail-item-description p { font-size: 0.95rem; line-height: 1.75; }

.services-detail-item-features h3 {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-bottom: 1rem;
  font-weight: 700;
}

.services-detail-feature-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.services-detail-feature-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.9rem;
  color: var(--text-mid);
  line-height: 1.5;
}

.services-detail-feature-list i {
  color: var(--primary);
  font-size: 0.9rem;
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.services-detail-item-image-row {
  margin-top: 2rem;
}

.services-detail-item-image-row img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.services-detail-divider {
  margin: 1rem 0;
  opacity: 0.5;
}
.services-detail-divider svg { width: 100%; display: block; }

.services-faq-section {
  background: var(--surface);
  position: relative;
  padding: 1rem 0;
}

.services-faq-wave-top,
.services-faq-wave-bottom { line-height: 0; }
.services-faq-wave-top svg,
.services-faq-wave-bottom svg { width: 100%; display: block; }

.services-faq-content-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-xl) 2rem;
}

.services-faq-content-container > h2 {
  text-align: center;
  margin-bottom: 2.5rem;
}

.services-faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.services-faq-item {
  background: var(--white-tinted);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-mid), box-shadow var(--transition-mid);
}

.services-faq-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.services-faq-item h3 {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.98rem;
  margin-bottom: 0.75rem;
  color: var(--text-dark);
}

.services-faq-item h3 i { color: var(--primary); flex-shrink: 0; margin-top: 0.1rem; }
.services-faq-item p { font-size: 0.9rem; margin: 0; line-height: 1.65; }



.guide-intro-section {
  background: var(--white-tinted);
  padding: var(--space-xl) 0;
}

.guide-content-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 4rem;
  align-items: start;
}

.guide-toc-card {
  background: var(--bg-base);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  position: sticky;
  top: calc(var(--nav-height) + 2rem);
  box-shadow: var(--shadow-sm);
  border: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.guide-toc-card h2 {
  font-size: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.2rem;
  color: var(--text-dark);
}

.guide-toc-card h2 i { color: var(--primary); }

.guide-toc-list {
  padding-left: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.guide-toc-list li { font-size: 0.88rem; }
.guide-toc-list a {
  text-decoration: none;
  color: var(--text-mid);
  transition: color var(--transition-fast), padding-left var(--transition-fast);
  padding-left: 0;
  display: inline-block;
}

.guide-toc-list a:hover {
  color: var(--primary-dark);
  padding-left: 0.3rem;
}

.guide-main-content-block h2 {
  font-size: 1.6rem;
  margin-top: 3rem;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid color-mix(in oklch, var(--accent), transparent 30%);
  scroll-margin-top: calc(var(--nav-height) + 1rem);
}

.guide-main-content-block h2:first-child { margin-top: 0; }

.guide-main-content-block p { font-size: 0.97rem; line-height: 1.8; }

.guide-highlight-block {
  background: color-mix(in oklch, var(--primary-xlight), transparent 20%);
  border-left: 4px solid var(--primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 1.2rem 1.5rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin: 2rem 0;
}

.guide-highlight-block i {
  color: var(--primary);
  font-size: 1.2rem;
  margin-top: 0.1rem;
  flex-shrink: 0;
}

.guide-highlight-block p { margin: 0; font-size: 0.95rem; font-weight: 500; }

.guide-rooms-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 1.5rem 0;
}

.guide-room-card {
  background: var(--bg-base);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  border: 1px solid color-mix(in oklch, var(--accent), transparent 35%);
  transition: transform var(--transition-mid), box-shadow var(--transition-mid);
}

.guide-room-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.guide-room-card > i {
  font-size: 1.4rem;
  color: var(--primary);
  margin-bottom: 0.75rem;
  display: block;
}

.guide-room-card h3 { font-size: 1rem; margin-bottom: 0.4rem; }
.guide-room-card p { font-size: 0.87rem; margin: 0; }

.guide-cta-section {
  position: relative;
  background: var(--primary-light);
  padding: 1rem 0;
}

.guide-cta-wave-top,
.guide-cta-wave-bottom { line-height: 0; }
.guide-cta-wave-top svg,
.guide-cta-wave-bottom svg { width: 100%; display: block; }

.guide-cta-content-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 2rem var(--space-lg);
  position: relative;
}

.guide-cta-background-image {
  width: 100%;
  height: 400px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
}

.guide-cta-overlay-content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(to bottom, color-mix(in oklch, var(--primary-dark), transparent 25%) 0%, color-mix(in oklch, var(--primary-dark), transparent 15%) 100%);
}

.guide-cta-overlay-content h2 {
  color: var(--white-tinted);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  margin-bottom: 0.75rem;
  text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.guide-cta-overlay-content p {
  color: color-mix(in oklch, var(--white-tinted), transparent 15%);
  max-width: 500px;
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
}

.guide-cta-button-group {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}

.guide-cta-primary-button {
  background: var(--white-tinted);
  color: var(--primary-dark);
  text-decoration: none;
  padding: 0.8rem 1.8rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.92rem;
  transition: all var(--transition-fast);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.guide-cta-primary-button:hover {
  background: var(--accent-light);
  color: var(--primary-dark);
  transform: translateY(-2px);
}

.guide-cta-secondary-button {
  background: transparent;
  color: var(--white-tinted);
  text-decoration: none;
  padding: 0.8rem 1.8rem;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 0.92rem;
  border: 1.5px solid color-mix(in oklch, var(--white-tinted), transparent 50%);
  transition: all var(--transition-fast);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.guide-cta-secondary-button:hover {
  background: color-mix(in oklch, var(--white-tinted), transparent 80%);
  color: var(--white-tinted);
  border-color: var(--white-tinted);
}



.contact-main-section { padding: var(--space-xl) 0; background: var(--white-tinted); }
.contact-main-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 4rem;
  align-items: start;
}

.contact-info-column h2 { font-size: 1.5rem; margin-bottom: 2rem; }

.contact-info-item-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.contact-info-item-row:last-of-type { border-bottom: none; }

.contact-info-item-icon {
  width: 44px;
  height: 44px;
  background: color-mix(in oklch, var(--primary-xlight), transparent 20%);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  font-size: 1rem;
  flex-shrink: 0;
}

.contact-info-item-row strong {
  display: block;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 0.2rem;
  font-weight: 600;
}

.contact-info-item-row p {
  font-size: 0.92rem;
  margin: 0;
  line-height: 1.5;
}

.contact-info-item-row a {
  text-decoration: none;
  color: var(--primary-dark);
  font-weight: 500;
}

.contact-info-item-row a:hover { color: var(--primary); }

.contact-map-wrapper { margin-top: 1.5rem; }

.contact-form-wizard-wrapper {
  background: var(--bg-base);
  border-radius: var(--radius-xl);
  padding: 3rem 2.5rem;
  box-shadow: var(--shadow-lg);
  border: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.contact-form-step-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 2.5rem;
  gap: 0;
}

.contact-form-step-dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: color-mix(in oklch, var(--accent), transparent 30%);
  border: 2px solid color-mix(in oklch, var(--accent), transparent 20%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-muted);
  transition: all var(--transition-mid);
  position: relative;
  z-index: 1;
  cursor: default;
  flex-shrink: 0;
}

.contact-form-step-dot::before {
  content: attr(data-step);
}

.contact-form-step-dot.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--white-tinted);
  box-shadow: 0 2px 12px color-mix(in oklch, var(--primary), transparent 55%);
}

.contact-form-step-dot.completed {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--white-tinted);
}

.contact-form-step-line {
  flex: 1;
  height: 2px;
  background: color-mix(in oklch, var(--accent), transparent 30%);
  transition: background var(--transition-mid);
  max-width: 60px;
}

.contact-form-step-line.completed { background: var(--primary); }

.contact-form-step-panel {
  display: none;
  animation: stepSlideIn 0.3s ease-out;
}

.contact-form-step-panel.active { display: block; }

@keyframes stepSlideIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

.contact-wizard-form h3 {
  font-size: 1.3rem;
  margin-bottom: 0.3rem;
}

.contact-form-step-subtitle {
  font-size: 0.88rem;
  color: var(--text-muted);
  margin-bottom: 1.8rem;
}

.contact-form-field-group {
  margin-bottom: 1.4rem;
}

.contact-form-field-label {
  display: block;
  font-size: 0.83rem;
  font-weight: 600;
  color: var(--text-dark);
  margin-bottom: 0.4rem;
  letter-spacing: 0.02em;
}

.contact-form-field-label span { color: var(--secondary-dark); }

.contact-form-input-field,
.contact-form-select-field,
.contact-form-textarea-field {
  width: 100%;
  padding: 0.85rem 1.1rem;
  border: 1.5px solid color-mix(in oklch, var(--accent), transparent 20%);
  border-radius: var(--radius-md);
  font-family: 'Commissioner', sans-serif;
  font-size: 0.95rem;
  color: var(--text-dark);
  background: var(--white-tinted);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  min-height: 44px;
  outline: none;
}

.contact-form-input-field:focus,
.contact-form-select-field:focus,
.contact-form-textarea-field:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--primary), transparent 80%);
}

.contact-form-textarea-field { resize: vertical; min-height: 130px; }

.contact-form-privacy-checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.contact-form-checkbox-input {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 0.1rem;
  accent-color: var(--primary);
  cursor: pointer;
}

.contact-form-checkbox-label {
  font-size: 0.83rem;
  color: var(--text-mid);
  line-height: 1.55;
  cursor: pointer;
}

.contact-form-checkbox-label a {
  color: var(--primary);
  font-weight: 600;
}

.contact-form-wizard-navigation-buttons {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-top
: 1.5rem;
}

.contact-form-next-step-button,
.contact-form-submit-button {
  background: var(--primary);
  color: var(--white-tinted);
  border: none;
  padding: 0.85rem 1.8rem;
  border-radius: var(--radius-pill);
  font-family: 'Commissioner', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: background var(--transition-fast), transform var(--transition-spring), box-shadow var(--transition-fast);
  box-shadow: var(--shadow-sm);
  min-height: 44px;
}

.contact-form-next-step-button:hover,
.contact-form-submit-button:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.contact-form-prev-step-button {
  background: transparent;
  color: var(--text-mid);
  border: 1.5px solid color-mix(in oklch, var(--accent), transparent 20%);
  padding: 0.85rem 1.5rem;
  border-radius: var(--radius-pill);
  font-family: 'Commissioner', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: all var(--transition-fast);
  min-height: 44px;
}

.contact-form-prev-step-button:hover {
  background: color-mix(in oklch, var(--accent), transparent 50%);
  border-color: var(--accent-dark);
  color: var(--text-dark);
}



.thanks-page-main-wrapper {
  min-height: calc(100vh - var(--nav-height));
  display: flex;
  align-items: center;
}

.thanks-page-hero-section {
  width: 100%;
  padding: calc(var(--nav-height) + 4rem) 2rem 5rem;
  background: linear-gradient(160deg, var(--bg-base) 0%, color-mix(in oklch, var(--accent), white 50%) 50%, color-mix(in oklch, var(--primary-xlight), white 40%) 100%);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.thanks-page-blob-bg {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(ellipse, color-mix(in oklch, var(--primary-light), transparent 55%) 0%, transparent 70%);
  border-radius: 55% 45% 60% 40% / 45% 60% 40% 55%;
  top: -200px;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
  animation: blobFloat1 14s ease-in-out infinite;
}

.thanks-page-content-wrapper {
  max-width: 600px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}


.thanks-envelope-animation-wrapper {
  display: flex;
  justify-content: center;
  margin-bottom: 2.5rem;
}

.thanks-envelope-body {
  position: relative;
  width: 100px;
  height: 70px;
  background: var(--white-tinted);
  border-radius: var(--radius-xs) var(--radius-xs) var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow-md);
  border: 1.5px solid color-mix(in oklch, var(--secondary), transparent 40%);
  overflow: visible;
  animation: envelopeAppear 0.6s ease-out 0.3s both;
}

@keyframes envelopeAppear {
  from { opacity: 0; transform: scale(0.7) translateY(20px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

.thanks-envelope-flap {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 40px;
  background: color-mix(in oklch, var(--secondary-light), white 30%);
  clip-path: polygon(0 0, 50% 55%, 100% 0);
  transform-origin: top center;
  animation: flapOpen 0.5s ease-out 1s both;
  z-index: 2;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
}

@keyframes flapOpen {
  from { transform: rotateX(0deg); }
  to { transform: rotateX(-160deg); }
}

.thanks-envelope-letter {
  position: absolute;
  width: 80px;
  left: 10px;
  background: var(--accent-light);
  border-radius: var(--radius-xs);
  border: 1px solid color-mix(in oklch, var(--secondary), transparent 50%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  animation: letterSlideUp 0.6s ease-out 1.4s both;
  z-index: 3;
  height: 55px;
  bottom: 5px;
}

@keyframes letterSlideUp {
  from { transform: translateY(0); }
  to { transform: translateY(-45px); }
}

.thanks-envelope-letter-lines {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 100%;
}

.thanks-envelope-letter-lines span {
  display: block;
  height: 3px;
  background: color-mix(in oklch, var(--primary), transparent 40%);
  border-radius: 2px;
}

.thanks-envelope-letter-lines span:first-child { width: 90%; }
.thanks-envelope-letter-lines span:nth-child(2) { width: 70%; }
.thanks-envelope-letter-lines span:last-child { width: 80%; }

.thanks-envelope-bottom-fold {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 35px;
  background: color-mix(in oklch, var(--secondary-light), white 20%);
  clip-path: polygon(0 100%, 50% 45%, 100% 100%);
}

.thanks-page-text-content {
  animation: textFadeIn 0.6s ease-out 2s both;
}

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

.thanks-page-heading {
  font-size: clamp(2rem, 5vw, 3rem);
  margin-bottom: 1rem;
  color: var(--text-dark);
}

.thanks-page-subtext {
  font-size: 1.05rem;
  color: var(--text-mid);
  line-height: 1.75;
  margin-bottom: 0.75rem;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.thanks-page-secondary-text {
  font-size: 0.92rem;
  color: var(--text-muted);
  margin-bottom: 2rem;
}

.thanks-page-action-buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.thanks-page-home-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--primary);
  color: var(--white-tinted);
  text-decoration: none;
  padding: 0.85rem 1.8rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.95rem;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-sm);
  min-height: 44px;
}

.thanks-page-home-button:hover {
  background: var(--primary-dark);
  color: var(--white-tinted);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.thanks-page-guide-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--primary-dark);
  text-decoration: none;
  padding: 0.85rem 1.8rem;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 0.95rem;
  border: 1.5px solid color-mix(in oklch, var(--primary), transparent 50%);
  transition: all var(--transition-fast);
  min-height: 44px;
}

.thanks-page-guide-button:hover {
  background: color-mix(in oklch, var(--primary), transparent 88%);
  border-color: var(--primary);
  color: var(--primary-dark);
  transform: translateY(-2px);
}



.legal-page-main-wrapper {
  background: var(--white-tinted);
  padding: calc(var(--nav-height) + 3rem) 0 var(--space-xl);
}

.legal-page-container {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 2rem;
}

.legal-page-header {
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 2px solid color-mix(in oklch, var(--accent), transparent 30%);
}

.legal-page-header h1 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  margin-bottom: 0.5rem;
}

.legal-page-date {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 1.2rem;
}

.legal-page-intro {
  font-size: 0.97rem;
  line-height: 1.75;
  color: var(--text-mid);
  background: color-mix(in oklch, var(--accent-light), transparent 30%);
  border-radius: var(--radius-md);
  padding: 1.2rem 1.5rem;
  border-left: 4px solid var(--secondary);
}

.legal-page-section-group {
  margin-bottom: 2.5rem;
}

.legal-page-section-group h2 {
  font-size: 1.3rem;
  color: var(--primary-dark);
  margin-bottom: 1rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.legal-page-section-group h3 {
  font-size: 1.05rem;
  color: var(--text-dark);
  margin-top: 1.5rem;
  margin-bottom: 0.6rem;
}

.legal-page-section-group p {
  font-size: 0.93rem;
  line-height: 1.8;
  color: var(--text-mid);
}

.legal-bullet-list {
  list-style: none;
  padding-left: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0.75rem 0;
}

.legal-bullet-list li {
  font-size: 0.92rem;
  color: var(--text-mid);
  padding-left: 1.2rem;
  position: relative;
  line-height: 1.65;
}

.legal-bullet-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 6px;
  height: 6px;
  background: var(--secondary);
  border-radius: 50%;
}

.legal-terms-numbered-section {
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 50%);
}

.legal-terms-numbered-section:last-child { border-bottom: none; }

.legal-terms-numbered-section h2 {
  font-size: 1.2rem;
  color: var(--primary-dark);
  margin-bottom: 0.9rem;
}

.legal-terms-numbered-section p {
  font-size: 0.93rem;
  line-height: 1.8;
  color: var(--text-mid);
  margin-bottom: 0.75rem;
}

.legal-terms-numbered-section a { color: var(--primary); }

.legal-cookie-table-wrapper {
  overflow-x: auto;
  margin: 1.5rem 0;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.legal-cookie-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.87rem;
  background: var(--white-tinted);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.legal-cookie-table thead {
  background: color-mix(in oklch, var(--primary), transparent 80%);
}

.legal-cookie-table th {
  text-align: left;
  padding: 0.9rem 1rem;
  font-weight: 700;
  color: var(--primary-dark);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.legal-cookie-table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
  color: var(--text-mid);
  vertical-align: top;
  line-height: 1.5;
}

.legal-cookie-table tr:last-child td { border-bottom: none; }

.legal-cookie-table tr:nth-child(even) td {
  background: color-mix(in oklch, var(--bg-base), transparent 30%);
}

.legal-cookie-table code {
  background: color-mix(in oklch, var(--accent), transparent 30%);
  padding: 0.15rem 0.4rem;
  border-radius: var(--radius-xs);
  font-family: monospace;
  font-size: 0.85em;
  color: var(--primary-dark);
}

.legal-page-container h2 {
  font-size: 1.35rem;
  color: var(--primary-dark);
  margin-top: 2.5rem;
  margin-bottom: 0.9rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.legal-page-container h2:first-of-type { margin-top: 0; }

.legal-page-container p {
  font-size: 0.93rem;
  line-height: 1.8;
  color: var(--text-mid);
  margin-bottom: 0.9rem;
}

.legal-page-container a { color: var(--primary); }



.cookie-consent-overlay {
  position: fixed;
  inset: 0;
  background: color-mix(in oklch, black, transparent 55%);
  z-index: 9000;
  opacity: 0;
  transition: opacity var(--transition-mid);
  pointer-events: none;
}

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

.cookie-consent-side-panel {
  position: fixed;
  top: 0;
  right: -340px;
  width: 320px;
  height: 100vh;
  background: var(--white-tinted);
  z-index: 9001;
  box-shadow: -8px 0 40px color-mix(in oklch, black, transparent 75%);
  display: flex;
  flex-direction: column;
  transition: right 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  overflow: hidden;
}

.cookie-consent-side-panel.panel-open {
  right: 0;
}

.cookie-consent-panel-header {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  padding: 1.5rem;
  color: var(--white-tinted);
  flex-shrink: 0;
}

.cookie-consent-panel-header-top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.cookie-consent-shield-icon {
  font-size: 1.5rem;
  color: var(--secondary-light);
}

.cookie-consent-panel-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--white-tinted);
  margin: 0;
}

.cookie-consent-panel-subtitle {
  font-size: 0.78rem;
  color: color-mix(in oklch, var(--white-tinted), transparent 25%);
  line-height: 1.5;
  margin: 0;
}

.cookie-consent-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.cookie-consent-category-item {
  background: var(--bg-base);
  border-radius: var(--radius-md);
  padding: 1rem;
  border: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
}

.cookie-consent-category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.4rem;
}

.cookie-consent-category-name {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text-dark);
}

.cookie-consent-category-desc {
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}

.cookie-consent-toggle {
  position: relative;
  width: 42px;
  height: 24px;
  flex-shrink: 0;
}

.cookie-consent-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.cookie-consent-toggle-slider {
  position: absolute;
  inset: 0;
  background: color-mix(in oklch, var(--accent), transparent 20%);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.cookie-consent-toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: var(--white-tinted);
  border-radius: 50%;
  transition: transform var(--transition-fast);
  box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}

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

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

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

.cookie-consent-panel-footer {
  padding: 1.25rem 1.5rem;
  border-top: 1px solid color-mix(in oklch, var(--accent), transparent 40%);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  flex-shrink: 0;
  background: var(--white-tinted);
}

.cookie-consent-accept-all-button {
  background: var(--primary);
  color: var(--white-tinted);
  border: none;
  padding: 0.8rem;
  border-radius: var(--radius-pill);
  font-family: 'Commissioner', sans-serif;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast);
  min-height: 44px;
}

.cookie-consent-accept-all-button:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
}

.cookie-consent-save-button {
  background: transparent;
  color: var(--primary-dark);
  border: 1.5px solid color-mix(in oklch, var(--primary), transparent 50%);
  padding: 0.75rem;
  border-radius: var(--radius-pill);
  font-family: 'Commissioner', sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  min-height: 44px;
}

.cookie-consent-save-button:hover {
  background: color-mix(in oklch, var(--primary), transparent 88%);
  border-color: var(--primary);
}

.cookie-consent-reject-button {
  background: transparent;
  color: var(--text-muted);
  border: none;
  padding: 0.5rem;
  font-family: 'Commissioner', sans-serif;
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  text-align: center;
  transition: color var(--transition-fast);
  text-decoration: underline;
  min-height: 36px;
}

.cookie-consent-reject-button:hover { color: var(--text-dark); }

.cookie-consent-policy-link {
  text-align: center;
  font-size: 0.72rem;
  color: var(--text-muted);
  padding-top: 0.25rem;
}

.cookie-consent-policy-link a { color: var(--primary); }



@media (max-width: 1024px) {
  .homepage-services-cards-grid {
    grid-template-columns: 1fr;
    max-width: 500px;
    margin: 0 auto;
  }

  .homepage-service-card-featured {
    transform: none;
  }

  .homepage-service-card-featured:hover {
    transform: translateY(-8px);
  }

  .homepage-sticky-storytelling-container {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .homepage-sticky-visual-panel {
    position: relative;
    top: auto;
  }

  .homepage-sticky-main-image { height: 380px; }

  .homepage-gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .homepage-gallery-item-large {
    grid-column: span 2;
    grid-row: span 1;
  }

  .homepage-gallery-item-large img { height: 300px; }
  .homepage-gallery-item img { height: 200px; }

  .services-detail-item-body {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .guide-content-container {
    grid-template-columns: 1fr;
  }

  .guide-toc-card {
    position: static;
  }
}

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

  .main-navigation-links { display: none; }
  .main-navigation-hamburger-button { display: flex; }

  .homepage-intro-content-container {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .homepage-intro-main-image { height: 300px; }

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

  .homepage-key-advantages-container {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .homepage-key-advantages-photo { height: 320px; }

  .homepage-key-advantages-floating-badge {
    right: 1rem;
    bottom: -1rem;
  }

  .homepage-process-steps-row {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
  }

  .homepage-process-step-connector {
    width: 2px;
    height: 30px;
    margin: 0;
  }

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

  .homepage-gallery-item-large {
    grid-column: span 1;
  }

  .homepage-gallery-item-large img { height: 260px; }
  .homepage-gallery-item img { height: 200px; }

  .footer-columns-wrapper {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .footer-bottom-bar {
    flex-direction: column;
    text-align: center;
  }

  .story-intro-grid,
  .story-team-content-container {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .story-intro-photo,
  .story-team-photo { height: 300px; }

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

  .story-mission-inner-card { padding: 2.5rem 1.5rem; }

  .services-detail-item { padding: 2rem 1.5rem; }

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

  .contact-main-container {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .contact-form-wizard-wrapper { padding: 2rem 1.5rem; }

  .homepage-hero-trust-row {
    flex-direction: column;
    gap: 0.5rem;
  }

  .homepage-hero-action-group {
    flex-direction: column;
    align-items: center;
  }

  .homepage-hero-primary-button,
  .homepage-hero-secondary-button {
    width: 100%;
    max-width: 280px;
    justify-content: center;
  }

  .guide-rooms-grid { grid-template-columns: 1fr; }

  .guide-cta-overlay-content h2 { font-size: 1.4rem; }

  .guide-cta-button-group { flex-direction: column; align-items: center; }

  .guide-cta-primary-button,
  .guide-cta-secondary-button {
    width: 100%;
    max-width: 260px;
    justify-content: center;
  }

  .cookie-consent-side-panel {
    width: 100%;
    right: -100%;
  }

  .cookie-consent-side-panel.panel-open { right: 0; }

  .homepage-sticky-scroll-content-panel { padding: 1rem 0; }

  .homepage-sticky-text-step h2,
  .homepage-sticky-text-step h3 { font-size: 1.3rem; }
}

@media (max-width: 480px) {
  .homepage-hero-content-wrapper { padding: 2rem 1rem; }
  .homepage-hero-badge { font-size: 0.75rem; }

  .homepage-intro-content-container,
  .homepage-benefits-content-container,
  .homepage-services-content-container,
  .homepage-key-advantages-container,
  .homepage-gallery-content-container,
  .homepage-process-content-container,
  .story-content-container,
  .story-values-content-container,
  .story-team-content-container,
  .story-mission-content-container,
  .services-detail-container,
  .services-faq-content-container,
  .guide-content-container,
  .guide-cta-content-container,
  .contact-main-container,
  .legal-page-container,
  .footer-main-content-area {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .footer-large-cta-block { padding: var(--space-lg) 1.25rem; }
  .footer-cta-headline { font-size: 1.6rem; }

  .inner-page-hero-section { padding: calc(var(--nav-height) + 3rem) 1.25rem 3rem; }

  .services-detail-item { padding: 1.5rem 1rem; }
  .services-detail-item-header { flex-direction: column; gap: 1rem; }

  .contact-form-wizard-wrapper { padding: 1.5rem 1rem; }

  .thanks-page-action-buttons { flex-direction: column; align-items: center; }
  .thanks-page-home-button,
  .thanks-page-guide-button {
    width: 100%;
    max-width: 260px;
    justify-content: center;
  }

  .legal-cookie-table { font-size: 0.78rem; }
  .legal-cookie-table th,
  .legal-cookie-table td { padding: 0.6rem 0.7rem; }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .homepage-hero-blob-one,
  .homepage-hero-blob-two,
  .footer-cta-blob-bg,
  .inner-page-hero-blob-bg {
    animation: none;
  }
}