:root {
  --cw-color-bg-primary: #f2f0ea;
  --cw-color-bg-secondary: #e6e1d8;
  --cw-color-surface-primary: #fbfaf6;
  --cw-color-surface-elevated: #ffffff;
  --cw-color-text-primary: #1f2b31;
  --cw-color-text-secondary: #46565d;
  --cw-color-border-soft: #d7d0c3;
  --cw-color-border-strong: #aa9c82;
  --cw-color-accent-route: #b06a3c;
  --cw-color-accent-route-soft: #d9b89f;
  --cw-color-trust-info: #35535f;
  --cw-color-success: #4f6b52;
  --cw-color-warning: #8c5d2b;

  --cw-font-ui: "IBM Plex Mono", "SFMono-Regular", Menlo, monospace;
  --cw-font-editorial: "Cormorant Garamond", Georgia, serif;

  --cw-space-2xs: 0.25rem;
  --cw-space-xs: 0.5rem;
  --cw-space-sm: 0.75rem;
  --cw-space-md: 1rem;
  --cw-space-lg: 1.5rem;
  --cw-space-xl: 2rem;
  --cw-space-2xl: 3rem;
  --cw-space-3xl: 4.5rem;
  --cw-space-section-y: clamp(3.6rem, 7.5vw, 6rem);

  --cw-radius-sm: 12px;
  --cw-radius-md: 18px;
  --cw-radius-lg: 28px;
  --cw-radius-pill: 999px;

  --cw-shadow-soft: 0 14px 35px rgba(35, 29, 20, 0.08);
  --cw-shadow-strong: 0 24px 48px rgba(24, 20, 14, 0.14);
  --cw-card-padding: clamp(1.1rem, 1.8vw, 1.45rem);
  --cw-card-radius: 20px;
  --cw-card-border: 1px solid var(--cw-color-border-soft);
  --cw-card-shadow: 0 14px 30px rgba(35, 29, 20, 0.08);

  --cw-max-width: 1160px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  min-width: 320px;
}

html {
  scroll-behavior: smooth;
}

body {
  position: relative;
  font-family: var(--cw-font-ui);
  color: var(--cw-color-text-primary);
  background: var(--cw-color-bg-primary);
  line-height: 1.45;
}

.variant-toggle {
  position: fixed;
  top: 1.05rem;
  right: 1.2rem;
  z-index: 120;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.34rem 0.46rem 0.34rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 88%, white);
  border-radius: 999px;
  background: color-mix(in srgb, var(--cw-color-surface-primary) 82%, white);
  box-shadow: 0 10px 22px rgba(30, 26, 20, 0.12);
}

.variant-toggle__label {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cw-color-text-secondary);
}

.variant-toggle__switch {
  position: relative;
  width: 2.42rem;
  height: 1.42rem;
  display: inline-flex;
  align-items: center;
}

.variant-toggle__switch input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  margin: 0;
}

.variant-toggle__slider {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 88%, white);
  background: #ece8df;
  position: relative;
  transition: background-color 180ms ease, border-color 180ms ease;
}

.variant-toggle__slider::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.18rem;
  width: 0.96rem;
  height: 0.96rem;
  border-radius: 50%;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 85%, white);
  transform: translateY(-50%);
  transition: transform 180ms ease;
}

.variant-toggle__switch input:checked + .variant-toggle__slider {
  background: color-mix(in srgb, var(--cw-color-accent-route) 24%, white);
  border-color: color-mix(in srgb, var(--cw-color-accent-route) 42%, var(--cw-color-border-soft));
}

.variant-toggle__switch input:checked + .variant-toggle__slider::before {
  transform: translate(0.98rem, -50%);
}

.variant-default-node.is-hidden-by-variant {
  display: none !important;
}

.variant-alt-shell {
  position: relative;
  min-height: 100vh;
  width: 100%;
  background: var(--cw-color-bg-primary);
}

.variant-alt-frame {
  width: 100%;
  min-height: 100vh;
  border: 0;
  display: block;
}

.bg-noise,
.bg-gradient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
}

.bg-gradient {
  background:
    radial-gradient(circle at 12% 8%, rgba(200, 148, 109, 0.2), transparent 42%),
    radial-gradient(circle at 88% 14%, rgba(94, 127, 138, 0.14), transparent 38%),
    linear-gradient(180deg, var(--cw-color-bg-primary) 0%, var(--cw-color-bg-secondary) 100%);
}

.bg-noise {
  opacity: 0.16;
  background-image: repeating-radial-gradient(circle at 0 0, transparent 0, #000000 0.9px, transparent 1.8px);
  background-size: 18px 18px;
  z-index: -1;
}

a {
  color: inherit;
}

.container {
  width: min(calc(100% - 3rem), var(--cw-max-width));
  margin: 0 auto;
}

.section {
  padding: var(--cw-space-section-y) 0;
}

.section-muted {
  background:
    linear-gradient(180deg, rgba(251, 250, 246, 0.66), rgba(246, 242, 236, 0.74)),
    linear-gradient(90deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0));
  border-top: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 72%, white);
  border-bottom: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 72%, white);
}

h1,
h2,
h3,
p {
  margin: 0;
}

h1,
h2 {
  font-family: var(--cw-font-editorial);
  letter-spacing: 0.015em;
}

h1 {
  font-size: clamp(2.1rem, 4.6vw, 4rem);
  line-height: 0.98;
  max-width: 16ch;
}

h2 {
  font-size: clamp(1.7rem, 3vw, 2.55rem);
  line-height: 1.02;
  margin-bottom: clamp(1.7rem, 2.8vw, 2.7rem);
}

.section .container > h2::after {
  content: "";
  display: block;
  width: 76px;
  height: 2px;
  margin-top: 0.62rem;
  border-radius: var(--cw-radius-pill);
  background: color-mix(in srgb, var(--cw-color-accent-route) 62%, white);
}

h3 {
  font-size: clamp(1.06rem, 2vw, 1.34rem);
  margin-bottom: var(--cw-space-sm);
}

p {
  color: var(--cw-color-text-secondary);
}

.eyebrow {
  display: inline-flex;
  width: fit-content;
  justify-self: start;
  align-self: start;
  align-items: center;
  gap: var(--cw-space-xs);
  border-radius: var(--cw-radius-pill);
  border: 1px solid color-mix(in srgb, var(--cw-color-accent-route) 40%, white);
  background: color-mix(in srgb, var(--cw-color-accent-route-soft) 38%, white);
  color: color-mix(in srgb, var(--cw-color-accent-route) 82%, #2d241b);
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.4rem 0.86rem;
}

.lead {
  font-size: clamp(1rem, 1.5vw, 1.22rem);
  max-width: 64ch;
  margin-top: var(--cw-space-lg);
}

.accent {
  color: var(--cw-color-accent-route);
}

.hero .container {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--cw-space-2xl);
  align-items: start;
}

.hero-headline {
  display: grid;
  gap: var(--cw-space-md);
}

.hero-card {
  background: color-mix(in srgb, var(--cw-color-surface-elevated) 88%, #f3efe7);
  border: 1px solid var(--cw-color-border-soft);
  border-radius: var(--cw-radius-lg);
  box-shadow: var(--cw-shadow-soft);
  padding: var(--cw-space-xl);
  display: grid;
  gap: var(--cw-space-lg);
}

.grid {
  display: grid;
  gap: clamp(1.35rem, 2.2vw, 2.2rem);
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: clamp(1.5rem, 2.6vw, 2.4rem);
  row-gap: clamp(1.2rem, 2vw, 2rem);
}

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

.card,
.bio-card,
.pricing-card,
.timeline,
.role-trust-note,
.faq-list details {
  border: var(--cw-card-border);
  border-radius: var(--cw-card-radius);
  background: color-mix(in srgb, var(--cw-color-surface-primary) 78%, white);
}

.card,
.bio-card,
.pricing-card,
.role-trust-note {
  padding: var(--cw-card-padding);
  box-shadow: var(--cw-card-shadow);
  display: grid;
  gap: var(--cw-space-sm);
}

.card p,
.bio-card p,
.pricing-card p {
  font-size: 0.98rem;
}

.card-icon {
  width: 2.6rem;
  height: 2.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--cw-color-accent-route) 34%, white);
  border-radius: 12px;
  color: color-mix(in srgb, var(--cw-color-accent-route) 88%, #2a3430);
  margin-bottom: 0.86rem;
  background: color-mix(in srgb, var(--cw-color-accent-route-soft) 34%, white);
}

.card-icon svg {
  width: 1.45rem;
  height: 1.45rem;
}

.role-proof-card {
  border-left: 4px solid var(--cw-color-accent-route);
}

.role-method-card {
  border-top: 3px solid var(--cw-color-trust-info);
}

.role-pricing-card {
  border-top: 3px solid var(--cw-color-success);
}

.role-trust-note {
  border-top: 3px solid var(--cw-color-warning);
}

.bullet-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--cw-space-md);
}

.card.bullet-list {
  padding: var(--cw-card-padding);
}

.bullet-list li {
  position: relative;
  padding-left: 1.58rem;
  line-height: 1.52;
  color: var(--cw-color-text-secondary);
}

.bullet-list li::before {
  content: "";
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 50%;
  background: var(--cw-color-accent-route);
  position: absolute;
  left: 0.12rem;
  top: 0.52rem;
}

.timeline {
  list-style: none;
  padding: var(--cw-space-lg);
  margin: 0;
  display: grid;
  gap: var(--cw-space-lg);
}

.timeline li {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: var(--cw-space-md);
}

.step-index {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.05rem;
  color: #fff;
  background: linear-gradient(150deg, var(--cw-color-accent-route), color-mix(in srgb, var(--cw-color-accent-route) 60%, #4d5f66));
}

.section-pricing {
  background: linear-gradient(180deg, rgba(250, 247, 240, 0.4), rgba(255, 255, 255, 0.7));
}

.section-pricing .pricing-card {
  max-width: 900px;
  margin-inline: auto;
}

.pricing-main {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--cw-space-md);
  margin-bottom: var(--cw-space-md);
  flex-wrap: wrap;
}

.pricing-label {
  font-weight: 600;
  color: var(--cw-color-text-primary);
}

.pricing-value {
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  font-family: var(--cw-font-ui);
  font-weight: 600;
  color: var(--cw-color-accent-route);
  line-height: 1;
}

.boundary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cw-space-md);
}

.faq-list {
  display: grid;
  gap: var(--cw-space-sm);
}

.faq-list details {
  overflow: hidden;
  transition: border-color 220ms ease, box-shadow 220ms ease;
}

.faq-list details[open] {
  border-color: var(--cw-color-border-strong);
  box-shadow: 0 16px 28px rgba(28, 31, 34, 0.08);
}

.faq-list summary {
  list-style: none;
  cursor: pointer;
  font-weight: 400;
  color: var(--cw-color-text-primary);
  padding: var(--cw-space-md) var(--cw-space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cw-space-md);
}

.faq-list summary::-webkit-details-marker {
  display: none;
}

.faq-list summary::after {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transform-origin: center;
  transition: transform 180ms ease;
  flex: 0 0 auto;
  margin-left: auto;
}

.faq-list details[open] summary::after {
  transform: rotate(-135deg);
}

.faq-list details p {
  padding: 0 var(--cw-space-lg) var(--cw-space-md);
}

.section-cta-final {
  text-align: center;
}

.cta-copy {
  max-width: 56ch;
  margin: 0 auto var(--cw-space-lg);
}

.cta-row {
  display: flex;
  justify-content: center;
  gap: var(--cw-space-md);
  flex-wrap: wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: var(--cw-radius-pill);
  border: 1px solid transparent;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 220ms ease, background-color 220ms ease, color 220ms ease, border-color 220ms ease;
  padding: 0.78rem 1.28rem;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(1px);
}

.btn-primary {
  background: linear-gradient(145deg, var(--cw-color-accent-route), color-mix(in srgb, var(--cw-color-accent-route) 76%, #7a3f1a));
  color: #fff;
  box-shadow: 0 14px 26px rgba(98, 50, 20, 0.28);
}

.btn-primary:hover {
  box-shadow: 0 18px 36px rgba(88, 44, 18, 0.34);
}

.btn-ghost {
  background: transparent;
  border-color: var(--cw-color-border-strong);
  color: var(--cw-color-text-primary);
}

.btn-ghost:hover {
  background: rgba(255, 255, 255, 0.6);
}

.footer {
  border-top: 1px solid var(--cw-color-border-soft);
  margin-top: var(--cw-space-2xl);
  padding: var(--cw-space-lg) 0;
}

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

.footer p {
  color: var(--cw-color-text-secondary);
  font-size: 0.92rem;
}

.footer a {
  color: var(--cw-color-text-primary);
  text-decoration: none;
  border-bottom: 1px dashed color-mix(in srgb, var(--cw-color-text-primary) 40%, transparent);
}

.footer-social {
  border-bottom: none !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--cw-color-border-soft) 85%, white);
  background: color-mix(in srgb, var(--cw-color-surface-primary) 80%, white);
  box-shadow: 0 8px 18px rgba(26, 24, 20, 0.08);
  transition: transform 180ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.footer-social-row {
  display: inline-flex;
  align-items: center;
  gap: 0.56rem;
}

.footer-social:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--cw-color-accent-route) 42%, var(--cw-color-border-soft));
  box-shadow: 0 12px 22px rgba(26, 24, 20, 0.12);
}

.footer-social-icon {
  width: 22px;
  height: 22px;
  display: block;
}

.sticky-cta {
  position: fixed;
  bottom: var(--cw-space-md);
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  z-index: 40;
  opacity: 0;
  pointer-events: none;
  transition: transform 280ms ease, opacity 240ms ease;
}

.sticky-cta.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 560ms ease, transform 560ms ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .btn,
  .reveal,
  .sticky-cta {
    transition: none;
  }
}
