@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap");

/*
  WordPress companion stylesheet for theme.json.
  Root font-size is 10px, and all type sizes below were compensated
  so they render at the same visual size as a 16px root setup.
*/

/* -------------------------------------------------------------------------- */
/* Token aliases from theme.json                                              */
/* -------------------------------------------------------------------------- */
:root {
  --color-primary: var(--wp--preset--color--primary);
  --color-primary-container: var(--wp--preset--color--primary-container);
  --color-surface: var(--wp--preset--color--surface);
  --color-background: var(--wp--preset--color--background);
  --color-secondary: var(--wp--preset--color--secondary);
  --color-surface-container-lowest: var(--wp--preset--color--surface-container-lowest);
  --color-surface-container-low: var(--wp--preset--color--surface-container-low);
  --color-surface-container: var(--wp--preset--color--surface-container);
  --color-surface-container-high: var(--wp--preset--color--surface-container-high);
  --color-surface-container-highest: var(--wp--preset--color--surface-container-highest);
  --color-surface-variant: var(--wp--preset--color--surface-variant);
  --color-surface-bright: var(--wp--preset--color--surface-bright);
  --color-on-primary-container: var(--wp--preset--color--on-primary-container);
  --color-on-surface: var(--wp--preset--color--on-surface);
  --color-on-background: var(--wp--preset--color--on-background);
  --color-outline: var(--wp--preset--color--outline);
  --color-outline-variant: var(--wp--preset--color--outline-variant);
  --color-error: var(--wp--preset--color--error);
  --color-error-container: var(--wp--preset--color--error-container);

  --font-body: var(--wp--preset--font-family--body);
  --font-headline: var(--wp--preset--font-family--headline);
  --font-label: var(--wp--preset--font-family--label);

  --text-display-large: var(--wp--preset--font-size--display-large);
  --text-headline-medium: var(--wp--preset--font-size--headline-medium);
  --text-body-large: var(--wp--preset--font-size--body-large);
  --text-label-small: var(--wp--preset--font-size--label-small);

  --text-display-large--line-height: 0.8;
  --text-display-large--letter-spacing: -0.04em;
  --text-headline-medium--line-height: 0.95;
  --text-body-large--line-height: 1.6;
  --text-label-small--line-height: 1;
  --text-label-small--letter-spacing: 0.1em;

  --radius: var(--wp--custom--radius--default);
  --radius-sm: var(--wp--custom--radius--sm);
  --radius-md: var(--wp--custom--radius--md);
  --radius-lg: var(--wp--custom--radius--lg);

  --spacing-gutter: var(--wp--custom--spacing--gutter);
  --spacing-card: var(--wp--custom--spacing--card);
  --spacing-section: var(--wp--custom--spacing--section);
  --spacing-section-lg: var(--wp--custom--spacing--section-lg);

  --site-width: var(--wp--custom--layout--site-width);
  --site-width-wide: var(--wp--custom--layout--site-width-wide);
  --site-width-narrow: var(--wp--custom--layout--site-width-narrow);

  --shadow-ambient: var(--wp--custom--shadow--ambient);

  --animate-kinetic-slide: var(--wp--custom--motion--kinetic-slide);
  --animate-glow-pulse: var(--wp--custom--motion--glow-pulse);
  --animate-marquee-horizontal: var(--wp--custom--motion--marquee-horizontal);
  --animate-marquee-vertical: var(--wp--custom--motion--marquee-vertical);
  --animate-reveal: var(--wp--custom--motion--reveal);
}

/* -------------------------------------------------------------------------- */
/* Motion / keyframes kept in CSS                                             */
/* -------------------------------------------------------------------------- */

@keyframes kinetic-slide {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes marquee-horizontal {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes marquee-vertical {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 5px rgb(252 1 1 / 0.20); }
  50% { box-shadow: 0 0 22px rgb(252 1 1 / 0.32); }
}

@keyframes reveal {
  0% {
    transform: translateY(100%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes blur-fade-out {
  to {
    filter: blur(20px);
    opacity: 0;
    transform: translateY(-50px);
  }
}

/* -------------------------------------------------------------------------- */
/* Base                                                                        */
/* -------------------------------------------------------------------------- */

	/* Active page */
	.wp-block-navigation .current-menu-item > .wp-block-navigation-item__content,
	.wp-block-navigation .current_page_item > .wp-block-navigation-item__content {
		color: var(--color-primary);
		font-weight: 900;
		text-decoration: underline;
		text-underline-offset: 0.4em;
	}

.hljs {
	background-color: var(--color-background);
	color: var(--color-on-background);
}

@layer base {
  html {
    background: var(--color-background);
    color: var(--color-on-background);
    scroll-behavior: smooth;
    font-size: 10px;
    -ms-overflow-style: none;  /* IE and old Edge */
    scrollbar-width: none;     /* Firefox */
  }

  body {
    background:
      radial-gradient(circle at 20% 0%, rgb(252 1 1 / 0.10), transparent 35%),
      linear-gradient(to bottom, var(--color-surface), var(--color-surface-container-lowest) 70%);
    color: var(--color-on-background);
    font-family: var(--font-body);
    line-height: 1.5;
    overflow-x: hidden;
    -ms-overflow-style: none;  /* IE and old Edge */
    scrollbar-width: none;     /* Firefox */
  }

	html::-webkit-scrollbar,
	body::-webkit-scrollbar {
	  display: none;             /* Chrome, Safari, Opera */
	}

	/*
  html :where(.editor-styles-wrapper) :where([id^="block-"]) {
    line-height: 1.5;
  }

  html :where(.editor-styles-wrapper) :where([id^="block-"]),
  html :where(.editor-styles-wrapper) :where([id^="block-"])::before,
  html :where(.editor-styles-wrapper) :where([id^="block-"])::after,
  html :where(.editor-styles-wrapper) :where([id^="block-"])::backdrop {
    box-sizing: border-box;
    border: none;
    margin: 0;
    padding: 0;
  }

  html :where(body:not(.wp-admin)) *,
  html :where(body:not(.wp-admin)) ::before,
  html :where(body:not(.wp-admin)) ::after,
  html :where(body:not(.wp-admin)) ::backdrop {
    box-sizing: border-box;
  }

  body:not(.wp-admin) .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
    max-width: none;
  }

  body:not(.wp-admin) .entry-content > *,
  body:not(.wp-admin) .wp-site-blocks > * {
    margin-block-start: 0;
    margin-block-end: 0;
  }

  body:not(.wp-admin) .wp-block-group,
  body:not(.wp-admin) .wp-block-columns,
  body:not(.wp-admin) .wp-block-cover,
  body:not(.wp-admin) .wp-block-column {
    margin-block-start: 0;
    margin-block-end: 0;
  }
	*/
	
	a {
		text-decoration: none !important;
	}

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

  pre,
  code,
  kbd,
  samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  }

  a {
    color: inherit;
  }

  strong {
    font-weight: 700;
  }

  ::selection {
    background-color: var(--color-primary);
    color: white;
  }

  .material-symbols-outlined {
    font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
    display: inline-block;
    line-height: 1;
  }

  input,
  textarea,
  select,
  button {
    font: inherit;
  }

  input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    background: var(--color-surface-variant);
    height: 2px;
  }

  input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 12px;
    height: 12px;
    background: var(--color-primary-container);
    cursor: pointer;
    border-radius: 9999px;
  }

  input[type="range"]::-moz-range-thumb {
    width: 12px;
    height: 12px;
    background: var(--color-primary-container);
    cursor: pointer;
    border: 0;
    border-radius: 9999px;
  }

  .km-page {
    min-height: 100dvh;
    background:
      radial-gradient(circle at 75% 25%, rgb(255 85 65 / 0.12), transparent 20%),
      radial-gradient(circle at 20% 10%, rgb(252 1 1 / 0.08), transparent 24%),
      linear-gradient(to bottom, var(--color-surface), var(--color-surface-container-lowest) 72%);
  }
}

/* -------------------------------------------------------------------------- */
/* Components                                                                  */
/* -------------------------------------------------------------------------- */

@layer components {
  /* ---------------------------------------------------------------------- */
  /* Aliases                                                                  */
  /* ---------------------------------------------------------------------- */

  .text-kinetic-red { color: var(--color-primary); }
  .bg-kinetic-red { background-color: var(--color-primary); }
  .border-kinetic-red { border-color: var(--color-primary); }

  /* ---------------------------------------------------------------------- */
  /* Layout shells                                                            */
  /* ---------------------------------------------------------------------- */

  .page-shell {
    width: 100%;
    max-width: var(--site-width);
    margin-inline: auto;
    padding-inline: var(--spacing-gutter);
  }

  .page-shell--wide {
    width: 100%;
    max-width: var(--site-width-wide);
    margin-inline: auto;
    padding-inline: var(--spacing-gutter);
  }

  .page-shell--narrow {
    width: 100%;
    max-width: var(--site-width-narrow);
    margin-inline: auto;
    padding-inline: var(--spacing-gutter);
  }

  .page-shell--full {
    width: 100%;
    padding-inline: var(--spacing-gutter);
  }

  .section-shell {
    padding-inline: var(--spacing-gutter);
    padding-block: var(--spacing-section);
  }

  .section-shell-lg {
    padding-inline: var(--spacing-gutter);
    padding-block: var(--spacing-section-lg);
  }

  .section-stack {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-section);
  }

  .editorial-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--spacing-gutter);
  }

  .section-label {
    display: block;
    margin-block-end: 0.75rem;
    font-family: var(--font-label);
    font-size: 1.1rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-primary);
  }

  .section-heading {
    font-family: var(--font-headline);
    font-size: clamp(4rem, 6vw, 7.2rem);
    line-height: 0.9;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: white;
  }

  .section-copy {
    max-width: 44rem;
    font-size: 1.6rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 80%, transparent);
  }

  .section-rule {
    width: 2.5rem;
    height: 1px;
    background: var(--color-primary);
  }

  /* ---------------------------------------------------------------------- */
  /* Fixed navigation                                                         */
  /* ---------------------------------------------------------------------- */

  .site-nav {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 50;
    background: color-mix(in srgb, var(--color-surface) 90%, transparent);
    backdrop-filter: blur(20px);
    border-block-end: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
  }

  .site-nav__inner {
    width: 100%;
    max-width: var(--site-width);
    margin-inline: auto;
    padding-inline: var(--spacing-gutter);
    padding-block: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
  }

  .site-nav__group {
    display: flex;
    align-items: center;
    gap: 1rem;
  }

  .site-nav__brand {
    font-family: var(--font-headline);
    font-size: 2.4rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: var(--color-primary);
    text-decoration: none;
    transition: color 0.3s ease, transform 0.3s ease;
  }

  .site-nav__brand:hover {
    color: white;
    transform: translateX(2px);
  }

  .site-nav__divider {
    display: none;
    width: 1px;
    height: 1rem;
    background: rgb(255 255 255 / 0.10);
  }

  .site-nav__links {
    display: none;
    align-items: center;
    gap: 2rem;
  }

  .site-nav__link {
    position: relative;
    display: inline-flex;
    align-items: center;
    font-family: var(--font-headline);
    font-size: 1.1rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 72%, transparent);
    text-decoration: none;
    transition: color 0.3s ease, opacity 0.3s ease;
  }

  .site-nav__link::after {
    content: "";
    position: absolute;
    inset-inline-start: 0;
    inset-block-end: -0.4rem;
    width: 0;
    height: 1px;
    background: var(--color-primary);
    transition: width 0.3s ease;
  }

  .site-nav__link:hover {
    color: white;
  }

  .site-nav__link:hover::after,
  .site-nav__link--active::after {
    width: 100%;
  }

  .site-nav__link--active {
    color: var(--color-primary);
    font-weight: 900;
  }

  .site-nav__search {
    display: none;
    position: relative;
  }

  .site-nav__search-input {
    width: 16rem;
    border: 0;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: 0.625rem 3rem 0.625rem 1rem;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-secondary);
  }

  .site-nav__search-input::placeholder {
    color: color-mix(in srgb, var(--color-secondary) 35%, transparent);
  }

  .site-nav__search-input:focus {
    outline: none;
    box-shadow: 0 0 0 1px var(--color-primary);
  }

  .site-nav__search-keys {
    pointer-events: none;
    position: absolute;
    inset-inline-end: 0.75rem;
    inset-block-start: 50%;
    display: flex;
    gap: 0.25rem;
    transform: translateY(-50%);
  }

  .site-nav__search-key {
    border: 1px solid rgb(255 255 255 / 0.20);
    border-radius: var(--radius-sm);
    padding: 0.125rem 0.25rem;
    font-size: 0.8rem;
    line-height: 1;
    color: rgb(255 255 255 / 0.65);
  }

  .has-fixed-nav {
    padding-block-start: 6rem;
  }

  /* ---------------------------------------------------------------------- */
  /* Buttons                                                                  */
  /* ---------------------------------------------------------------------- */

  .btn-primary,
  .site-nav__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2.75rem;
    padding-inline: 1.5rem;
    padding-block: 0.625rem;
    background: var(--color-primary);
    color: var(--color-surface);
    border-radius: var(--radius-sm);
    font-family: var(--font-headline);
    font-size: 1.2rem;
    line-height: 1;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    border: none;
    outline: none;
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
    transition:
      transform 0.25s ease,
      background-color 0.25s ease,
      color 0.25s ease,
      letter-spacing 0.25s ease;
  }

  .btn-primary:hover,
  .site-nav__cta:hover {
    transform: translateY(-2px);
    background: white;
    color: var(--color-primary);
    letter-spacing: 0.18em;
  }

  .btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2.75rem;
    padding-inline: 1.5rem;
    padding-block: 0.625rem;
    background: transparent;
    color: white;
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 20%, transparent);
    border-radius: var(--radius-sm);
    font-family: var(--font-headline);
    font-size: 1.2rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    transition: border-color 0.25s ease, color 0.25s ease, transform 0.25s ease;
  }

  .btn-secondary:hover {
    transform: translateY(-2px);
    color: var(--color-primary);
    border-color: color-mix(in srgb, var(--color-primary) 30%, transparent);
  }

  .btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0;
    background: transparent;
    color: var(--color-primary);
    font-family: var(--font-headline);
    font-size: 1.2rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none !important;
	
    transition: color 0.25s ease;
  }

  .btn-ghost:hover {
    color: color-mix(in srgb, var(--color-secondary) 80%, transparent);
  }

  /* ---------------------------------------------------------------------- */
  /* Hero + feature                                                           */
  /* ---------------------------------------------------------------------- */

  .hero-panel {
    position: relative;
    overflow: hidden;
	height: 100dvh;
  }

  .hero-headline {
    max-width: 70rem;
    font-family: var(--font-headline);
    font-size: clamp(6.4rem, 12vw, 16rem);
    line-height: 0.82;
    font-weight: 900;
    letter-spacing: -0.06em;
    text-transform: uppercase;
    color: white;
  }

  .hero-copy {
    max-width: 28rem;
    font-size: 1.6rem;
    line-height: 1.75;
    color: color-mix(in srgb, var(--color-secondary) 80%, transparent);
  }

  .hero-copy--rail {
    border-inline-start: 1px solid color-mix(in srgb, var(--color-outline-variant) 20%, transparent);
    padding-inline-start: 1.5rem;
  }

  .feature-frame {
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
    box-shadow: var(--shadow-ambient);
  }

  .feature-media {
    position: relative;
    min-height: 26rem;
    background:
      radial-gradient(circle at center, rgb(255 255 255 / 0.14), transparent 28%),
      linear-gradient(135deg, rgb(12 14 16 / 0.85), rgb(12 14 16 / 0.35)),
      linear-gradient(180deg, var(--color-surface-container-low), var(--color-surface-container-lowest));
  }

  .feature-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgb(252 1 1 / 0.10);
  }

  .feature-copy {
    position: absolute;
    inset-inline: 0;
    inset-block-end: 0;
    z-index: 1;
    padding: var(--spacing-card);
  }

  .feature-kicker {
    margin-block-end: 1rem;
    display: block;
    font-family: var(--font-label);
    font-size: 1.1rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-primary);
  }

  .feature-title {
    font-family: var(--font-headline);
    font-size: clamp(4.4rem, 5vw, 6.4rem);
    line-height: 0.92;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: white;
  }

  .feature-meta {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 2rem;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: var(--spacing-card);
  }

  .stat-list {
    display: grid;
    gap: 1rem;
  }

  .stat-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding-block-end: 0.5rem;
    border-block-end: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
  }

  .stat-row__label {
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 50%, transparent);
  }

  .stat-row__value {
    font-family: var(--font-headline);
    font-size: 1.4rem;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    color: white;
  }

  /* ---------------------------------------------------------------------- */
  /* Cards / modules                                                          */
  /* ---------------------------------------------------------------------- */

  .module-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: var(--spacing-gutter);
  }

  .module-card,
  .surface-card {
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: var(--spacing-card);
  }

  .surface-card--compact {
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: var(--spacing-gutter);
  }

  .surface-panel,
  .form-panel {
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--color-surface-container-high) 50%, transparent);
    backdrop-filter: blur(12px);
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 10%, transparent);
    padding: var(--spacing-card);
  }

  .ghost-panel {
    border-radius: var(--radius-sm);
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
    background: color-mix(in srgb, var(--color-surface-bright) 90%, transparent);
    backdrop-filter: blur(20px);
  }

  .module-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 5rem;
    height: 5rem;
    margin-block-end: 2rem;
    border-radius: var(--radius-sm);
    border: 1px solid color-mix(in srgb, var(--color-primary) 20%, transparent);
    background: var(--color-surface-container);
    color: var(--color-primary-container);
  }

  .module-title {
    font-family: var(--font-headline);
    font-size: 2.8rem;
    line-height: 1;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    color: white;
  }

  .module-body {
    margin-block-start: 1rem;
    color: color-mix(in srgb, var(--color-secondary) 74%, transparent);
    line-height: 1.7;
  }

  /* ---------------------------------------------------------------------- */
  /* Marquee band                                                             */
  /* ---------------------------------------------------------------------- */

  .marquee-band {
    overflow: hidden;
    background: var(--color-surface-container-low);
    padding-block: 2rem;
  }

  .marquee-track {
    display: flex;
    width: max-content;
    white-space: nowrap;
	animation-name: marquee-horizontal;
	animation-duration: 25s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
  }

  .marquee-item {
    margin-inline: 1.25rem;
    font-family: var(--font-headline);
    font-size: clamp(4.8rem, 6vw, 7.2rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: rgb(255 255 255 / 0.10);
  }
	
  .vertical-marquee-panel {
    display: grid;
    grid-template-columns: 5.5rem minmax(0, 1fr);
    gap: 1.5rem;
    min-height: 32rem;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: 1.5rem;
  }

  .vertical-marquee-rail {
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-lowest);
	position: absolute;
  }

  .vertical-marquee-track {
    display: grid;
    gap: 2rem;
    padding: 1.5rem 0;
	animation-name: marquee-vertical;
	animation-duration: 25s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
  }

  .vertical-marquee-item {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-family: var(--font-headline);
    font-size: 2rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgb(255 255 255 / 0.18);
  }

  .vertical-marquee-text--active {
    color: var(--color-primary);
  }

  /* ---------------------------------------------------------------------- */
  /* Documentation                                                            */
  /* ---------------------------------------------------------------------- */

  .docs-layout {
    display: grid;
    gap: var(--spacing-gutter);
  }

  .docs-sidebar {
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
    padding: var(--spacing-card);
  }

  .docs-sidebar__section {
    display: grid;
    gap: 1rem;
  }

  .docs-sidebar__title {
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 45%, transparent);
  }

  .docs-sidebar__link {
    display: block;
    border-inline-start: 1px solid transparent;
    padding-inline-start: 0.75rem;
    font-size: 1.5rem;
    line-height: 1.5;
    color: color-mix(in srgb, var(--color-secondary) 70%, transparent);
    text-decoration: none;
    transition: color 0.2s ease, border-color 0.2s ease;
  }

  .docs-sidebar__link:hover {
    color: white;
  }

  .docs-sidebar__link--active {
    border-inline-start-color: var(--color-primary);
    color: white;
    font-family: var(--font-headline);
    font-weight: 700;
  }

  .docs-panel {
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
    padding: var(--spacing-card);
  }

  .docs-panel--strong {
    background: var(--color-surface-container-high);
  }

  .docs-kicker {
    display: inline-block;
    margin-block-end: 1.25rem;
    border-radius: var(--radius-sm);
    background: var(--color-primary);
    padding: 0.625rem 1rem;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-surface);
  }

  .docs-hero-title {
    font-family: var(--font-headline);
    font-size: clamp(4.8rem, 6vw, 8rem);
    line-height: 0.92;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: white;
  }

  .docs-section-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-block-end: 2rem;
  }

  .docs-section-title {
    font-family: var(--font-headline);
    font-size: 2.8rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: white;
  }

  .docs-table-wrap {
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-lowest);
  }

  .docs-table {
    width: 100%;
    border-collapse: collapse;
  }

  .docs-table thead {
    background: var(--color-surface-container-highest);
  }

  .docs-table th {
    padding: 1rem 1.25rem;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-align: left;
    text-transform: uppercase;
    color: rgb(255 255 255 / 0.80);
  }

  .docs-table td {
    padding: 1rem 1.25rem;
    border-top: 1px solid rgb(255 255 255 / 0.05);
    font-size: 1.5rem;
    line-height: 1.6;
    color: color-mix(in srgb, var(--color-secondary) 78%, transparent);
  }

  .docs-table td strong {
    font-family: var(--font-headline);
    color: var(--color-primary);
    text-transform: uppercase;
  }

  .docs-code {
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-lowest);
  }

  .docs-code__topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--color-surface-container-highest);
    padding: 0.875rem 1.25rem;
  }

  .docs-code__dots {
    display: flex;
    gap: 0.5rem;
  }

  .docs-code__dot {
    width: 0.625rem;
    height: 0.625rem;
    border-radius: 9999px;
    background: rgb(255 255 255 / 0.18);
  }

  .docs-code__dot--active {
    background: var(--color-primary);
  }

  .docs-code__label {
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 45%, transparent);
  }

  .docs-code pre {
    margin: 0;
    overflow-x: auto;
    padding: 1.25rem;
    font-size: 1.5rem;
    line-height: 1.9;
    color: color-mix(in srgb, var(--color-secondary) 88%, transparent);
  }

  .docs-nav-cards {
    display: grid;
    gap: 1rem;
  }

  .docs-nav-card {
    display: block;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
    padding: 1.5rem;
    text-decoration: none;
    transition: background-color 0.2s ease;
  }

  .docs-nav-card:hover {
    background: var(--color-surface-container-high);
  }

  .docs-nav-card__eyebrow {
    display: block;
    margin-block-end: 1rem;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 40%, transparent);
  }

  .docs-nav-card__title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-family: var(--font-headline);
    font-size: 1.8rem;
    line-height: 1;
    font-weight: 900;
    text-transform: uppercase;
    color: white;
  }
	
  .pill {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-surface);
    font-family: var(--font-headline);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .18em;
    font-weight: 900;
    padding: .6rem .95rem;
    border-radius: var(--radius);
  }

  /* ---------------------------------------------------------------------- */
  /* Content vessels                                                          */
  /* ---------------------------------------------------------------------- */

  .project-card {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }

  .project-card__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
  }

  .project-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s ease, opacity 0.7s ease, filter 0.7s ease;
    opacity: 0.84;
  }

  .project-card:hover .project-card__image {
    transform: scale(1.08);
    opacity: 1;
  }

  .project-card__title {
    margin-block-end: 1rem;
    font-family: var(--font-headline);
    font-size: clamp(3.2rem, 3vw, 4rem);
    line-height: 0.95;
    font-weight: 900;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: white;
    transition: color 0.25s ease;
  }

  .project-card:hover .project-card__title {
    color: var(--color-primary);
  }

  .project-card__meta {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
  }

  .project-card__meta-item {
    display: grid;
    gap: 0.25rem;
  }

  .project-card__meta-label {
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 45%, transparent);
  }

  .project-card__meta-value {
    font-family: var(--font-headline);
    font-size: 1.3rem;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    color: white;
  }

  .status-card {
    display: flex;
    min-height: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-lowest);
    padding: var(--spacing-card);
    text-align: center;
  }

  .status-card__ring {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);
    border-radius: 9999px;
  }

  .status-card__dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 9999px;
    background: var(--color-primary-container);
  }

  /* ---------------------------------------------------------------------- */
  /* Form patterns                                                            */
  /* ---------------------------------------------------------------------- */

  .field-grid {
    display: grid;
    gap: 2.5rem;
  }

  .field-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .field-label {
    display: block;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 50%, transparent);
    margin-block-end: 0.5rem;
  }

  .field-input {
    width: 100%;
    background: transparent;
    color: var(--color-on-surface);
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-outline) 30%, transparent);
    padding-block: 0.75rem;
    font-family: var(--font-body);
    font-size: 1.4rem;
    line-height: 1.4;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    outline: none;
    transition: border-color 0.2s ease, color 0.2s ease;
  }

  .field-input::placeholder {
    color: color-mix(in srgb, var(--color-secondary) 20%, transparent);
  }

  .field-input:focus {
    border-bottom-color: var(--color-primary-container);
  }

  .field-meta {
    font-family: var(--font-label);
    font-size: 1rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 50%, transparent);
    transition: color 0.2s ease;
  }

  .range-row {
    display: grid;
    gap: 1rem;
  }

  .range-row__top {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
  }

  .toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-block: 0.75rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-outline-variant) 20%, transparent);
  }

  .toggle {
    position: relative;
    display: inline-block;
    width: 2.5rem;
    height: 1.25rem;
    padding: 0.25rem;
    border-radius: 9999px;
    background: var(--color-surface-container);
  }

  .toggle__dot {
    display: block;
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 9999px;
    background: color-mix(in srgb, var(--color-secondary) 25%, transparent);
  }

  .toggle--active .toggle__dot {
    margin-inline-start: auto;
    background: var(--color-primary-container);
  }

  .contact-panel {
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-low);
    padding: var(--spacing-card);
  }

  .location-grid {
    display: grid;
    gap: 1.5rem;
  }

  .location-item {
    border-inline-start: 1px solid color-mix(in srgb, var(--color-outline-variant) 30%, transparent);
    padding-inline-start: 1.5rem;
  }

  .map-panel {
    overflow: hidden;
    border-radius: var(--radius-sm);
    background:
      linear-gradient(180deg, rgb(255 255 255 / 0.06), rgb(12 14 16 / 0.85)),
      radial-gradient(circle at 65% 35%, rgb(255 85 65 / 0.12), transparent 18%),
      linear-gradient(135deg, #2d3135, #111315);
    min-height: 16rem;
    padding: 1.5rem;
    display: flex;
    align-items: end;
  }

  /* ---------------------------------------------------------------------- */
  /* Social strip + footer                                                    */
  /* ---------------------------------------------------------------------- */

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

  .social-grid__item {
    display: flex;
    min-height: 14rem;
    flex-direction: column;
    justify-content: space-between;
    gap: 1rem;
    padding: 2rem;
    border-block-start: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
    border-inline-end: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
    text-decoration: none;
    transition: background-color 0.5s ease, color 0.5s ease;
  }

  .social-grid__item:hover {
    background: white;
    color: var(--color-surface-container-lowest);
  }

  .site-footer {
    background: var(--color-surface-container-lowest);
    border-block-start: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
    padding-block: var(--spacing-section-lg) var(--spacing-section);
  }

  .site-footer__inner {
    width: 100%;
    max-width: var(--site-width);
    margin-inline: auto;
    padding-inline: var(--spacing-gutter);
    display: grid;
    gap: 3rem;
  }

  .site-footer__brand {
    font-family: var(--font-headline);
    font-size: 3.2rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: white;
  }

  .site-footer__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, max-content));
    gap: 0.75rem 2rem;
  }

  .site-footer__link {
    font-family: var(--font-headline);
    font-size: 1rem;
    line-height: 1;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 50%, transparent);
    text-decoration: none;
    transition: color 0.25s ease;
  }

  .site-footer__link:hover {
    color: var(--color-primary);
  }

  .site-footer__meta {
    font-family: var(--font-headline);
    font-size: 1rem;
    line-height: 1.2;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgb(255 255 255 / 0.40);
  }

  /* ---------------------------------------------------------------------- */
  /* Responsive                                                               */
  /* ---------------------------------------------------------------------- */

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

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

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

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

    .site-footer__inner {
      grid-template-columns: 1fr auto;
      align-items: end;
      justify-content: space-between;
    }
  }

  @media (min-width: 1024px) {
    .site-nav__search {
      display: block;
    }

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

  @media (min-width: 1280px) {
    .site-nav__divider,
    .site-nav__links {
      display: flex;
    }

    .docs-layout {
      grid-template-columns: 18rem minmax(0, 1fr) 15rem;
    }
  }
}

/* -------------------------------------------------------------------------- */
/* Utilities                                                                   */
/* -------------------------------------------------------------------------- */

@layer utilities {
  .animate-marquee-horizontal {
    animation: var(--animate-marquee-horizontal);
	animation-duration: 25s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
  }

  .animate-marquee-vertical {
    animation: var(--animate-marquee-vertical);
	animation-duration: 25s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
  }

  .scroll-blur-fade {
    animation: blur-fade-out linear both;
    animation-timeline: scroll();
    animation-range: exit 0% exit 100%;
  }

  .hover-lift {
    transition:
      transform 0.6s cubic-bezier(0.16, 1, 0.3, 1),
      border-color 0.3s ease,
      color 0.3s ease;
  }

  .hover-lift:hover {
    transform: translateY(-8px);
  }

  .kinetic-text-split {
    display: inline-block;
    transition:
      transform 0.6s cubic-bezier(0.16, 1, 0.3, 1),
      letter-spacing 0.6s cubic-bezier(0.16, 1, 0.3, 1),
      color 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  }

  .kinetic-text-split:hover {
    letter-spacing: 0.2em;
    transform: scaleX(1.05);
    color: var(--color-primary-container);
  }

  .blur-on-scroll {
    filter: blur(0);
    transition: filter 0.3s ease;
  }

  .blur-on-scroll:hover {
    filter: blur(4px);
  }

  .text-display-large {
    font-size: var(--text-display-large);
    line-height: var(--text-display-large--line-height);
    letter-spacing: var(--text-display-large--letter-spacing);
  }

  .text-headline-medium {
    font-size: var(--text-headline-medium);
    line-height: var(--text-headline-medium--line-height);
  }

  .text-body-large {
    font-size: var(--text-body-large);
    line-height: var(--text-body-large--line-height);
  }

  .text-label-small {
    font-size: var(--text-label-small);
    line-height: var(--text-label-small--line-height);
    letter-spacing: var(--text-label-small--letter-spacing);
    text-transform: uppercase;
  }

  .text-huge {
    font-size: clamp(4.8rem, 12vw, 16rem);
    line-height: 0.85;
  }

  .text-medium-huge {
    font-size: clamp(3.2rem, 6vw, 7.2rem);
    line-height: 1;
  }

  .text-stroke {
    -webkit-text-stroke: 1px rgb(252 1 1 / 0.35);
    color: transparent !important;
  }

  .stack-card {
    gap: var(--spacing-card);
  }

  .stack-section {
    gap: var(--spacing-section);
  }

  .pad-gutter {
    padding: var(--spacing-gutter);
  }

  .pad-card {
    padding: var(--spacing-card);
  }

  .pad-section {
    padding: var(--spacing-section);
  }

  .pad-section-lg {
    padding: var(--spacing-section-lg);
  }

  .no-scrollbar::-webkit-scrollbar {
    display: none;
  }

  .sidebar-scrollbar::-webkit-scrollbar {
    width: 2px;
    height: 2px;
  }

  .sidebar-scrollbar::-webkit-scrollbar-track {
    background: rgb(255 255 255 / 0.05);
  }

  .sidebar-scrollbar::-webkit-scrollbar-thumb {
    background: var(--color-primary);
  }

  .glass-surface {
    background-color: color-mix(in srgb, var(--color-surface-bright) 90%, transparent);
    backdrop-filter: blur(20px);
  }

  .ghost-border {
    border: 1px solid color-mix(in srgb, var(--color-outline-variant) 15%, transparent);
  }

  .grid-mesh {
    background-image:
      linear-gradient(to right, rgb(255 255 255 / 0.03) 1px, transparent 1px),
      linear-gradient(to bottom, rgb(255 255 255 / 0.03) 1px, transparent 1px);
    background-size: 40px 40px;
  }

  .kinetic-gradient {
    background:
      radial-gradient(circle at top right, rgb(255 85 65 / 0.18), transparent 24%),
      radial-gradient(circle at 20% 10%, rgb(252 1 1 / 0.14), transparent 28%);
  }

  .shadow-ambient {
    box-shadow: var(--shadow-ambient);
  }

  .text-muted {
    color: color-mix(in srgb, var(--color-secondary) 70%, transparent);
  }

  .text-meta {
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.2em;
    text-transform: uppercase;
  }
	
	.km-demo__surface-low {
    background: var(--color-surface-container-low);
  }

  .km-demo__surface-lowest {
    background: var(--color-surface-container-lowest);
  }

  .km-demo__hero-top,
  .km-demo__hero-bottom,
  .km-demo__content-grid,
  .km-demo__contact-grid {
    display: grid;
    gap: var(--spacing-gutter);
  }

  .km-demo__hero-top {
    align-items: end;
    margin-block-end: clamp(3.2rem, 5vw, 4.8rem);
  }

  .km-demo__hero-rail {
    display: flex;
    align-items: end;
  }

  .km-demo__feature-card {
    min-height: 100%;
  }

  .km-demo__feature-row {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }

  .km-demo__feature-copy,
  .km-demo__docs-copy,
  .km-demo__body-copy {
    font-size: 1.6rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 78%, transparent);
  }

  .km-demo__feature-copy {
    margin-block-start: 1.5rem;
    max-width: 48rem;
  }

  .km-demo__inline-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-headline);
    font-size: 1.1rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-primary);
    text-decoration: none;
    transition: color 0.25s ease, transform 0.25s ease;
  }

  .km-demo__inline-link:hover {
    color: white;
  }

  .km-demo__section-head {
    display: grid;
    gap: 2rem;
    align-items: end;
    margin-block-end: clamp(3rem, 5vw, 5rem);
  }

  .km-demo__head-copy {
    max-width: 34rem;
    font-size: 1.4rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 65%, transparent);
  }

  .km-demo__module-eyebrow,
  .km-demo__muted-label,
  .km-demo__channel-label,
  .km-demo__meta-label {
    display: block;
    font-family: var(--font-label);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-secondary) 45%, transparent);
  }

  .km-demo__module-eyebrow {
    margin-block-end: 2.5rem;
  }

  .km-demo__marquee-wrap {
    display: flex;
    width: max-content;
  }

  .km-demo__docs-head {
    max-width: 84rem;
    margin-block-end: clamp(3rem, 5vw, 5rem);
  }

  .km-demo__docs-copy {
    max-width: 72rem;
    margin-block-start: 2rem;
  }

  .km-demo__docs-stack {
    display: grid;
    gap: 3.5rem;
  }

  .km-demo__aside-card {
    margin-block-start: 2.5rem;
    border-radius: var(--radius-sm);
    background: var(--color-surface-container-high);
    padding: 1.5rem;
  }

  .km-demo__aside-copy {
    margin-block: 1rem 1.5rem;
    font-size: 1.4rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 65%, transparent);
  }

  .km-demo__docs-toc {
    display: none;
  }

  .km-demo__content-copy {
    max-width: 56rem;
    margin-block-start: 2rem;
  }

  .km-demo__vessel-grid {
    display: grid;
    gap: var(--spacing-gutter);
    margin-block-start: clamp(3rem, 6vw, 5rem);
  }

  .km-demo__text-vessel {
    display: flex;
    min-height: 100%;
    aspect-ratio: 3 / 4;
    flex-direction: column;
    justify-content: space-between;
  }

  .km-demo__vessel-title {
    font-family: var(--font-headline);
    font-size: 3rem;
    line-height: 0.98;
    font-weight: 900;
    text-transform: uppercase;
    color: white;
    transition: color 0.25s ease;
  }

  .km-demo__text-vessel:hover .km-demo__vessel-title {
    color: var(--color-primary);
  }

  .km-demo__vessel-copy {
    margin-block-start: 1.5rem;
    font-size: 1.4rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 65%, transparent);
  }

  .km-demo__strategy-vessel {
    overflow: hidden;
    padding: 0;
  }

  .km-demo__strategy-head {
    padding: 1.5rem 1.5rem 0;
  }

  .km-demo__mini-marquee {
    margin-block-start: 4rem;
    padding-block: 1.25rem;
    background: var(--color-surface-container);
  }

  .km-demo__mini-marquee .marquee-item {
    margin-inline: 1rem;
    font-size: 3rem;
  }

  .km-demo__vertical-copy {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 2rem;
  }

  .km-demo__checklist {
    margin: 1.5rem 0 0;
    padding-inline-start: 1.8rem;
    font-size: 1.4rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 75%, transparent);
  }

  .km-demo__checklist li + li {
    margin-block-start: 0.75rem;
  }

  .km-demo__brief-panel {
    padding: clamp(3rem, 4vw, 4.8rem);
  }

  .km-demo__form-stack {
    display: grid;
    gap: 4rem;
  }

  .field-textarea {
    min-height: 12rem;
    resize: none;
  }

  .km-demo__select-wrap {
    position: relative;
  }

  .km-demo__field-select {
    appearance: none;
    -webkit-appearance: none;
    padding-inline-end: 2rem;
  }

  .km-demo__select-icon {
    pointer-events: none;
    position: absolute;
    inset-inline-end: 0;
    inset-block-start: 50%;
    transform: translateY(-50%);
    color: color-mix(in srgb, var(--color-secondary) 35%, transparent);
  }

  .km-demo__toggle-label {
    font-family: var(--font-headline);
    font-size: 1.1rem;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: white;
  }

  .km-demo__contact-side {
    display: grid;
    gap: var(--spacing-gutter);
    align-content: start;
  }

  .km-demo__channel-link {
    font-family: var(--font-headline);
    font-size: clamp(2.4rem, 4vw, 3.4rem);
    line-height: 0.98;
    font-weight: 900;
    letter-spacing: -0.04em;
    text-transform: uppercase;
    color: white;
    text-decoration: none;
    transition: color 0.25s ease;
  }

  .km-demo__channel-link:hover {
    color: var(--color-primary);
  }

  .km-demo__channel-stack {
    display: grid;
    gap: 2.5rem;
  }

  .km-demo__location-grid {
    display: grid;
    gap: 1.5rem;
  }

  .km-demo__location-title {
    font-family: var(--font-headline);
    font-size: 2rem;
    line-height: 1;
    font-weight: 900;
    text-transform: uppercase;
    color: white;
  }

  .km-demo__location-copy {
    margin-block-start: 1rem;
    font-size: 1.4rem;
    line-height: 1.7;
    color: color-mix(in srgb, var(--color-secondary) 65%, transparent);
  }

  .km-demo__map-shell {
    padding: 0.5rem;
  }

  .km-demo__footer-right {
    display: grid;
    gap: 1rem;
    text-align: left;
  }

  @media (min-width: 768px) {
    .km-demo__feature-row {
      flex-direction: row;
      align-items: end;
      justify-content: space-between;
    }

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

    .km-demo__footer-right {
      text-align: right;
    }
  }

  @media (min-width: 1024px) {
    .km-demo__section-head {
      grid-template-columns: minmax(0, 1fr) minmax(28rem, 34rem);
    }

    .km-demo__head-copy {
      justify-self: end;
    }

    .km-demo__content-grid,
    .km-demo__contact-grid {
      grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    }
  }

  @media (min-width: 1280px) {
    .km-demo__hero-top,
    .km-demo__hero-bottom {
      grid-template-columns: repeat(12, minmax(0, 1fr));
    }

    .km-demo__hero-main,
    .km-demo__feature-span {
      grid-column: span 8;
    }

    .km-demo__hero-rail,
    .km-demo__meta-span {
      grid-column: span 4;
    }

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

    .km-demo__docs-toc {
      display: block;
    }
}