:root {
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl: clamp(2.7rem, 1rem + 5vw, 6.5rem);

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

  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;
  --transition-interactive: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  --content-narrow: 640px;
  --content-default: 960px;
  --content-wide: 1180px;

  --font-display: 'Cabinet Grotesk', 'Arial', sans-serif;
  --font-body: 'Satoshi', 'Inter', sans-serif;
}

:root,
[data-theme='light'] {
  --color-bg: #f6f8fb;
  --color-surface: #ffffff;
  --color-surface-2: #f0f5fa;
  --color-surface-offset: #e8f0f7;
  --color-surface-offset-2: #dce8f2;
  --color-surface-dynamic: #d2e2ef;
  --color-divider: #d7e3ec;
  --color-border: #c7d6e3;
  --color-text: #101216;
  --color-text-muted: #5d6670;
  --color-text-faint: #8c98a5;
  --color-text-inverse: #ffffff;
  --color-primary: #047cbd;
  --color-primary-hover: #005f97;
  --color-primary-active: #04486f;
  --color-primary-highlight: #d7efff;
  --color-ink: #050607;
  --color-success: #2d7b4f;
  --color-warning: #9b5a18;
  --color-error: #ae2d52;
  --shadow-sm: 0 1px 2px oklch(0.25 0.04 240 / 0.06);
  --shadow-md: 0 8px 24px oklch(0.25 0.04 240 / 0.08);
  --shadow-lg: 0 24px 72px oklch(0.25 0.04 240 / 0.14);
}

[data-theme='dark'] {
  --color-bg: #080a0d;
  --color-surface: #11151b;
  --color-surface-2: #161c24;
  --color-surface-offset: #1d2630;
  --color-surface-offset-2: #263341;
  --color-surface-dynamic: #2f4252;
  --color-divider: #25303a;
  --color-border: #33404d;
  --color-text: #f4f7fa;
  --color-text-muted: #a9b3bd;
  --color-text-faint: #71808e;
  --color-text-inverse: #07090c;
  --color-primary: #28aeee;
  --color-primary-hover: #63c8ff;
  --color-primary-active: #9bdcff;
  --color-primary-highlight: #123244;
  --color-ink: #000000;
  --color-success: #77c69b;
  --color-warning: #dfad64;
  --color-error: #f07291;
  --shadow-sm: 0 1px 2px oklch(0 0 0 / 0.25);
  --shadow-md: 0 10px 28px oklch(0 0 0 / 0.34);
  --shadow-lg: 0 24px 72px oklch(0 0 0 / 0.46);
}

.skip-link {
  position: fixed;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 100;
  transform: translateY(-140%);
  border-radius: var(--radius-full);
  background: var(--color-text);
  color: var(--color-bg);
  padding: var(--space-2) var(--space-4);
  text-decoration: none;
}

.skip-link:focus {
  transform: translateY(0);
}

body {
  overflow-x: hidden;
}

main {
  overflow: hidden;
}

.page-shell {
  min-height: 100dvh;
  background:
    radial-gradient(circle at 80% 10%, color-mix(in oklab, var(--color-primary) 18%, transparent), transparent 28rem),
    linear-gradient(180deg, var(--color-bg), var(--color-surface-2) 48%, var(--color-bg));
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid oklch(from var(--color-text) l c h / 0.1);
  background: color-mix(in oklab, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(16px);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: min(100% - var(--space-8), var(--content-wide));
  margin-inline: auto;
  padding-block: var(--space-3);
}

.brand-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text);
  text-decoration: none;
}

.brand-link img {
  width: 4.7rem;
  height: auto;
  border-radius: var(--radius-sm);
  mix-blend-mode: multiply;
}

[data-theme='dark'] .brand-link img {
  filter: invert(1) hue-rotate(180deg) saturate(1.15);
  mix-blend-mode: screen;
}

.brand-text {
  display: none;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.nav-links {
  display: none;
  align-items: center;
  gap: var(--space-4);
}

.nav-links a {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
}

.nav-links a:hover {
  color: var(--color-text);
}

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

.theme-toggle,
.menu-toggle {
  display: inline-grid;
  width: 2.75rem;
  height: 2.75rem;
  place-items: center;
  border: 1px solid oklch(from var(--color-text) l c h / 0.12);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-surface) 78%, transparent);
}

.menu-toggle {
  color: var(--color-text);
}

.btn {
  display: inline-flex;
  min-height: 2.75rem;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: 700;
  text-decoration: none;
}

.btn-primary {
  background: var(--color-text);
  color: var(--color-bg);
}

.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-secondary {
  border: 1px solid oklch(from var(--color-text) l c h / 0.14);
  background: color-mix(in oklab, var(--color-surface) 82%, transparent);
  color: var(--color-text);
}

.btn-secondary:hover {
  border-color: oklch(from var(--color-primary) l c h / 0.42);
  color: var(--color-primary);
}

.mobile-menu {
  display: none;
  width: min(100% - var(--space-8), var(--content-wide));
  margin-inline: auto;
  padding: 0 0 var(--space-4);
}

.mobile-menu.is-open {
  display: grid;
  gap: var(--space-2);
}

.mobile-menu a {
  border-radius: var(--radius-lg);
  color: var(--color-text);
  padding: var(--space-3) var(--space-4);
  text-decoration: none;
}

.mobile-menu a:hover {
  background: var(--color-surface);
}

.container {
  width: min(100% - var(--space-8), var(--content-wide));
  margin-inline: auto;
}

.hero {
  display: grid;
  min-height: calc(100dvh - 4.75rem);
  align-items: center;
  gap: var(--space-10);
  padding-block: clamp(var(--space-16), 12vw, var(--space-32));
  position: relative;
  isolation: isolate;
}

.hero::before {
  position: absolute;
  inset: var(--space-6) 50% auto auto;
  z-index: -1;
  width: min(100vw, 100rem);
  height: min(60rem, 100%);
  pointer-events: none;
  background:
    linear-gradient(90deg, var(--color-bg) 0%, transparent 22%, transparent 78%, var(--color-bg) 100%),
    url('./assets/cover-background.svg') center / cover no-repeat;
  content: '';
  transform: translateX(50%);
  opacity: 0.92;
  mask-image: linear-gradient(to bottom, black 0%, black 68%, transparent 100%);
}

[data-theme='dark'] .hero::before {
  opacity: 0.62;
  mix-blend-mode: screen;
}

.eyebrow {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: var(--space-2);
  border: 1px solid oklch(from var(--color-primary) l c h / 0.24);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-primary-highlight) 72%, transparent);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: var(--space-2) var(--space-3);
  text-transform: uppercase;
}

.eyebrow::before {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: var(--radius-full);
  background: currentColor;
  content: '';
}

.hero-copy {
  display: grid;
  gap: var(--space-6);
}

h1 {
  max-width: 12ch;
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 800;
  letter-spacing: -0.06em;
}

.hero-lede {
  color: var(--color-text-muted);
  font-size: var(--text-lg);
  line-height: 1.45;
  max-width: 48ch;
}

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

.hero-panel {
  display: grid;
  place-items: center;
  border: 1px solid oklch(from var(--color-text) l c h / 0.12);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 72% 18%, color-mix(in oklab, var(--color-primary) 14%, transparent), transparent 16rem),
    color-mix(in oklab, var(--color-surface) 88%, transparent);
  box-shadow: var(--shadow-lg);
  padding: clamp(var(--space-5), 4vw, var(--space-8));
}

.panel-logo {
  display: grid;
  width: 100%;
  min-height: clamp(16rem, 32vw, 24rem);
  place-items: center;
  border-radius: calc(var(--radius-xl) - var(--space-2));
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 10%, transparent), transparent),
    var(--color-surface);
  padding: clamp(var(--space-8), 6vw, var(--space-16));
}

.panel-logo img {
  width: min(100%, 30rem);
  border-radius: var(--radius-sm);
  mix-blend-mode: multiply;
}

[data-theme='dark'] .panel-logo img {
  filter: invert(1) hue-rotate(180deg) saturate(1.15);
  mix-blend-mode: screen;
}

.section {
  padding-block: clamp(var(--space-12), 8vw, var(--space-24));
  position: relative;
  scroll-margin-top: 6rem;
}

.section.tight {
  padding-block: clamp(var(--space-8), 5vw, var(--space-16));
}

.section-header {
  display: grid;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.section-header h2 {
  max-width: 16ch;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: -0.045em;
}

.section-header p {
  color: var(--color-text-muted);
}

#services {
  border-top: 1px solid oklch(from var(--color-text) l c h / 0.08);
  border-bottom: 1px solid oklch(from var(--color-text) l c h / 0.08);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--color-surface) 72%, transparent), transparent),
    repeating-linear-gradient(90deg, transparent 0 4rem, oklch(from var(--color-text) l c h / 0.035) 4rem 4.05rem);
}

#projects {
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary-highlight) 76%, transparent), transparent 46%),
    linear-gradient(180deg, var(--color-surface), color-mix(in oklab, var(--color-surface-offset) 64%, transparent));
  box-shadow: inset 0 0 0 1px oklch(from var(--color-text) l c h / 0.08);
  padding-inline: clamp(var(--space-5), 4vw, var(--space-8));
}

#work {
  background:
    radial-gradient(circle at 12% 18%, color-mix(in oklab, var(--color-primary) 9%, transparent), transparent 18rem),
    linear-gradient(180deg, transparent, color-mix(in oklab, var(--color-surface-2) 70%, transparent));
}

#rates {
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-text) 6%, transparent), transparent 50%),
    var(--color-surface);
  box-shadow: inset 0 0 0 1px oklch(from var(--color-text) l c h / 0.08);
  padding-inline: clamp(var(--space-5), 4vw, var(--space-8));
}

#contact {
  border-top: 1px solid oklch(from var(--color-text) l c h / 0.08);
  background:
    radial-gradient(circle at 80% 24%, color-mix(in oklab, var(--color-primary) 12%, transparent), transparent 18rem),
    linear-gradient(180deg, color-mix(in oklab, var(--color-surface-2) 72%, transparent), transparent);
}

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

.service-list {
  display: grid;
  gap: var(--space-3);
}

.service-item {
  display: grid;
  gap: var(--space-2);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  padding: var(--space-5);
}

.service-item h3,
.work-card h3,
.rate-card h3 {
  font-size: var(--text-lg);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.service-item p,
.work-card p,
.rate-card p,
.rate-card li {
  color: var(--color-text-muted);
}

.note-card {
  align-self: start;
  border-radius: var(--radius-xl);
  background: var(--color-text);
  color: var(--color-bg);
  padding: clamp(var(--space-6), 4vw, var(--space-10));
}

.note-card .label {
  color: color-mix(in oklab, var(--color-bg) 72%, transparent);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.note-card p {
  margin-top: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.2;
}

.note-photo {
  width: 100%;
  height: clamp(13rem, 24vw, 18rem);
  margin-top: var(--space-6);
  border: 1px solid color-mix(in oklab, var(--color-bg) 16%, transparent);
  border-radius: var(--radius-lg);
  object-fit: cover;
  opacity: 0.92;
}

.work-grid {
  display: grid;
  gap: var(--space-4);
}

.work-card {
  display: grid;
  min-height: 15rem;
  align-content: end;
  gap: var(--space-3);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, transparent, color-mix(in oklab, var(--color-surface) 92%, transparent)),
    var(--color-surface);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
}

.work-card::before {
  position: absolute;
  inset: var(--space-5) var(--space-5) auto auto;
  width: 5rem;
  height: 5rem;
  border: 1px solid oklch(from var(--color-primary) l c h / 0.18);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-primary) 12%, transparent);
  content: '';
}

.work-card > * {
  position: relative;
}

.work-card.featured {
  background:
    linear-gradient(140deg, color-mix(in oklab, var(--color-primary) 22%, transparent), transparent 55%),
    var(--color-surface);
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.tag {
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: var(--space-1) var(--space-3);
}

.work-carousel {
  display: grid;
  gap: var(--space-5);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 88% 12%, color-mix(in oklab, var(--color-primary) 18%, transparent), transparent 18rem),
    linear-gradient(145deg, var(--color-surface), var(--color-surface-2));
  box-shadow: var(--shadow-sm);
  margin-top: var(--space-5);
  overflow: hidden;
  padding: clamp(var(--space-5), 4vw, var(--space-8));
}

.carousel-topline {
  display: grid;
  gap: var(--space-4);
  align-items: center;
}

.carousel-topline p {
  max-width: 52ch;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-top: var(--space-2);
}

.label {
  display: inline-flex;
  width: fit-content;
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-primary-highlight) 70%, transparent);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  padding: var(--space-2) var(--space-3);
  text-transform: uppercase;
}

.carousel-controls {
  display: flex;
  gap: var(--space-2);
}

.carousel-button {
  display: grid;
  width: 2.75rem;
  height: 2.75rem;
  place-items: center;
  border: 1px solid oklch(from var(--color-text) l c h / 0.12);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
  font-size: 1.65rem;
  font-weight: 900;
  line-height: 1;
  transition: transform var(--transition-interactive), border-color var(--transition-interactive), color var(--transition-interactive);
}

.carousel-button:hover,
.carousel-button:focus-visible {
  border-color: var(--color-primary);
  color: var(--color-primary);
  transform: translateY(-1px);
}

.carousel-stage {
  position: relative;
  overflow: hidden;
}

.work-slide {
  display: grid;
  gap: var(--space-6);
  align-items: stretch;
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateX(2.5rem);
  transition: opacity 420ms ease, transform 420ms cubic-bezier(0.16, 1, 0.3, 1);
}

.work-slide.is-active {
  position: relative;
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.slide-copy {
  display: grid;
  align-content: center;
  gap: var(--space-4);
}

.slide-copy h3 {
  max-width: 18ch;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 900;
  letter-spacing: -0.05em;
  line-height: 1.02;
}

.slide-copy p:not(.eyebrow) {
  max-width: 56ch;
  color: var(--color-text-muted);
}

.slide-visual {
  min-height: clamp(20rem, 45vw, 31rem);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: calc(var(--radius-xl) - var(--space-2));
  box-shadow: var(--shadow-md);
  overflow: hidden;
  position: relative;
  isolation: isolate;
}

.portfolio-preview {
  display: grid;
  aspect-ratio: 1 / 1;
  margin: 0;
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: calc(var(--radius-xl) - var(--space-2));
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 8%, transparent), transparent 48%),
    var(--color-surface);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  position: relative;
}

.portfolio-preview.landscape {
  aspect-ratio: 4 / 3;
  align-self: center;
}

.portfolio-preview img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.portfolio-preview.document img {
  padding: var(--space-4);
  background:
    linear-gradient(180deg, var(--color-surface-2), var(--color-surface)),
    var(--color-surface);
  object-fit: contain;
}

.portfolio-preview.landscape img {
  padding: var(--space-4);
  background:
    radial-gradient(circle at 18% 12%, color-mix(in oklab, var(--color-primary) 12%, transparent), transparent 13rem),
    linear-gradient(180deg, var(--color-surface-2), var(--color-surface)),
    var(--color-surface);
  object-fit: contain;
  object-position: center;
}

.portfolio-preview figcaption {
  position: absolute;
  right: var(--space-4);
  bottom: var(--space-4);
  max-width: calc(100% - var(--space-8));
  border: 1px solid oklch(1 0 0 / 0.2);
  border-radius: var(--radius-full);
  background: oklch(0.12 0.02 245 / 0.78);
  color: white;
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.04em;
  padding: var(--space-2) var(--space-3);
  text-transform: uppercase;
}

.slide-visual::after {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, transparent 0 45%, oklch(1 0 0 / 0.08) 46%, transparent 58%),
    radial-gradient(circle at 12% 92%, oklch(1 0 0 / 0.18), transparent 12rem);
  content: '';
  pointer-events: none;
  z-index: 1;
}

.slide-visual.softwave {
  background:
    radial-gradient(circle at 25% 22%, #a8e4ff, transparent 10rem),
    linear-gradient(135deg, #08223b, #075b87 48%, #dff7ff);
}

.slide-visual.redlight {
  background:
    radial-gradient(circle at 58% 36%, #fff0c8, transparent 8rem),
    radial-gradient(circle at 70% 58%, #ff4f42, transparent 13rem),
    linear-gradient(145deg, #210b13, #8b1f22 48%, #ffd4a8);
}

.slide-visual.funnels {
  background:
    linear-gradient(90deg, oklch(1 0 0 / 0.08) 1px, transparent 1px),
    linear-gradient(0deg, oklch(1 0 0 / 0.08) 1px, transparent 1px),
    linear-gradient(135deg, #0a1826, #0b5b83);
  background-size: 3rem 3rem, 3rem 3rem, auto;
}

.slide-visual.ai-system {
  background:
    radial-gradient(circle at 28% 30%, #2fc7ff, transparent 9rem),
    linear-gradient(145deg, #030914, #0b2541 58%, #101216);
}

.slide-visual.consulting {
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 80% 18%, color-mix(in oklab, var(--color-primary) 42%, transparent), transparent 14rem),
    linear-gradient(145deg, var(--color-surface-2), var(--color-surface));
  padding: var(--space-5);
}

.mock-browser {
  display: flex;
  gap: var(--space-2);
  position: absolute;
  top: var(--space-5);
  left: var(--space-5);
  right: var(--space-5);
  height: 2.2rem;
  border-radius: var(--radius-full);
  background: oklch(1 0 0 / 0.78);
  padding: 0.72rem var(--space-4);
  z-index: 2;
}

.mock-browser span {
  width: 0.7rem;
  height: 0.7rem;
  border-radius: var(--radius-full);
  background: #047cbd;
}

.pulse-line {
  position: absolute;
  top: 48%;
  left: 8%;
  width: 84%;
  height: 0.35rem;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, transparent, #ffffff, #52d6ff, #ffffff, transparent);
  box-shadow: 0 0 28px #74ddff;
  z-index: 2;
}

.glow-orb {
  position: absolute;
  inset: 13% 14% auto auto;
  width: 11rem;
  height: 11rem;
  border-radius: var(--radius-full);
  background: radial-gradient(circle, #fff8d7, #ff5b44 58%, transparent 70%);
  filter: blur(0.5px);
  z-index: 1;
}

.visual-card {
  position: absolute;
  z-index: 3;
  border: 1px solid oklch(1 0 0 / 0.24);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.86);
  box-shadow: var(--shadow-lg);
  color: #101216;
  padding: var(--space-4);
}

.main-card {
  left: var(--space-5);
  bottom: var(--space-5);
  width: min(18rem, calc(100% - var(--space-10)));
}

.main-card strong,
.score-card strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.main-card p {
  color: #48515a;
  font-size: var(--text-sm);
  margin-top: var(--space-2);
}

.small-card {
  right: var(--space-5);
  top: 36%;
  font-size: var(--text-sm);
  font-weight: 900;
}

.flow-node {
  display: grid;
  width: 7.4rem;
  height: 4.5rem;
  place-items: center;
  border: 1px solid oklch(1 0 0 / 0.28);
  border-radius: var(--radius-lg);
  background: oklch(1 0 0 / 0.88);
  box-shadow: var(--shadow-md);
  color: #101216;
  font-weight: 900;
  position: absolute;
  z-index: 3;
}

.node-one { top: 18%; left: 9%; }
.node-two { top: 42%; left: 30%; }
.node-three { top: 24%; right: 22%; }
.node-four { bottom: 15%; right: 8%; }

.flow-line {
  position: absolute;
  height: 0.25rem;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, #7edbff, #ffffff);
  box-shadow: 0 0 22px #47c5ff;
  transform-origin: left center;
  z-index: 2;
}

.line-one {
  top: 38%;
  left: 22%;
  width: 44%;
  transform: rotate(12deg);
}

.line-two {
  top: 55%;
  left: 43%;
  width: 42%;
  transform: rotate(-18deg);
}

.ai-grid {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, oklch(1 0 0 / 0.08) 1px, transparent 1px),
    linear-gradient(0deg, oklch(1 0 0 / 0.08) 1px, transparent 1px);
  background-size: 2rem 2rem;
  mask-image: radial-gradient(circle, black, transparent 75%);
  z-index: 1;
}

.score-card {
  display: grid;
  gap: var(--space-2);
  position: relative;
  width: min(100%, 23rem);
  color: var(--color-text);
}

.score-card span {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 800;
  margin-top: var(--space-2);
}

.score-bar {
  height: 0.65rem;
  border-radius: var(--radius-full);
  background: var(--color-surface-offset);
  overflow: hidden;
}

.score-bar i {
  display: block;
  width: 78%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover));
}

.score-bar:nth-of-type(2) i {
  width: 68%;
}

.score-bar:nth-of-type(3) i {
  width: 84%;
}

.carousel-dots {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.carousel-dots button {
  width: 2rem;
  height: 0.55rem;
  border: 0;
  border-radius: var(--radius-full);
  background: oklch(from var(--color-text) l c h / 0.18);
  cursor: pointer;
  padding: 0;
  transition: width var(--transition-interactive), background var(--transition-interactive);
}

.carousel-dots button.is-active,
.carousel-dots button:hover,
.carousel-dots button:focus-visible {
  width: 3rem;
  background: var(--color-primary);
}

.owner-card {
  display: grid;
  gap: var(--space-6);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-text) 5%, transparent), transparent 46%),
    linear-gradient(180deg, var(--color-surface), var(--color-surface-2));
  box-shadow: var(--shadow-sm);
  padding: clamp(var(--space-5), 4vw, var(--space-10));
}

.owner-snapshot {
  display: grid;
  gap: var(--space-4);
  align-content: stretch;
  min-height: clamp(21rem, 42vw, 34rem);
}

.owner-photo-card {
  display: grid;
  place-items: center;
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: calc(var(--radius-xl) - var(--space-2));
  background:
    repeating-linear-gradient(90deg, transparent 0 2.25rem, oklch(from var(--color-text) l c h / 0.035) 2.25rem 2.32rem),
    linear-gradient(145deg, var(--color-surface-2), var(--color-surface));
  min-height: 18rem;
  padding: clamp(var(--space-5), 4vw, var(--space-8));
  position: relative;
  overflow: hidden;
}

.owner-photo-card::before {
  position: absolute;
  width: min(78%, 24rem);
  aspect-ratio: 1;
  border: 1px solid oklch(from var(--color-text) l c h / 0.12);
  border-radius: var(--radius-full);
  background: transparent;
  content: '';
}

.owner-photo-card img {
  width: min(78%, 24rem);
  aspect-ratio: 1;
  border: 0.35rem solid var(--color-surface);
  border-radius: var(--radius-full);
  filter: grayscale(1) contrast(1.08) brightness(1.04);
  box-shadow: 0 0 0 1px oklch(from var(--color-text) l c h / 0.16), var(--shadow-sm);
  object-fit: cover;
  position: relative;
  z-index: 1;
}

.owner-proof-list {
  display: grid;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
}

.owner-proof-list li {
  display: grid;
  grid-template-columns: minmax(6.5rem, 0.36fr) 1fr;
  gap: var(--space-3);
  align-items: baseline;
  border-bottom: 1px solid oklch(from var(--color-text) l c h / 0.1);
  padding-block: var(--space-3);
}

.owner-proof-list li:first-child {
  border-top: 1px solid oklch(from var(--color-text) l c h / 0.1);
}

.owner-proof-list strong {
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.owner-proof-list span {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.owner-note {
  border-left: 0;
  border-radius: var(--radius-lg);
  background: var(--color-text);
  color: var(--color-bg);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.15;
  padding: var(--space-5);
}

.owner-copy {
  display: grid;
  align-content: center;
  gap: var(--space-4);
}

.owner-copy h2 {
  max-width: 14ch;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 900;
  letter-spacing: -0.05em;
  line-height: 1.02;
}

.owner-copy p {
  color: var(--color-text-muted);
}

.owner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding-top: var(--space-2);
}

.disabled-link {
  cursor: default;
  opacity: 0.72;
}

.ad-showcase {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.ad-card {
  display: grid;
  min-height: 17rem;
  align-content: space-between;
  gap: var(--space-5);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
  padding: clamp(var(--space-5), 3vw, var(--space-8));
  position: relative;
  overflow: hidden;
}

.ad-card::after {
  position: absolute;
  inset: auto -12% -22% auto;
  width: 13rem;
  height: 13rem;
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-primary) 15%, transparent);
  content: '';
}

.ad-card > * {
  position: relative;
  z-index: 1;
}

.ad-card h3 {
  max-width: 11ch;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 900;
  letter-spacing: -0.045em;
  line-height: 1.02;
}

.ad-card p {
  color: var(--color-text-muted);
}

.ad-card-large {
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 16%, transparent), transparent 52%),
    var(--color-text);
  color: var(--color-bg);
}

.ad-card-large p {
  color: color-mix(in oklab, var(--color-bg) 78%, transparent);
}

.ad-topline {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  color: color-mix(in oklab, var(--color-bg) 72%, transparent);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.ad-cta {
  width: fit-content;
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 900;
  padding: var(--space-2) var(--space-4);
}

.ad-card-blue {
  background:
    linear-gradient(160deg, var(--color-primary-highlight), transparent 64%),
    var(--color-surface);
}

.ad-phone {
  display: grid;
  gap: var(--space-2);
  width: min(100%, 12rem);
  border: 1px solid oklch(from var(--color-primary) l c h / 0.18);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-md);
  padding: var(--space-5);
}

.ad-phone span,
.ad-label {
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ad-phone strong {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.ad-phone small {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 700;
}

.ad-card-minimal {
  background:
    repeating-linear-gradient(90deg, transparent 0 2.4rem, oklch(from var(--color-text) l c h / 0.035) 2.4rem 2.45rem),
    var(--color-surface);
}

.photo-showcase {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.photo-card {
  display: grid;
  min-height: 22rem;
  align-items: end;
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  position: relative;
}

.photo-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-card::after {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 15%, oklch(0.08 0.02 245 / 0.84));
  content: '';
}

.photo-card figcaption {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-6);
  position: relative;
  z-index: 1;
}

.photo-card strong {
  color: white;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
}

.photo-card span {
  max-width: 34ch;
  color: oklch(0.92 0.02 245 / 0.78);
}

.project-columns {
  display: grid;
  gap: var(--space-4);
}

.project-column {
  display: grid;
  gap: var(--space-4);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--color-primary) 8%, transparent), transparent 42%),
    var(--color-surface);
  padding: var(--space-6);
}

.project-column.featured-column {
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 22%, transparent), transparent),
    var(--color-text);
  color: var(--color-bg);
}

.project-column.featured-column p,
.project-column.featured-column li {
  color: color-mix(in oklab, var(--color-bg) 76%, transparent);
}

.project-number {
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.12em;
}

.featured-column .project-number {
  color: var(--color-bg);
}

.project-column h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.05;
}

.project-column p,
.project-column li {
  color: var(--color-text-muted);
}

.offer-price {
  width: fit-content;
  border-radius: var(--radius-full);
  background: var(--color-primary-highlight);
  color: var(--color-primary);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 900;
  letter-spacing: -0.025em;
  padding: var(--space-2) var(--space-4);
}

.price-note {
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 900;
}

.project-column.featured-column .offer-price {
  background: var(--color-bg);
  color: var(--color-text);
}

.project-column.featured-column .price-note {
  color: var(--color-bg);
}

.project-column ul {
  display: grid;
  gap: var(--space-2);
  padding-left: var(--space-5);
}

.project-column .session-list {
  padding-left: 0;
  list-style: none;
}

.session-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  border-bottom: 1px solid oklch(from var(--color-text) l c h / 0.1);
  color: var(--color-text);
  padding-block: var(--space-2);
}

.session-list li:last-child {
  border-bottom: 0;
}

.session-list strong {
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}

.project-column .btn {
  width: fit-content;
  margin-top: var(--space-2);
}

.featured-column .btn-primary {
  background: var(--color-bg);
  color: var(--color-text);
}

.rates {
  display: grid;
  gap: var(--space-4);
}

.rate-card {
  display: grid;
  gap: var(--space-4);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  padding: var(--space-6);
}

.rate-label {
  width: fit-content;
  border-radius: var(--radius-full);
  background: var(--color-primary-highlight);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  padding: var(--space-1) var(--space-3);
  text-transform: uppercase;
}

.rate-card.accent {
  background: var(--color-text);
  color: var(--color-bg);
}

.rate-card.accent .rate-label {
  background: color-mix(in oklab, var(--color-bg) 14%, transparent);
  color: var(--color-bg);
}

.rate-card.accent p,
.rate-card.accent li {
  color: color-mix(in oklab, var(--color-bg) 74%, transparent);
}

.price {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: -0.045em;
}

.rate-card ul {
  display: grid;
  gap: var(--space-2);
  padding-left: var(--space-5);
}

.mini-rate-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2) var(--space-4);
  border-top: 1px solid oklch(from var(--color-text) l c h / 0.1);
  color: var(--color-text-muted);
  padding-top: var(--space-2);
}

.mini-rate-grid strong {
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}

.rate-breakdown {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.rate-breakdown article {
  display: grid;
  gap: var(--space-2);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--color-surface) 78%, transparent);
  padding: var(--space-5);
}

.rate-breakdown h3,
.ghl-card h3 {
  font-size: var(--text-base);
  font-weight: 900;
}

.rate-breakdown p,
.ghl-card p {
  color: var(--color-text-muted);
}

.cost-box {
  display: grid;
  gap: var(--space-5);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
  padding: clamp(var(--space-6), 4vw, var(--space-10));
}

.cost-steps {
  display: grid;
  gap: var(--space-3);
}

.cost-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
}

.step-number {
  display: grid;
  width: 2rem;
  height: 2rem;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: white;
  font-size: var(--text-xs);
  font-weight: 900;
}

.cost-step h3 {
  font-size: var(--text-base);
  font-weight: 800;
}

.cost-step p {
  color: var(--color-text-muted);
}

.social-panel {
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 10%, transparent), transparent 55%),
    var(--color-surface);
  box-shadow: var(--shadow-sm);
  padding: clamp(var(--space-6), 5vw, var(--space-10));
}

.social-links {
  display: grid;
  gap: var(--space-3);
}

.social-card {
  display: grid;
  gap: var(--space-4);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--color-surface) 80%, transparent);
  color: var(--color-text);
  cursor: pointer;
  padding: var(--space-4);
  text-decoration: none;
}

.social-card:hover,
.social-card:focus-visible {
  border-color: oklch(from var(--color-primary) l c h / 0.36);
  box-shadow: var(--shadow-sm);
}

.social-card:focus-visible {
  outline: 3px solid oklch(from var(--color-primary) l c h / 0.3);
  outline-offset: 3px;
}

.social-card svg {
  width: 1.55rem;
  height: 1.55rem;
  color: var(--color-primary);
  fill: none;
  flex: 0 0 auto;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}

.social-copy {
  display: grid;
  gap: var(--space-1);
}

.social-copy strong {
  font-size: var(--text-base);
  line-height: 1.1;
}

.social-copy small,
.social-note {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.social-url {
  width: fit-content;
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: 800;
  overflow-wrap: anywhere;
  text-decoration: none;
}

.social-url:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

.social-button {
  justify-self: start;
  min-height: 2.5rem;
  padding: var(--space-2) var(--space-4);
}

.social-note {
  margin-top: var(--space-4);
}

.contact-grid {
  display: grid;
  gap: var(--space-6);
  align-items: stretch;
}

.contact-band {
  display: grid;
  gap: var(--space-6);
  align-content: start;
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 18% 10%, color-mix(in oklab, var(--color-primary) 44%, transparent), transparent 16rem),
    radial-gradient(circle at 94% 86%, color-mix(in oklab, var(--color-primary) 26%, transparent), transparent 18rem),
    linear-gradient(145deg, color-mix(in oklab, var(--color-primary) 18%, transparent), transparent 48%),
    var(--color-text);
  color: var(--color-bg);
  padding: clamp(var(--space-6), 5vw, var(--space-12));
  position: relative;
  overflow: hidden;
}

.contact-band::after {
  position: absolute;
  inset: auto -10% -18% auto;
  width: min(42vw, 22rem);
  aspect-ratio: 1;
  border: 1px solid color-mix(in oklab, var(--color-bg) 18%, transparent);
  border-radius: var(--radius-full);
  content: '';
}

.contact-band > * {
  position: relative;
  z-index: 1;
}

.contact-band .eyebrow {
  margin-bottom: var(--space-4);
}

.contact-band h2 {
  max-width: 12ch;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: -0.045em;
  line-height: 1.02;
}

.contact-band p {
  color: color-mix(in oklab, var(--color-bg) 76%, transparent);
}

.contact-fit {
  display: grid;
  gap: var(--space-3);
  border: 1px solid color-mix(in oklab, var(--color-bg) 16%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in oklab, var(--color-bg) 8%, transparent);
  padding: var(--space-4);
}

.contact-fit > span {
  color: color-mix(in oklab, var(--color-bg) 68%, transparent);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-fit-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.contact-fit-list strong {
  border: 1px solid color-mix(in oklab, var(--color-bg) 18%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-bg) 9%, transparent);
  color: var(--color-bg);
  font-size: var(--text-xs);
  line-height: 1.15;
  padding: var(--space-2) var(--space-3);
}

.contact-methods {
  display: grid;
  gap: var(--space-3);
}

.contact-method {
  display: grid;
  gap: var(--space-1);
  border: 1px solid color-mix(in oklab, var(--color-bg) 18%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--color-bg) 8%, transparent);
  color: var(--color-bg);
  padding: var(--space-4);
  text-decoration: none;
}

.contact-method:hover,
.contact-method:focus-visible {
  border-color: color-mix(in oklab, var(--color-bg) 44%, transparent);
  background: color-mix(in oklab, var(--color-bg) 12%, transparent);
}

.contact-method span {
  color: color-mix(in oklab, var(--color-bg) 68%, transparent);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-method strong {
  overflow-wrap: anywhere;
  font-size: var(--text-base);
  line-height: 1.2;
}

.contact-promise {
  display: grid;
  gap: var(--space-4);
  border-top: 1px solid color-mix(in oklab, var(--color-bg) 18%, transparent);
  padding-top: var(--space-5);
}

.contact-promise strong {
  font-size: var(--text-sm);
  font-weight: 900;
  letter-spacing: 0.02em;
}

.contact-steps {
  display: grid;
  gap: var(--space-2);
}

.contact-steps span {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  border: 1px solid color-mix(in oklab, var(--color-bg) 14%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--color-bg) 7%, transparent);
  color: color-mix(in oklab, var(--color-bg) 78%, transparent);
  font-size: var(--text-sm);
  font-weight: 800;
  padding: var(--space-3);
}

.contact-steps b {
  display: inline-grid;
  width: 1.65rem;
  height: 1.65rem;
  flex: 0 0 auto;
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-bg) 92%, transparent);
  color: var(--color-text);
  font-size: var(--text-xs);
}

.ghl-card {
  display: grid;
  gap: var(--space-5);
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, var(--color-surface), color-mix(in oklab, var(--color-surface-2) 78%, var(--color-surface))),
    var(--color-surface);
  box-shadow: var(--shadow-sm);
  padding: clamp(var(--space-5), 4vw, var(--space-8));
}

.form-heading {
  display: grid;
  gap: var(--space-2);
}

.ghl-form-embed {
  width: 100%;
  overflow: hidden;
  border: 1px solid oklch(from var(--color-text) l c h / 0.1);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
}

.ghl-form-embed iframe {
  display: block;
  width: 100%;
  min-height: 1224px;
  border: 0;
  border-radius: var(--radius-lg);
}

.ghl-card h3 {
  max-width: 13ch;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
}

.quote-form {
  display: grid;
  gap: var(--space-3);
}

.quote-form label {
  display: grid;
  gap: var(--space-2);
}

.quote-form label span {
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.quote-form input,
.quote-form select,
.quote-form textarea {
  width: 100%;
  border: 1px solid oklch(from var(--color-text) l c h / 0.14);
  border-radius: calc(var(--radius-lg) - var(--space-1));
  background: var(--color-surface);
  color: var(--color-text);
  padding: var(--space-3) var(--space-4);
}

.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus {
  border-color: color-mix(in oklab, var(--color-primary) 64%, var(--color-border));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary-highlight) 58%, transparent);
  outline: 0;
}

.quote-form textarea {
  min-height: 8rem;
  resize: vertical;
}

.quote-form .full {
  grid-column: 1 / -1;
}

.quote-form .hp {
  display: none;
}

.quote-form .btn {
  width: 100%;
}

.form-status {
  min-height: 1.5rem;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 700;
}

.form-status.success {
  color: var(--color-success);
}

.form-status.error {
  color: var(--color-error);
}

.embed-placeholder {
  display: grid;
  min-height: 14rem;
  place-items: center;
  border: 1px dashed oklch(from var(--color-primary) l c h / 0.38);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 12%, transparent), transparent),
    var(--color-surface-2);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 800;
  text-align: center;
}

.site-footer {
  border-top: 1px solid oklch(from var(--color-text) l c h / 0.1);
  padding-block: var(--space-8);
}

.footer-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  justify-content: space-between;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.footer-links a {
  color: inherit;
  text-decoration: none;
}

.footer-links a:hover {
  color: var(--color-primary);
}

@media (min-width: 720px) {
  .brand-text {
    display: inline;
  }

  .nav-links {
    display: flex;
  }

  .menu-toggle {
    display: none;
  }

  .hero {
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.82fr);
  }

  .split {
    grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.72fr);
    align-items: start;
  }

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

  .ad-showcase {
    grid-template-columns: 1.2fr 0.8fr 0.8fr;
  }

  .carousel-topline {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .carousel-controls {
    justify-content: end;
  }

  .work-slide {
    grid-template-columns: minmax(0, 0.86fr) minmax(22rem, 1fr);
  }

  .photo-showcase {
    grid-template-columns: 1.35fr 0.65fr;
  }

  .owner-card {
    grid-template-columns: minmax(18rem, 0.78fr) minmax(0, 1fr);
    align-items: center;
  }

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

  .work-card.featured {
    grid-column: span 2;
  }

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

  .rate-breakdown {
    grid-template-columns: repeat(3, 1fr);
  }

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

  .contact-grid {
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.58fr);
  }

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

  .footer-inner {
    flex-direction: row;
    align-items: center;
  }
}

@media (max-width: 719px) {
  .nav {
    width: min(100% - var(--space-6), var(--content-wide));
  }

  .container {
    width: min(100% - var(--space-6), var(--content-wide));
  }

  h1 {
    max-width: 10ch;
  }

  .hero {
    min-height: auto;
  }

  .panel-logo {
    min-height: 10rem;
    padding: var(--space-5);
  }
}
