@layer base, layout, components, utilities;

@layer base {
  :root {
    --color-bg-primary: #0a0d14;
    --color-bg-secondary: #0f1420;
    --color-bg-light: #f0f2f8;
    --color-bg-light-alt: #e8ecf5;
    --color-surface: #141928;
    --color-surface-raised: #1a2035;
    --color-surface-light: #ffffff;
    --color-surface-light-raised: #f7f9fd;

    --color-accent-primary: #6c63ff;
    --color-accent-secondary: #00d4aa;
    --color-accent-warm: #ff7b54;
    --color-accent-glow: rgba(108, 99, 255, 0.4);
    --color-accent-glow-secondary: rgba(0, 212, 170, 0.3);

    --color-text-primary-dark: #e8eaf6;
    --color-text-secondary-dark: #9aa3c0;
    --color-text-primary-light: #12172b;
    --color-text-secondary-light: #4a5270;
    --color-text-muted-light: #7a8299;

    --accent-primary: var(--color-accent-primary);
    --accent-secondary: var(--color-accent-secondary);

    --shadow-sm: 0 1px 3px rgba(0,0,0,0.15), 0 1px 2px rgba(0,0,0,0.1);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.2), 0 2px 6px rgba(0,0,0,0.12);
    --shadow-lg: 0 10px 30px rgba(0,0,0,0.25), 0 4px 12px rgba(0,0,0,0.15);
    --shadow-glow: 0 0 20px var(--color-accent-glow), 0 4px 20px rgba(0,0,0,0.3);
    --shadow-glow-secondary: 0 0 20px var(--color-accent-glow-secondary), 0 4px 20px rgba(0,0,0,0.3);
    --shadow-card-light: 0 2px 8px rgba(108, 99, 255, 0.08), 0 4px 20px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04);
    --shadow-card-hover-light: 0 4px 16px rgba(108, 99, 255, 0.18), 0 8px 30px rgba(0,0,0,0.1), 0 2px 6px rgba(0,0,0,0.06);
    --shadow-card-dark: 0 2px 8px rgba(0,0,0,0.4), 0 4px 20px rgba(0,0,0,0.3), 0 0 1px rgba(108,99,255,0.2);
    --shadow-card-hover-dark: 0 4px 16px rgba(108,99,255,0.3), 0 8px 30px rgba(0,0,0,0.5), 0 0 2px rgba(108,99,255,0.4);

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

    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-8: 32px;
    --space-10: 40px;
    --space-12: 48px;
    --space-16: 64px;
    --space-20: 80px;
    --space-24: 96px;
    --space-32: 128px;

    --font-heading: 'Space Grotesk', sans-serif;
    --font-body: 'Inter', sans-serif;

    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;
    --transition-spring: 350ms cubic-bezier(0.34, 1.56, 0.64, 1);

    --header-height: 72px;
    --container-max: 1280px;
    --container-narrow: 720px;
  }

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

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

  body {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.6;
    color: var(--color-text-primary-light);
    background-color: var(--color-bg-light);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
  }

  main {
    flex: 1;
  }

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

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

  ul, ol {
    list-style: none;
  }

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

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

@layer layout {
  .content-container {
    inline-size: min(100%, var(--container-max));
    margin-inline: auto;
    padding-inline: var(--space-6);
  }

  @media (min-width: 768px) {
    .content-container {
      padding-inline: var(--space-8);
    }
  }

  @media (min-width: 1024px) {
    .content-container {
      padding-inline: var(--space-12);
    }
  }

  .form-container-narrow {
    max-inline-size: var(--container-narrow);
    margin-inline: auto;
  }
}

@layer components {

  
  .skeleton-overlay {
    position: fixed;
    inset: 0;
    background-color: var(--color-bg-light);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    padding: var(--space-6);
    animation: skeletonFadeOut 0.4s ease 1.2s forwards;
  }

  @keyframes skeletonFadeOut {
    to { opacity: 0; visibility: hidden; pointer-events: none; }
  }

  @keyframes skeletonShimmer {
    0% { background-position: -600px 0; }
    100% { background-position: 600px 0; }
  }

  .skeleton-nav,
  .skeleton-block,
  .skeleton-card {
    background: linear-gradient(90deg, #e2e5ef 25%, #eef0f7 50%, #e2e5ef 75%);
    background-size: 600px 100%;
    animation: skeletonShimmer 1.5s infinite linear;
    border-radius: var(--radius-sm);
  }

  .skeleton-nav {
    block-size: 60px;
    border-radius: var(--radius-md);
  }

  .skeleton-hero {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-block: var(--space-8);
  }

  .skeleton-title { block-size: 48px; inline-size: 70%; }
  .skeleton-subtitle { block-size: 24px; inline-size: 50%; }
  .skeleton-btn { block-size: 44px; inline-size: 160px; border-radius: var(--radius-full); }

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

  .skeleton-card {
    block-size: 200px;
    border-radius: var(--radius-lg);
  }

  
  .site-header {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 1000;
    block-size: var(--header-height);
    background-color: var(--color-bg-primary);
    border-block-end: 1px solid rgba(108, 99, 255, 0.15);
    transition: background-color var(--transition-base), box-shadow var(--transition-base);
  }

  .site-header.scrolled {
    box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 1px rgba(108,99,255,0.2);
  }

  .site-header.header-light {
    background-color: rgba(240, 242, 248, 0.95);
    border-block-end-color: rgba(108, 99, 255, 0.1);
    backdrop-filter: blur(12px);
  }

  .site-header.header-dark {
    background-color: rgba(10, 13, 20, 0.95);
    backdrop-filter: blur(12px);
  }

  .header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    block-size: var(--header-height);
  }

  .brand-mark {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    flex-shrink: 0;
  }

  .brand-logo {
    inline-size: 36px;
    block-size: 36px;
    flex-shrink: 0;
  }

  .brand-name {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
    transition: color var(--transition-base);
  }

  .site-header.header-light .brand-name {
    color: var(--color-text-primary-light);
  }

  .primary-nav {
    display: none;
  }

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

  .nav-list {
    display: flex;
    align-items: center;
    gap: var(--space-1);
  }

  .nav-link {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--color-text-secondary-dark);
    padding-block: var(--space-2);
    padding-inline: var(--space-4);
    border-radius: var(--radius-full);
    transition: color var(--transition-base), background-color var(--transition-base);
    position: relative;
  }

  .nav-link:hover,
  .nav-link.active {
    color: var(--color-accent-primary);
    background-color: rgba(108, 99, 255, 0.1);
  }

  .site-header.header-light .nav-link {
    color: var(--color-text-secondary-light);
  }

  .site-header.header-light .nav-link:hover,
  .site-header.header-light .nav-link.active {
    color: var(--color-accent-primary);
    background-color: rgba(108, 99, 255, 0.08);
  }

  .menu-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: var(--space-2);
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-sm);
    transition: background-color var(--transition-base);
  }

  .menu-toggle:hover {
    background-color: rgba(108, 99, 255, 0.1);
  }

  @media (min-width: 1024px) {
    .menu-toggle { display: none; }
  }

  .toggle-bar {
    display: block;
    inline-size: 22px;
    block-size: 2px;
    background-color: var(--color-text-primary-dark);
    border-radius: var(--radius-full);
    transition: transform var(--transition-base), opacity var(--transition-base), background-color var(--transition-base);
  }

  .site-header.header-light .toggle-bar {
    background-color: var(--color-text-primary-light);
  }

  .menu-toggle.active .toggle-bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .menu-toggle.active .toggle-bar:nth-child(2) {
    opacity: 0;
  }

  .menu-toggle.active .toggle-bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  .mobile-nav-drawer {
    display: none;
    background-color: var(--color-bg-secondary);
    border-block-end: 1px solid rgba(108, 99, 255, 0.15);
    overflow: hidden;
    max-block-size: 0;
    transition: max-block-size var(--transition-slow);
  }

  .mobile-nav-drawer.open {
    display: block;
    max-block-size: 400px;
  }

  .site-header.header-light .mobile-nav-drawer {
    background-color: var(--color-bg-light);
    border-block-end-color: rgba(108, 99, 255, 0.1);
  }

  .mobile-nav-list {
    padding-block: var(--space-4);
    padding-inline: var(--space-6);
  }

  .mobile-nav-link {
    display: block;
    padding-block: var(--space-3);
    padding-inline: var(--space-4);
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--color-text-secondary-dark);
    border-radius: var(--radius-sm);
    transition: color var(--transition-base), background-color var(--transition-base);
  }

  .mobile-nav-link:hover {
    color: var(--color-accent-primary);
    background-color: rgba(108, 99, 255, 0.1);
  }

  .site-header.header-light .mobile-nav-link {
    color: var(--color-text-secondary-light);
  }

  
  .hero-zone {
    position: relative;
    min-block-size: 100svh;
    display: flex;
    align-items: center;
    overflow: hidden;
    padding-block-start: var(--header-height);
    background-color: var(--color-bg-primary);
  }

  .hero-backdrop {
    position: absolute;
    inset: 0;
    background:
      radial-gradient(ellipse 80% 60% at 60% 40%, rgba(108, 99, 255, 0.15) 0%, transparent 60%),
      radial-gradient(ellipse 40% 40% at 20% 70%, rgba(0, 212, 170, 0.08) 0%, transparent 50%),
      radial-gradient(ellipse 60% 80% at 80% 80%, rgba(108, 99, 255, 0.05) 0%, transparent 50%);
  }

  .hero-particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
  }

  .particle {
    position: absolute;
    border-radius: var(--radius-full);
    opacity: 0;
    animation: particleFloat 8s ease-in-out infinite;
  }

  .p1 { inline-size: 4px; block-size: 4px; background: var(--color-accent-primary); inset-block-start: 20%; inset-inline-start: 15%; animation-delay: 0s; }
  .p2 { inline-size: 6px; block-size: 6px; background: var(--color-accent-secondary); inset-block-start: 60%; inset-inline-start: 80%; animation-delay: 1.5s; }
  .p3 { inline-size: 3px; block-size: 3px; background: var(--color-accent-primary); inset-block-start: 40%; inset-inline-start: 60%; animation-delay: 3s; }
  .p4 { inline-size: 5px; block-size: 5px; background: var(--color-accent-warm); inset-block-start: 75%; inset-inline-start: 25%; animation-delay: 4.5s; }
  .p5 { inline-size: 4px; block-size: 4px; background: var(--color-accent-secondary); inset-block-start: 30%; inset-inline-start: 45%; animation-delay: 2s; }

  @keyframes particleFloat {
    0%, 100% { opacity: 0; transform: translateY(0); }
    25%, 75% { opacity: 0.7; }
    50% { opacity: 1; transform: translateY(-20px); }
  }

  .hero-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    padding-block: var(--space-20);
    position: relative;
    z-index: 1;
  }

  @media (min-width: 1024px) {
    .hero-layout {
      grid-template-columns: 1fr 1fr;
      align-items: center;
    }
  }

  .hero-text-block {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent-secondary);
    padding-block: var(--space-2);
    padding-inline: var(--space-4);
    background-color: rgba(0, 212, 170, 0.1);
    border: 1px solid rgba(0, 212, 170, 0.2);
    border-radius: var(--radius-full);
    inline-size: fit-content;
  }

  .hero-display {
    font-family: var(--font-heading);
    font-size: clamp(2.2rem, 5vw, 4rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--color-text-primary-dark);
  }

  .highlight-text {
    background: linear-gradient(135deg, var(--color-accent-primary) 0%, var(--color-accent-secondary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

  .hero-lead {
    font-size: clamp(1rem, 1.5vw, 1.15rem);
    color: var(--color-text-secondary-dark);
    line-height: 1.7;
    max-inline-size: 52ch;
  }

  .hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    align-items: center;
  }

  .hero-visual-block {
    display: flex;
    justify-content: center;
  }

  .hero-card-glow {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-glow), 0 0 60px rgba(108, 99, 255, 0.2);
    border: 1px solid rgba(108, 99, 255, 0.25);
    inline-size: 100%;
    max-inline-size: 520px;
  }

  .hero-image {
    inline-size: 100%;
    block-size: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
  }

  .hero-card-badge {
    position: absolute;
    inset-block-end: var(--space-5);
    inset-inline-start: var(--space-5);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background-color: rgba(10, 13, 20, 0.85);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(108, 99, 255, 0.3);
    border-radius: var(--radius-full);
    padding-block: var(--space-2);
    padding-inline: var(--space-4);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-accent-primary);
  }

  
  .primary-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: linear-gradient(135deg, var(--color-accent-primary) 0%, color-mix(in srgb, var(--color-accent-primary) 70%, var(--color-accent-secondary)) 100%);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 600;
    padding-block: var(--space-3);
    padding-inline: var(--space-6);
    border-radius: var(--radius-full);
    border: none;
    box-shadow: 0 4px 15px rgba(108, 99, 255, 0.4), 0 2px 6px rgba(0,0,0,0.2);
    transition: transform var(--transition-spring), box-shadow var(--transition-base), filter var(--transition-base);
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
  }

  .primary-action:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(108, 99, 255, 0.5), 0 4px 12px rgba(0,0,0,0.2);
    filter: brightness(1.05);
    color: #fff;
  }

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

  .secondary-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: transparent;
    color: var(--color-accent-secondary);
    font-size: 0.9rem;
    font-weight: 600;
    padding-block: var(--space-3);
    padding-inline: var(--space-6);
    border-radius: var(--radius-full);
    border: 1.5px solid var(--color-accent-secondary);
    transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-spring), box-shadow var(--transition-base);
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
  }

  .secondary-action:hover {
    background-color: rgba(0, 212, 170, 0.1);
    box-shadow: 0 0 15px rgba(0, 212, 170, 0.2);
    transform: translateY(-2px);
    color: var(--color-accent-secondary);
  }

  
  .intro-strip {
    background-color: var(--color-bg-light-alt);
    padding-block: var(--space-5);
    border-block: 1px solid rgba(108, 99, 255, 0.1);
    overflow: hidden;
  }

  .intro-ticker {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
    font-size: 0.875rem;
  }

  .ticker-label {
    font-weight: 600;
    color: var(--color-accent-primary);
    flex-shrink: 0;
  }

  .ticker-item {
    color: var(--color-text-secondary-light);
    font-weight: 500;
  }

  .ticker-sep {
    color: var(--color-accent-primary);
    opacity: 0.4;
  }

  
  .section-header {
    margin-block-end: var(--space-12);
    max-inline-size: 60ch;
  }

  .section-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-block-end: var(--space-4);
  }

  .section-subtext {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  [data-section="dark"] .section-heading {
    color: var(--color-text-primary-dark);
  }

  [data-section="dark"] .section-subtext {
    color: var(--color-text-secondary-dark);
  }

  [data-section="light"] .section-heading {
    color: var(--color-text-primary-light);
  }

  
  .featured-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light);
  }

  .info-grid.featured-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

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

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

    .featured-primary {
      grid-row: 1 / 3;
    }
  }

  .content-block {
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: transform var(--transition-spring), box-shadow var(--transition-base);
  }

  .card-glow-wrap {
    background-color: var(--color-surface-light);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-card-light);
    block-size: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid rgba(108, 99, 255, 0.06);
    transition: box-shadow var(--transition-base), border-color var(--transition-base);
  }

  .content-block:hover .card-glow-wrap {
    box-shadow: var(--shadow-card-hover-light);
    border-color: rgba(108, 99, 255, 0.15);
  }

  .card-image-zone {
    position: relative;
    overflow: hidden;
  }

  .card-image {
    inline-size: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    transition: transform var(--transition-slow);
  }

  .content-block:hover .card-image {
    transform: scale(1.04);
  }

  .card-category-tag {
    position: absolute;
    inset-block-start: var(--space-4);
    inset-inline-start: var(--space-4);
    background-color: var(--color-accent-primary);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding-block: var(--space-1);
    padding-inline: var(--space-3);
    border-radius: var(--radius-full);
  }

  .card-tag-inline {
    position: static;
    display: inline-flex;
    margin-block-end: var(--space-3);
  }

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

  .card-body-solo {
    padding: var(--space-6);
    block-size: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .card-heading {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
  }

  .featured-primary .card-heading {
    font-size: 1.3rem;
  }

  .card-excerpt {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
    flex: 1;
  }

  .card-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-accent-primary);
    transition: gap var(--transition-base), color var(--transition-base);
    margin-block-start: auto;
  }

  .card-action:hover {
    gap: var(--space-3);
    color: color-mix(in srgb, var(--color-accent-primary) 80%, white);
  }

  
  .dark-feature-zone {
    background-color: var(--color-bg-secondary);
    padding-block: var(--space-24);
    position: relative;
    overflow: hidden;
  }

  .dark-feature-zone::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 80% at 0% 50%, rgba(108, 99, 255, 0.08) 0%, transparent 60%);
    pointer-events: none;
  }

  .split-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

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

    .split-layout .split-visual:first-child {
      order: -1;
    }
  }

  .split-visual {
    display: flex;
    justify-content: center;
  }

  .glow-image-frame {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-glow);
    border: 1px solid rgba(108, 99, 255, 0.2);
    inline-size: 100%;
    max-inline-size: 480px;
  }

  .glow-image-frame::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--radius-xl);
    box-shadow: inset 0 0 30px rgba(108, 99, 255, 0.1);
    pointer-events: none;
  }

  .split-image {
    inline-size: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
  }

  .split-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .eyebrow-label {
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent-secondary);
  }

  .split-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2.2rem);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: var(--color-text-primary-dark);
  }

  .split-body {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-text-secondary-dark);
  }

  
  .process-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light-alt);
  }

  .process-flow {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
    position: relative;
  }

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

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

  .process-step {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding: var(--space-6);
    background-color: var(--color-surface-light);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(108, 99, 255, 0.08);
    box-shadow: var(--shadow-card-light);
    transition: box-shadow var(--transition-base), transform var(--transition-spring);
  }

  .process-step:hover {
    box-shadow: var(--shadow-card-hover-light);
    transform: translateY(-3px);
  }

  .step-number-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: 36px;
    block-size: 36px;
    background: linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));
    border-radius: var(--radius-sm);
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    color: #fff;
  }

  .step-connector {
    display: none;
  }

  .step-icon-wrap {
    font-size: 1.5rem;
    color: var(--color-accent-primary);
  }

  .step-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
  }

  .step-desc {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  
  .topics-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-primary);
    position: relative;
    overflow: hidden;
  }

  .topics-zone::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 50% at 100% 0%, rgba(0, 212, 170, 0.06) 0%, transparent 60%);
    pointer-events: none;
  }

  .topics-mosaic {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

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

    .topic-wide {
      grid-column: 1 / 3;
    }
  }

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

    .topic-large {
      grid-row: 1 / 3;
    }

    .topic-wide {
      grid-column: 2 / 4;
    }
  }

  .topic-tile {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background-color: var(--color-surface);
    border: 1px solid rgba(108, 99, 255, 0.15);
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    box-shadow: var(--shadow-card-dark);
    transition: box-shadow var(--transition-base), border-color var(--transition-base), transform var(--transition-spring);
    min-block-size: 200px;
  }

  .topic-tile:hover {
    box-shadow: var(--shadow-card-hover-dark);
    border-color: rgba(108, 99, 255, 0.35);
    transform: translateY(-2px);
  }

  .tile-glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(108, 99, 255, 0.05) 0%, transparent 70%);
    opacity: 0;
    transition: opacity var(--transition-base);
    pointer-events: none;
  }

  .topic-tile:hover .tile-glow {
    opacity: 1;
  }

  .tile-bg-image {
    position: absolute;
    inset: 0;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    opacity: 0.12;
    mix-blend-mode: luminosity;
  }

  .tile-icon {
    font-size: 1.75rem;
    color: var(--color-accent-primary);
    position: relative;
    z-index: 1;
  }

  .tile-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
    position: relative;
    z-index: 1;
  }

  .tile-body {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-dark);
    position: relative;
    z-index: 1;
  }

  
  .latest-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light);
  }

  .articles-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-block-start: 1px solid rgba(108, 99, 255, 0.1);
  }

  .article-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    padding-block: var(--space-6);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
    transition: background-color var(--transition-base);
    border-radius: var(--radius-sm);
    padding-inline: var(--space-4);
  }

  @media (min-width: 768px) {
    .article-row {
      grid-template-columns: 160px 1fr 40px;
      align-items: center;
    }
  }

  .article-row:hover {
    background-color: rgba(108, 99, 255, 0.04);
  }

  .article-meta {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
  }

  .article-date {
    font-size: 0.8rem;
    color: var(--color-text-muted-light);
    font-weight: 500;
  }

  .article-category {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-accent-primary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }

  .article-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
    line-height: 1.35;
    margin-block-end: var(--space-2);
  }

  .article-title a {
    transition: color var(--transition-base);
  }

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

  .article-preview {
    font-size: 0.875rem;
    line-height: 1.65;
    color: var(--color-text-secondary-light);
  }

  .article-arrow {
    display: none;
    color: var(--color-accent-primary);
    font-size: 1rem;
    justify-content: flex-end;
    opacity: 0;
    transition: opacity var(--transition-base), transform var(--transition-base);
  }

  @media (min-width: 768px) {
    .article-arrow { display: flex; }
  }

  .article-row:hover .article-arrow {
    opacity: 1;
    transform: translateX(4px);
  }

  .section-cta {
    margin-block-start: var(--space-10);
    display: flex;
    justify-content: center;
  }

  
  .contact-preview-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-secondary);
    position: relative;
    overflow: hidden;
  }

  .contact-preview-zone::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 50% 70% at 50% 100%, rgba(0, 212, 170, 0.06) 0%, transparent 60%);
    pointer-events: none;
  }

  .contact-cards-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
    margin-block-end: var(--space-10);
  }

  @media (min-width: 640px) {
    .contact-cards-row {
      grid-template-columns: repeat(2, 1fr);
    }
  }

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

  .contact-info-card {
    background-color: var(--color-surface);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    border: 1px solid rgba(108, 99, 255, 0.15);
    box-shadow: var(--shadow-card-dark);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    transition: box-shadow var(--transition-base), border-color var(--transition-base), transform var(--transition-spring);
  }

  .contact-info-card:hover {
    box-shadow: var(--shadow-card-hover-dark);
    border-color: rgba(108, 99, 255, 0.3);
    transform: translateY(-3px);
  }

  .contact-icon-wrap {
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, rgba(108, 99, 255, 0.2), rgba(0, 212, 170, 0.1));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--color-accent-primary);
  }

  .contact-card-label {
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-secondary-dark);
  }

  .contact-card-value {
    font-size: 0.95rem;
    color: var(--color-text-primary-dark);
    line-height: 1.6;
  }

  .contact-card-value a {
    color: var(--color-accent-secondary);
    transition: color var(--transition-base);
  }

  .contact-card-value a:hover {
    color: color-mix(in srgb, var(--color-accent-secondary) 80%, white);
  }

  .contact-cta {
    display: flex;
    justify-content: center;
  }

  
  .page-hero-zone {
    background-color: var(--color-bg-primary);
    padding-block: var(--space-20);
    padding-block-start: calc(var(--header-height) + var(--space-20));
    position: relative;
    overflow: hidden;
  }

  .page-hero-zone::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 80% at 30% 50%, rgba(108, 99, 255, 0.1) 0%, transparent 60%);
    pointer-events: none;
  }

  .page-hero-content {
    position: relative;
    z-index: 1;
    max-inline-size: 700px;
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
  }

  .page-hero-heading {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.15;
    color: var(--color-text-primary-dark);
  }

  .page-hero-lead {
    font-size: 1.05rem;
    line-height: 1.75;
    color: var(--color-text-secondary-dark);
    max-inline-size: 55ch;
  }

  
  .team-intro-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light);
  }

  .team-grid-zone {
    padding-block: var(--space-12) var(--space-24);
    background-color: var(--color-bg-light);
  }

  .info-grid.team-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

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

  .team-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .team-photo-wrap {
    overflow: hidden;
  }

  .team-photo {
    inline-size: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    transition: transform var(--transition-slow);
  }

  .team-card:hover .team-photo {
    transform: scale(1.04);
  }

  .team-info {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .team-info-solo {
    padding: var(--space-6);
    block-size: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .team-name {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
  }

  .team-role {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-accent-primary);
  }

  .team-bio {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  .team-specializations {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-block-start: var(--space-2);
  }

  .spec-tag {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--color-accent-secondary);
    background-color: rgba(0, 212, 170, 0.08);
    border: 1px solid rgba(0, 212, 170, 0.2);
    border-radius: var(--radius-full);
    padding-block: 2px;
    padding-inline: var(--space-3);
  }

  
  .values-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-primary);
  }

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

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

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

    .values-grid .value-item:last-child {
      grid-column: 1 / 4;
      max-inline-size: 400px;
      margin-inline: auto;
      inline-size: 100%;
    }
  }

  .value-item {
    background-color: var(--color-surface);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    border: 1px solid rgba(108, 99, 255, 0.12);
    box-shadow: var(--shadow-card-dark);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    transition: box-shadow var(--transition-base), border-color var(--transition-base), transform var(--transition-spring);
  }

  .value-item:hover {
    box-shadow: var(--shadow-card-hover-dark);
    border-color: rgba(108, 99, 255, 0.28);
    transform: translateY(-3px);
  }

  .value-icon {
    font-size: 1.5rem;
    color: var(--color-accent-primary);
  }

  .value-title {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
  }

  .value-desc {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-dark);
  }

  
  .join-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light);
  }

  .join-cta-block {
    max-inline-size: 680px;
    margin-inline: auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
  }

  .join-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--color-text-primary-light);
  }

  .join-body {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
  }

  
  .cases-filter-zone {
    padding-block: var(--space-8);
    background-color: var(--color-bg-light);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
  }

  .filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
  }

  .filter-btn {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-text-secondary-light);
    padding-block: var(--space-2);
    padding-inline: var(--space-4);
    border-radius: var(--radius-full);
    border: 1.5px solid rgba(108, 99, 255, 0.15);
    background-color: transparent;
    transition: all var(--transition-base);
    cursor: pointer;
    min-block-size: 44px;
  }

  .filter-btn:hover,
  .filter-btn.active-filter {
    background-color: var(--color-accent-primary);
    border-color: var(--color-accent-primary);
    color: #fff;
    box-shadow: 0 4px 12px rgba(108, 99, 255, 0.35);
  }

  .cases-zone {
    padding-block: var(--space-16) var(--space-24);
    background-color: var(--color-bg-light);
  }

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

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

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

  .case-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .case-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-block-end: var(--space-4);
  }

  .case-number {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text-muted-light);
    letter-spacing: 0.1em;
  }

  .case-tag {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-accent-primary);
    background-color: rgba(108, 99, 255, 0.08);
    border: 1px solid rgba(108, 99, 255, 0.15);
    border-radius: var(--radius-full);
    padding-block: 2px;
    padding-inline: var(--space-3);
  }

  .case-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
    margin-block-end: var(--space-4);
  }

  .case-summary {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
    margin-block-end: var(--space-5);
    flex: 1;
  }

  .case-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-block-end: var(--space-5);
  }

  .tag-item {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--color-text-muted-light);
    background-color: var(--color-bg-light-alt);
    border-radius: var(--radius-full);
    padding-block: 2px;
    padding-inline: var(--space-3);
  }

  .case-meta {
    display: flex;
    gap: var(--space-5);
    font-size: 0.8rem;
    color: var(--color-text-muted-light);
    border-block-start: 1px solid rgba(108, 99, 255, 0.08);
    padding-block-start: var(--space-4);
  }

  .case-meta span {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .case-card .card-glow-wrap {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
  }

  
  .case-insight-zone {
    padding-block: var(--space-20);
    background-color: var(--color-bg-secondary);
  }

  .insight-block {
    display: flex;
    gap: var(--space-8);
    align-items: flex-start;
    background-color: var(--color-surface);
    border-radius: var(--radius-xl);
    padding: var(--space-10);
    border: 1px solid rgba(108, 99, 255, 0.15);
    box-shadow: var(--shadow-card-dark);
  }

  .insight-icon {
    font-size: 2rem;
    color: var(--color-accent-secondary);
    flex-shrink: 0;
    margin-block-start: var(--space-1);
  }

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

  .insight-heading {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
  }

  .insight-body {
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--color-text-secondary-dark);
  }

  
  .books-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light);
  }

  .books-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .book-item {
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .book-item .card-glow-wrap {
    display: flex;
    flex-direction: row;
    gap: 0;
    align-items: stretch;
  }

  .book-spine {
    inline-size: 8px;
    background-color: var(--spine-color, var(--color-accent-primary));
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-xs) 0 0 var(--radius-xs);
  }

  .book-spine-letter {
    display: none;
  }

  .book-details {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex: 1;
  }

  .book-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
  }

  .book-author {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-accent-primary);
  }

  .book-desc {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  .book-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-block-start: var(--space-2);
  }

  
  .reports-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-primary);
  }

  .reports-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

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

  .report-card {
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .report-card .card-glow-wrap {
    background-color: var(--color-surface);
    border: 1px solid rgba(108, 99, 255, 0.15);
    box-shadow: var(--shadow-card-dark);
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .report-card:hover .card-glow-wrap {
    box-shadow: var(--shadow-card-hover-dark);
    border-color: rgba(108, 99, 255, 0.3);
  }

  .report-icon {
    font-size: 1.5rem;
    color: var(--color-accent-secondary);
  }

  .report-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
  }

  .report-desc {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-dark);
    flex: 1;
  }

  .report-freq {
    display: inline-flex;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-accent-secondary);
    background-color: rgba(0, 212, 170, 0.08);
    border: 1px solid rgba(0, 212, 170, 0.2);
    border-radius: var(--radius-full);
    padding-block: 2px;
    padding-inline: var(--space-3);
    inline-size: fit-content;
  }

  
  .resources-zone {
    padding-block: var(--space-24);
    background-color: var(--color-bg-light-alt);
  }

  .resources-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-block-start: 1px solid rgba(108, 99, 255, 0.1);
  }

  .resource-row {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: var(--space-5);
    padding-block: var(--space-6);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
    align-items: start;
    transition: background-color var(--transition-base);
    padding-inline: var(--space-4);
    border-radius: var(--radius-sm);
  }

  @media (min-width: 768px) {
    .resource-row {
      grid-template-columns: 44px 1fr auto;
    }
  }

  .resource-row:hover {
    background-color: rgba(108, 99, 255, 0.04);
  }

  .resource-icon-wrap {
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-md);
    background-color: rgba(108, 99, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent-primary);
    font-size: 1rem;
    flex-shrink: 0;
  }

  .resource-name {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
    margin-block-end: var(--space-2);
  }

  .resource-desc {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  .resource-type {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--color-text-muted-light);
    background-color: var(--color-bg-light);
    border-radius: var(--radius-full);
    padding-block: 2px;
    padding-inline: var(--space-3);
    block-size: fit-content;
    white-space: nowrap;
    flex-shrink: 0;
  }

  
  .reading-note-zone {
    padding-block: var(--space-20);
    background-color: var(--color-bg-secondary);
  }

  .reading-note-block {
    max-inline-size: 680px;
    margin-inline: auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
  }

  .reading-note-heading {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.01em;
  }

  .reading-note-body {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--color-text-secondary-dark);
  }

  
  .contact-news-zone {
    padding-block: var(--space-16);
    background-color: var(--color-bg-light-alt);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
  }

  .news-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

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

  .news-item {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-6);
    background-color: var(--color-surface-light);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(108, 99, 255, 0.08);
    box-shadow: var(--shadow-card-light);
    transition: box-shadow var(--transition-base), transform var(--transition-spring);
  }

  .news-item:hover {
    box-shadow: var(--shadow-card-hover-light);
    transform: translateY(-3px);
  }

  .news-date {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-accent-primary);
  }

  .news-title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
    line-height: 1.35;
  }

  .news-body {
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--color-text-secondary-light);
  }

  
  .full-form-zone {
    padding-block: var(--space-16) var(--space-24);
    background-color: var(--color-bg-light);
  }

  .form-header {
    margin-block-end: var(--space-10);
    text-align: center;
  }

  .form-main-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--color-text-primary-light);
    margin-block-end: var(--space-3);
  }

  .form-intro {
    font-size: 0.95rem;
    color: var(--color-text-secondary-light);
    line-height: 1.6;
  }

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

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

  .field-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-primary-light);
    letter-spacing: 0.01em;
  }

  .required-mark {
    color: var(--color-accent-primary);
    margin-inline-start: 2px;
  }

  .field-input {
    inline-size: 100%;
    padding-block: var(--space-4);
    padding-inline: var(--space-5);
    font-size: 0.95rem;
    color: var(--color-text-primary-light);
    background-color: var(--color-surface-light);
    border: 1.5px solid rgba(108, 99, 255, 0.15);
    border-radius: var(--radius-md);
    outline: none;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
    min-block-size: 52px;
  }

  .field-input:focus {
    border-color: var(--color-accent-primary);
    box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.12), 0 2px 8px rgba(108, 99, 255, 0.08);
  }

  .field-textarea {
    min-block-size: 140px;
    resize: vertical;
    line-height: 1.6;
  }

  .field-helper {
    font-size: 0.8rem;
    color: var(--color-text-muted-light);
    line-height: 1.5;
  }

  .form-field-check {
    gap: var(--space-3);
  }

  .check-label {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    cursor: pointer;
  }

  .check-input {
    position: absolute;
    opacity: 0;
    inline-size: 0;
    block-size: 0;
  }

  .check-custom {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 20px;
    block-size: 20px;
    border: 2px solid rgba(108, 99, 255, 0.3);
    border-radius: var(--radius-xs);
    background-color: var(--color-surface-light);
    flex-shrink: 0;
    margin-block-start: 2px;
    transition: border-color var(--transition-base), background-color var(--transition-base);
    position: relative;
  }

  .check-input:checked + .check-custom {
    background-color: var(--color-accent-primary);
    border-color: var(--color-accent-primary);
  }

  .check-input:checked + .check-custom::after {
    content: '';
    position: absolute;
    inline-size: 10px;
    block-size: 6px;
    border-inline-start: 2px solid #fff;
    border-block-end: 2px solid #fff;
    transform: rotate(-45deg) translateY(-1px);
  }

  .check-text {
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--color-text-secondary-light);
  }

  .inline-link {
    color: var(--color-accent-primary);
    text-decoration: underline;
    text-decoration-color: rgba(108, 99, 255, 0.4);
    transition: text-decoration-color var(--transition-base);
  }

  .inline-link:hover {
    text-decoration-color: var(--color-accent-primary);
  }

  .form-submit-area {
    padding-block-start: var(--space-4);
  }

  .submit-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    background: linear-gradient(135deg, var(--color-accent-primary) 0%, color-mix(in srgb, var(--color-accent-primary) 70%, var(--color-accent-secondary)) 100%);
    color: #fff;
    font-size: 1rem;
    font-weight: 600;
    padding-block: var(--space-4);
    padding-inline: var(--space-8);
    border-radius: var(--radius-full);
    border: none;
    box-shadow: 0 4px 15px rgba(108, 99, 255, 0.4), 0 2px 6px rgba(0,0,0,0.2);
    transition: transform var(--transition-spring), box-shadow var(--transition-base), filter var(--transition-base);
    cursor: pointer;
    min-block-size: 52px;
    font-family: var(--font-heading);
  }

  .submit-action:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(108, 99, 255, 0.5), 0 4px 12px rgba(0,0,0,0.2);
    filter: brightness(1.05);
  }

  
  .map-zone {
    padding-block: var(--space-16) var(--space-24);
    background-color: var(--color-bg-light-alt);
  }

  .map-info-split {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-10);
    align-items: start;
  }

  @media (min-width: 1024px) {
    .map-info-split {
      grid-template-columns: 320px 1fr;
    }
  }

  .map-heading {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
    margin-block-end: var(--space-6);
  }

  .map-detail-row {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
    padding-block: var(--space-4);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
  }

  .map-detail-row:last-child {
    border-block-end: none;
  }

  .map-detail-row i {
    color: var(--color-accent-primary);
    font-size: 1rem;
    margin-block-start: 3px;
    flex-shrink: 0;
  }

  .map-detail-row strong {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted-light);
    margin-block-end: var(--space-1);
  }

  .map-detail-row p {
    font-size: 0.9rem;
    color: var(--color-text-secondary-light);
    line-height: 1.6;
  }

  .map-detail-row a {
    color: var(--color-accent-secondary);
    transition: color var(--transition-base);
  }

  .map-detail-row a:hover {
    color: color-mix(in srgb, var(--color-accent-secondary) 80%, white);
  }

  .map-embed-wrap {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    border: 1px solid rgba(108, 99, 255, 0.1);
  }

  .map-embed-wrap iframe {
    display: block;
    border-radius: var(--radius-xl);
  }

  
  .thanks-main {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .thanks-full-viewport {
    flex: 1;
    background: linear-gradient(135deg, var(--color-accent-primary) 0%, color-mix(in srgb, var(--color-accent-primary) 40%, var(--color-accent-secondary)) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding-block: var(--space-20);
    padding-inline: var(--space-6);
    min-block-size: 60svh;
  }

  .thanks-inner {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
    max-inline-size: 520px;
  }

  .thanks-icon-ring {
    inline-size: 80px;
    block-size: 80px;
    border-radius: var(--radius-full);
    border: 3px solid rgba(255,255,255,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: #fff;
    background-color: rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
  }

  .thanks-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1.1;
  }

  .thanks-body {
    font-size: 1.05rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.7;
  }

  .thanks-home-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    font-size: 0.95rem;
    font-weight: 600;
    color: #fff;
    padding-block: var(--space-3);
    padding-inline: var(--space-6);
    border: 2px solid rgba(255,255,255,0.6);
    border-radius: var(--radius-full);
    transition: background-color var(--transition-base), border-color var(--transition-base), transform var(--transition-spring);
    margin-block-start: var(--space-2);
  }

  .thanks-home-action:hover {
    background-color: rgba(255,255,255,0.15);
    border-color: #fff;
    transform: translateY(-2px);
    color: #fff;
  }

  
  .legal-hero {
    background-color: var(--color-bg-primary);
    padding-block: var(--space-16);
    padding-block-start: calc(var(--header-height) + var(--space-16));
    position: relative;
    overflow: hidden;
  }

  .legal-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 50% 80% at 20% 50%, rgba(108, 99, 255, 0.08) 0%, transparent 60%);
    pointer-events: none;
  }

  .legal-page-title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 700;
    color: var(--color-text-primary-dark);
    letter-spacing: -0.03em;
    margin-block-end: var(--space-3);
    position: relative;
    z-index: 1;
  }

  .legal-date {
    font-size: 0.875rem;
    color: var(--color-text-secondary-dark);
    position: relative;
    z-index: 1;
  }

  .legal-body-zone {
    padding-block: var(--space-16) var(--space-24);
    background-color: var(--color-bg-light);
  }

  .legal-container {
    max-inline-size: 800px;
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
  }

  .legal-intro {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
    padding-block-end: var(--space-6);
    border-block-end: 1px solid rgba(108, 99, 255, 0.1);
  }

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

  .legal-summary-box {
    background: linear-gradient(135deg, rgba(108, 99, 255, 0.08) 0%, rgba(0, 212, 170, 0.04) 100%);
    border-inline-start: 4px solid var(--color-accent-primary);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--space-4) var(--space-5);
    font-size: 0.9rem;
    color: var(--color-text-primary-light);
    line-height: 1.6;
  }

  .legal-detail {
    padding-inline-start: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .legal-detail p,
  .legal-detail ul,
  .legal-detail li {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
  }

  .legal-detail ul {
    list-style: disc;
    padding-inline-start: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .legal-detail a {
    color: var(--color-accent-primary);
    text-decoration: underline;
    text-decoration-color: rgba(108, 99, 255, 0.4);
    transition: text-decoration-color var(--transition-base);
  }

  .legal-detail a:hover {
    text-decoration-color: var(--color-accent-primary);
  }

  
  .terms-section {
    padding-block-end: var(--space-6);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
  }

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

  .terms-heading {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-accent-primary);
    letter-spacing: 0.02em;
    margin-block-end: var(--space-4);
  }

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

  .terms-detail p,
  .terms-detail ul,
  .terms-detail li {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
  }

  .terms-detail ul {
    list-style: disc;
    padding-inline-start: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .terms-detail a {
    color: var(--color-accent-primary);
    text-decoration: underline;
    text-decoration-color: rgba(108, 99, 255, 0.4);
  }

  .terms-detail a:hover {
    text-decoration-color: var(--color-accent-primary);
  }

  
  .cookies-intro-block {
    display: flex;
    align-items: flex-start;
    gap: var(--space-5);
    padding-block-end: var(--space-6);
    border-block-end: 1px solid rgba(108, 99, 255, 0.1);
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
  }

  .cookies-intro-icon {
    font-size: 2rem;
    color: var(--color-accent-primary);
    flex-shrink: 0;
    margin-block-start: var(--space-1);
  }

  .cookies-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    padding-block-end: var(--space-8);
    border-block-end: 1px solid rgba(108, 99, 255, 0.08);
  }

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

  .cookies-heading-row {
    display: flex;
    align-items: center;
    gap: var(--space-4);
  }

  .cookies-section-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: 32px;
    block-size: 32px;
    background-color: var(--color-accent-primary);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
  }

  .cookies-section-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text-primary-light);
    letter-spacing: -0.01em;
  }

  .cookies-section-body {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    padding-inline-start: var(--space-4);
  }

  .cookies-section-body p,
  .cookies-section-body ul,
  .cookies-section-body li {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--color-text-secondary-light);
  }

  .cookies-section-body ul {
    list-style: disc;
    padding-inline-start: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .cookies-section-body a {
    color: var(--color-accent-primary);
    text-decoration: underline;
    text-decoration-color: rgba(108, 99, 255, 0.4);
  }

  .cookie-category {
    background-color: var(--color-surface-light-raised);
    border: 1px solid rgba(108, 99, 255, 0.08);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .cookie-cat-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text-primary-light);
  }

  .cookie-cat-badge {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding-block: 2px;
    padding-inline: var(--space-3);
    border-radius: var(--radius-full);
    color: #fff;
  }

  .cookie-cat-necessary { background-color: #2563eb; }
  .cookie-cat-analytics { background-color: var(--color-accent-primary); }
.cookie-cat-functional { background-color: var(--color-accent-warm); }
  .cookie-cat-marketing { background-color: #dc2626; }

  .cookie-cat-status {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--color-text-muted-light);
    margin-inline-start: auto;
  }

  .cookie-table {
    inline-size: 100%;
    border-collapse: collapse;
    font-size: 0.8rem;
    overflow-x: auto;
    display: block;
  }

  .cookie-table th {
    text-align: start;
    padding-block: var(--space-2);
    padding-inline: var(--space-3);
    background-color: rgba(108, 99, 255, 0.06);
    color: var(--color-text-primary-light);
    font-weight: 600;
    border-block-end: 1px solid rgba(108, 99, 255, 0.1);
    white-space: nowrap;
  }

  .cookie-table td {
    padding-block: var(--space-2);
    padding-inline: var(--space-3);
    color: var(--color-text-secondary-light);
    border-block-end: 1px solid rgba(108, 99, 255, 0.06);
    vertical-align: top;
  }

  .browser-settings-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    background-color: var(--color-surface-light-raised);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    border: 1px solid rgba(108, 99, 255, 0.08);
  }

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

  .browser-item {
    font-size: 0.8rem;
    color: var(--color-text-secondary-light);
    line-height: 1.6;
  }

  
  .site-footer {
    background-color: var(--color-bg-primary);
    border-block-start: 1px solid rgba(108, 99, 255, 0.15);
    padding-block: var(--space-5);
    margin-block-start: auto;
  }

  .footer-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
  }

  .footer-brand {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-secondary-dark);
    font-size: 0.875rem;
    font-weight: 600;
    transition: color var(--transition-base);
  }

  .footer-brand:hover {
    color: var(--color-text-primary-dark);
  }

  .footer-logo {
    inline-size: 24px;
    block-size: 24px;
  }

  .footer-nav {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    align-items: center;
  }

  .footer-nav a {
    font-size: 0.8rem;
    color: var(--color-text-secondary-dark);
    padding-block: var(--space-1);
    padding-inline: var(--space-3);
    border-radius: var(--radius-full);
    transition: color var(--transition-base), background-color var(--transition-base);
  }

  .footer-nav a:hover {
    color: var(--color-accent-primary);
    background-color: rgba(108, 99, 255, 0.08);
  }

  .footer-copy {
    font-size: 0.78rem;
    color: var(--color-text-secondary-dark);
    opacity: 0.6;
  }

  
  .scroll-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
  }

  .scroll-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
  }

  
  .cookie-consent-bar {
    position: fixed;
    inset-block-end: 0;
    inset-inline: 0;
    z-index: 8000;
    background-color: var(--color-bg-primary);
    border-block-start: 1px solid rgba(108, 99, 255, 0.25);
    box-shadow: 0 -8px 30px rgba(0,0,0,0.4), 0 -2px 8px rgba(108,99,255,0.1);
    transform: translateY(100%);
    transition: transform var(--transition-slow);
  }

  .cookie-consent-bar.visible {
    transform: translateY(0);
  }

  .cookie-bar-main {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding-block: var(--space-4);
    padding-inline: var(--space-6);
  }

  @media (min-width: 1024px) {
    .cookie-bar-main {
      flex-wrap: nowrap;
    }
  }

  .cookie-bar-text {
    font-size: 0.875rem;
    color: var(--color-text-secondary-dark);
    line-height: 1.6;
    flex: 1;
    min-inline-size: 0;
  }

  .cookie-bar-text a {
    color: var(--color-accent-primary);
    text-decoration: underline;
    text-decoration-color: rgba(108, 99, 255, 0.4);
    transition: text-decoration-color var(--transition-base);
  }

  .cookie-bar-text a:hover {
    text-decoration-color: var(--color-accent-primary);
  }

  .cookie-bar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    align-items: center;
    flex-shrink: 0;
  }

  .cookie-btn-accept {
    font-size: 0.85rem;
    font-weight: 600;
    color: #fff;
    background: linear-gradient(135deg, var(--color-accent-primary), color-mix(in srgb, var(--color-accent-primary) 70%, var(--color-accent-secondary)));
    padding-block: var(--space-2);
    padding-inline: var(--space-5);
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    min-block-size: 40px;
    box-shadow: 0 4px 12px rgba(108,99,255,0.35);
    transition: transform var(--transition-spring), box-shadow var(--transition-base);
  }

  .cookie-btn-accept:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(108,99,255,0.45);
  }

  .cookie-btn-reject {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-secondary-dark);
    background: transparent;
    padding-block: var(--space-2);
    padding-inline: var(--space-5);
    border-radius: var(--radius-full);
    border: 1.5px solid rgba(108,99,255,0.2);
    cursor: pointer;
    min-block-size: 40px;
    transition: border-color var(--transition-base), color var(--transition-base), background-color var(--transition-base);
  }

  .cookie-btn-reject:hover {
    border-color: rgba(108,99,255,0.4);
    color: var(--color-text-primary-dark);
    background-color: rgba(108,99,255,0.06);
  }

  .cookie-btn-customize {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--color-accent-secondary);
    background: transparent;
    border: none;
    cursor: pointer;
    padding-block: var(--space-2);
    padding-inline: var(--space-3);
    border-radius: var(--radius-full);
    transition: background-color var(--transition-base), color var(--transition-base);
    min-block-size: 40px;
    text-decoration: underline;
    text-decoration-color: rgba(0,212,170,0.4);
  }

  .cookie-btn-customize:hover {
    background-color: rgba(0,212,170,0.08);
    text-decoration-color: var(--color-accent-secondary);
  }

  .cookie-customize-panel {
    display: none;
    background-color: var(--color-surface);
    border-block-start: 1px solid rgba(108,99,255,0.15);
    padding-block: var(--space-5);
    padding-inline: var(--space-6);
  }

  .cookie-customize-panel.open {
    display: block;
  }

  .cookie-categories-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    margin-block-end: var(--space-5);
  }

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

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

  .cookie-category-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4);
    background-color: rgba(255,255,255,0.03);
    border-radius: var(--radius-md);
    border: 1px solid rgba(108,99,255,0.1);
  }

  .cookie-toggle-wrap {
    flex-shrink: 0;
    margin-block-start: 2px;
  }

  .cookie-toggle {
    position: relative;
    display: inline-block;
    inline-size: 40px;
    block-size: 22px;
  }

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

  .toggle-track {
    position: absolute;
    inset: 0;
    background-color: rgba(108,99,255,0.2);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: background-color var(--transition-base);
  }

  .toggle-track::before {
    content: '';
    position: absolute;
    block-size: 16px;
    inline-size: 16px;
    inset-inline-start: 3px;
    inset-block-start: 3px;
    background-color: #fff;
    border-radius: var(--radius-full);
    transition: transform var(--transition-base);
  }

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

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

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

  .cookie-cat-info {
    flex: 1;
  }

  .cookie-cat-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-primary-dark);
    margin-block-end: var(--space-1);
  }

  .cookie-cat-desc {
    font-size: 0.78rem;
    color: var(--color-text-secondary-dark);
    line-height: 1.5;
  }

  .cookie-save-btn {
    font-size: 0.875rem;
    font-weight: 600;
    color: #fff;
    background: linear-gradient(135deg, var(--color-accent-primary), color-mix(in srgb, var(--color-accent-primary) 70%, var(--color-accent-secondary)));
    padding-block: var(--space-2);
    padding-inline: var(--space-6);
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    min-block-size: 40px;
    box-shadow: 0 4px 12px rgba(108,99,255,0.35);
    transition: transform var(--transition-spring), box-shadow var(--transition-base);
  }

  .cookie-save-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(108,99,255,0.45);
  }

}

@layer utilities {

  
  @media (max-width: 767px) {
    .hero-layout {
      padding-block: var(--space-12);
    }

    .hero-display {
      font-size: clamp(1.8rem, 8vw, 2.5rem);
    }

    .hero-actions {
      flex-direction: column;
      align-items: flex-start;
    }

    .insight-block {
      flex-direction: column;
    }

    .book-item .card-glow-wrap {
      flex-direction: column;
    }

    .book-spine {
      inline-size: 100%;
      block-size: 6px;
      border-radius: var(--radius-xs) var(--radius-xs) 0 0;
    }

    .split-layout {
      gap: var(--space-8);
    }

    .cookie-bar-main {
      flex-direction: column;
      align-items: flex-start;
    }

    .values-grid .value-item:last-child {
      grid-column: auto;
      max-inline-size: none;
    }
  }

  @media (max-width: 639px) {
    .contact-cards-row {
      grid-template-columns: 1fr;
    }

    .process-flow {
      grid-template-columns: 1fr;
    }

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

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

    .topics-mosaic {
      grid-template-columns: 1fr;
    }

    .topic-wide {
      grid-column: auto;
    }
  }

  
  :focus-visible {
    outline: 2px solid var(--color-accent-primary);
    outline-offset: 3px;
    border-radius: var(--radius-xs);
  }

  
  ::selection {
    background-color: rgba(108, 99, 255, 0.25);
    color: var(--color-text-primary-light);
  }

  
  ::-webkit-scrollbar {
    inline-size: 8px;
    block-size: 8px;
  }

  ::-webkit-scrollbar-track {
    background-color: var(--color-bg-light);
  }

  ::-webkit-scrollbar-thumb {
    background-color: rgba(108, 99, 255, 0.3);
    border-radius: var(--radius-full);
  }

  ::-webkit-scrollbar-thumb:hover {
    background-color: rgba(108, 99, 255, 0.5);
  }

  
  @media print {
    .site-header,
    .cookie-consent-bar,
    .skeleton-overlay {
      display: none !important;
    }

    body {
      background: #fff;
      color: #000;
    }
  }
}