:root {
  --ink: #17201c;
  --muted: #627067;
  --paper: #f5f7f4;
  --panel: #ffffff;
  --line: #d8ded6;
  --teal: #12796f;
  --teal-dark: #0c504b;
  --coral: #d86f45;
  --gold: #c59637;
  --shadow: 0 24px 70px rgba(22, 34, 31, 0.13);
  --soft-shadow: 0 12px 30px rgba(22, 34, 31, 0.07);
}

@media (max-width: 520px) {
  .split-options,
  .home-proof-grid,
  .home-offer-grid,
  .start-choice-grid {
    grid-template-columns: 1fr;
  }

  .split-option {
    min-height: 0;
    padding: 16px;
  }

  .split-option p {
    font-size: 0.9rem;
    line-height: 1.35;
  }

  .split-option .card-cta {
    align-self: flex-start;
    min-height: 34px;
    padding: 8px 10px;
    font-size: 0.75rem;
  }
}

@media (max-width: 520px) {
  .split-options,
  .home-proof-grid,
  .home-offer-grid,
  .start-choice-grid {
    grid-template-columns: 1fr;
  }

  .split-option {
    min-height: 0;
    padding: 16px;
  }

  .split-option p {
    font-size: 0.9rem;
    line-height: 1.35;
  }

  .split-option .card-cta {
    align-self: flex-start;
    min-height: 34px;
    padding: 8px 10px;
    font-size: 0.75rem;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.5;
  overflow-x: hidden;
}

a {
  color: inherit;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px clamp(18px, 5vw, 72px);
  background: rgba(245, 247, 244, 0.92);
  border-bottom: 1px solid rgba(216, 222, 214, 0.8);
  backdrop-filter: blur(16px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-weight: 800;
}

.brand-mark {
  display: grid;
  width: 42px;
  height: 34px;
  place-items: center;
  color: #fff;
  background: var(--teal);
  border-radius: 8px;
  font-size: 0.82rem;
}

.brand-logo-mark {
  display: block;
  width: 48px;
  height: 40px;
  flex: 0 0 auto;
}

nav {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: flex-end;
  color: var(--muted);
  font-size: 0.95rem;
}

nav a {
  text-decoration: none;
}

.hero {
  display: grid;
  min-height: min(780px, calc(100vh - 67px));
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.75fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
  padding: clamp(40px, 8vw, 86px) clamp(18px, 5vw, 72px) clamp(56px, 7vw, 78px);
  background:
    linear-gradient(115deg, rgba(18, 121, 111, 0.13), rgba(216, 111, 69, 0.1) 45%, rgba(197, 150, 55, 0.16)),
    var(--paper);
}

.business-hero {
  min-height: auto;
}

.business-hero-offer {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  max-width: 760px;
  margin-top: 18px;
}

.business-hero-offer span {
  min-height: 58px;
  padding: 10px 12px;
  color: #24352f;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 760;
  line-height: 1.2;
  box-shadow: 0 10px 22px rgba(22, 34, 31, 0.055);
}

.business-hero-offer strong {
  display: block;
  color: var(--teal-dark);
  font-size: 0.95rem;
}

.split-hero {
  display: grid;
  min-height: min(760px, calc(100svh - 67px));
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 0.88fr);
  grid-template-rows: auto auto;
  gap: clamp(14px, 2.3vw, 28px) clamp(18px, 2.8vw, 38px);
  align-content: start;
  align-items: start;
  padding: clamp(14px, 2.7vw, 34px) clamp(18px, 5vw, 72px) clamp(14px, 2.5vw, 26px);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(245, 247, 244, 0) 62%),
    linear-gradient(115deg, rgba(18, 121, 111, 0.08), rgba(216, 111, 69, 0.055) 48%, rgba(197, 150, 55, 0.09)),
    var(--paper);
}

.split-copy {
  max-width: 740px;
  align-self: center;
  padding-top: 0;
}

.split-copy h1 {
  max-width: 690px;
  margin-bottom: 12px;
  font-size: clamp(2.35rem, 3.35vw, 3.7rem);
  font-weight: 760;
  line-height: 1;
}

.split-copy .lead {
  max-width: 660px;
  color: #35433b;
  font-size: clamp(0.98rem, 1.08vw, 1.08rem);
  line-height: 1.38;
}

.ownership-note {
  display: inline-flex;
  align-items: center;
  margin: 8px 0 0;
  padding-left: 13px;
  color: var(--teal-dark);
  border-left: 3px solid var(--gold);
  font-size: 0.96rem;
  font-weight: 760;
}

.split-copy .hero-actions {
  margin-top: 18px;
}

.help-stack {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  max-width: 720px;
  margin-top: 14px;
}

.help-stack span {
  display: flex;
  min-height: 34px;
  align-items: center;
  padding: 7px 10px;
  color: #23352f;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 121, 111, 0.12);
  border-radius: 8px;
  font-size: 0.76rem;
  font-weight: 760;
  box-shadow: 0 8px 18px rgba(22, 34, 31, 0.045);
}

.help-stack span::before {
  content: "";
  flex: 0 0 auto;
  width: 7px;
  height: 7px;
  margin-right: 9px;
  background: var(--teal);
  border-radius: 999px;
  box-shadow: 0 0 0 4px rgba(18, 121, 111, 0.09);
}

.button.is-cliff-target {
  animation: cliffCtaPulse 1.8s ease-in-out 2;
  box-shadow: 0 0 0 5px rgba(18, 121, 111, 0.12), 0 14px 34px rgba(18, 121, 111, 0.2);
}

.split-copy .trust-row {
  margin-top: 14px;
  gap: 10px;
}

.split-copy .trust-row span {
  padding: 8px 11px;
  color: #3f4f47;
  background: rgba(255, 255, 255, 0.74);
  font-size: 0.84rem;
}

.hero-media-stack {
  display: grid;
  gap: 14px;
  min-width: 0;
  width: 100%;
  max-width: 560px;
  align-self: center;
  justify-self: end;
}

.premium-companion-demo {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  padding: clamp(14px, 2vw, 20px);
  color: #18322d;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, 0.96), rgba(234, 243, 239, 0.98) 54%, rgba(255, 242, 228, 0.92)),
    #f5faf7;
  border: 1px solid rgba(18, 121, 111, 0.2);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.floating-companion-demo {
  min-height: 430px;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
}

.premium-demo-top,
.premium-demo-actions {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.premium-demo-top {
  margin-bottom: 12px;
  font-size: 0.82rem;
  font-weight: 850;
  text-transform: uppercase;
}

.floating-companion-demo .premium-demo-top {
  align-items: flex-start;
  min-height: 36px;
  padding: 0 0 8px;
}

.premium-demo-top span {
  color: var(--teal-dark);
  letter-spacing: 0.08em;
}

.premium-demo-top strong {
  min-width: 148px;
  padding: 7px 10px;
  color: #fff;
  background: var(--teal-dark);
  border-radius: 999px;
  text-align: center;
  white-space: nowrap;
}

.premium-demo-scene {
  position: relative;
  min-height: 300px;
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(253, 250, 244, 0.6), rgba(245, 250, 247, 0.95)),
    linear-gradient(90deg, transparent 0 19px, rgba(18, 121, 111, 0.06) 20px 21px, transparent 22px 100%),
    #f8fbf7;
  background-size: auto, 42px 42px, auto;
  box-shadow: inset 0 -28px 70px rgba(18, 121, 111, 0.08);
}

.floating-companion-demo .premium-demo-scene {
  min-height: 334px;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.floating-companion-demo .premium-demo-scene::before {
  display: none;
}

.floating-companion-demo .avatar-engine {
  position: fixed;
  z-index: 52;
  right: clamp(18px, 2.8vw, 46px);
  bottom: clamp(118px, 18vh, 162px);
  left: auto;
  --avatar-scale: 0.72;
  pointer-events: none;
}

.screen-cliff {
  position: fixed;
  right: clamp(-18px, -1vw, -8px);
  bottom: clamp(18px, 4vh, 34px);
  z-index: 52;
  width: 150px;
  height: 170px;
  pointer-events: none;
}

.screen-cliff::before {
  content: "";
  position: absolute;
  right: 12px;
  bottom: 2px;
  width: 116px;
  height: 116px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(18, 121, 111, 0.18), transparent 66%),
    radial-gradient(circle, rgba(216, 111, 69, 0.12), transparent 72%);
  opacity: 0.82;
  transform: translateY(6px);
  animation: cliffPresenceGlow 5.8s ease-in-out infinite;
}

.screen-cliff-panel {
  position: absolute;
  right: 72px;
  bottom: 104px;
  width: 232px;
  padding: 10px;
  color: #18322d;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.88), rgba(244, 251, 248, 0.78)),
    rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(18, 121, 111, 0.13);
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(22, 34, 31, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(18px);
  pointer-events: auto;
  transform: translateY(0);
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px) scale(0.96);
  transition: transform 260ms ease, opacity 260ms ease;
}

.screen-cliff.is-reacting .screen-cliff-panel,
.screen-cliff[data-screen-path="family"] .screen-cliff-panel,
.screen-cliff[data-screen-path="business"] .screen-cliff-panel,
.screen-cliff[data-screen-path="privacy"] .screen-cliff-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.screen-cliff-panel::after {
  content: "";
  position: absolute;
  right: -8px;
  bottom: 24px;
  width: 16px;
  height: 16px;
  background: rgba(248, 252, 250, 0.96);
  border-top: 1px solid rgba(18, 121, 111, 0.18);
  border-right: 1px solid rgba(18, 121, 111, 0.18);
  transform: rotate(45deg);
}

.screen-cliff-panel span {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 3px 8px;
  color: #fff;
  background: linear-gradient(135deg, var(--teal-dark), var(--teal));
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.screen-cliff-panel p {
  margin: 7px 0 0;
  font-size: 0.76rem;
  font-weight: 760;
  line-height: 1.35;
}

.screen-cliff-panel p::after {
  content: "";
  display: block;
  width: 42px;
  height: 3px;
  margin-top: 8px;
  background: linear-gradient(90deg, var(--teal), rgba(18, 121, 111, 0.08));
  border-radius: 999px;
}

.screen-cliff-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}

.screen-cliff-panel button {
  min-height: 26px;
  width: fit-content;
  padding: 5px 8px;
  color: var(--teal-dark);
  background: rgba(248, 251, 247, 0.74);
  border: 1px solid rgba(18, 121, 111, 0.13);
  border-radius: 999px;
  font: inherit;
  font-size: 0.64rem;
  font-weight: 900;
  cursor: pointer;
}

.screen-cliff-panel button:hover,
.screen-cliff-panel button:focus-visible,
.screen-cliff-panel button.is-selected {
  color: #fff;
  background: linear-gradient(135deg, var(--teal-dark), var(--teal));
  outline: none;
}

.screen-cliff .avatar-engine {
  position: absolute;
  left: auto;
  right: 0;
  bottom: 0;
  --avatar-scale: 0.54;
}

.screen-cliff-static {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 112px;
  height: 158px;
  object-fit: contain;
  object-position: 50% 100%;
  filter: drop-shadow(0 18px 16px rgba(22, 34, 31, 0.16));
}

.screen-cliff-idle-sprite {
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 112px;
  height: 224px;
  overflow: hidden;
  filter: drop-shadow(0 18px 16px rgba(22, 34, 31, 0.16));
  transform-origin: 50% 100%;
}

.screen-cliff-idle-sprite img,
.screen-cliff-idle-sprite video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: 50% 100%;
}

.screen-cliff-fallback-sheet {
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 112px;
  height: 224px;
  overflow: hidden;
  background-position: 0 0;
  background-repeat: no-repeat;
  opacity: 0;
  pointer-events: none;
}

.screen-cliff-idle-sprite video,
.screen-cliff-fallback-sheet img {
  display: none;
}

.screen-cliff-fallback-idle {
  opacity: 1;
  background-image: url("assets/cliff-idle-loop-v3-1-grounded.png");
  background-size: 800% 100%;
  animation: screenCliffIdleMobileFrames 4.2s steps(8) infinite;
}

.screen-cliff-fallback-attention {
  background-image: url("assets/cliff-listen-attention-v2-1-no-wink-registered.png");
  background-size: 1600% 100%;
  transform: scale(0.74);
  transform-origin: 50% 100%;
  animation: screenCliffAttentionMobileFrames 4.36s steps(16) 1 both;
}

.screen-cliff.is-screen-attention .screen-cliff-fallback-idle {
  opacity: 0;
}

.screen-cliff.is-screen-attention .screen-cliff-fallback-attention {
  opacity: 1;
}

.screen-cliff[data-screen-path="business"].is-reacting {
  right: -28px;
  bottom: -10px;
  width: 210px;
  height: 238px;
}

.screen-cliff[data-screen-path="business"].is-reacting .avatar-engine {
  right: 0;
  bottom: 0;
  --avatar-scale: 0.78;
}

.screen-cliff[data-screen-path="business"].is-reacting .screen-cliff-panel {
  right: 124px;
  bottom: 154px;
}

.screen-cliff[data-screen-path="family"] .screen-cliff-panel,
.screen-cliff[data-screen-path="business"] .screen-cliff-panel,
.screen-cliff[data-screen-path="privacy"] .screen-cliff-panel {
  transform: translateY(-4px) scale(1);
}

.screen-cliff.is-reacting .screen-cliff-panel {
  animation: cliffPanelReact 680ms cubic-bezier(.16, .84, .22, 1) 1;
}

.screen-cliff.is-reacting::before {
  animation: cliffPresenceReact 680ms ease-out 1, cliffPresenceGlow 5.8s ease-in-out 680ms infinite;
}

.companion-guide {
  position: fixed;
  z-index: 53;
  right: clamp(168px, 17vw, 286px);
  bottom: clamp(252px, 39vh, 322px);
  width: min(270px, calc(100vw - 48px));
  padding: 12px;
  color: #18322d;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(18, 121, 111, 0.18);
  border-radius: 8px;
  box-shadow: 0 18px 46px rgba(22, 34, 31, 0.16);
  backdrop-filter: blur(16px);
  transform-origin: 100% 100%;
  animation: guideFloat 5.2s ease-in-out infinite;
}

.companion-guide::after {
  content: "";
  position: absolute;
  right: -9px;
  bottom: 24px;
  width: 18px;
  height: 18px;
  background: rgba(255, 255, 255, 0.92);
  border-top: 1px solid rgba(18, 121, 111, 0.18);
  border-right: 1px solid rgba(18, 121, 111, 0.18);
  transform: rotate(45deg);
}

.companion-guide p {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 750;
  line-height: 1.35;
}

.companion-guide div {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 10px;
}

.companion-guide button {
  min-height: 30px;
  color: var(--teal-dark);
  background: #f8fbf7;
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 850;
  cursor: pointer;
}

.companion-guide button:hover,
.companion-guide button:focus-visible {
  color: #fff;
  background: var(--teal-dark);
  outline: none;
}

.floating-companion-demo .premium-demo-scene::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 14%;
  bottom: 22px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(18, 121, 111, 0.26), transparent);
}

.premium-workspace {
  position: absolute;
  inset: 20px 20px 58px 40%;
  border-radius: 8px;
}

.floating-companion-demo .premium-workspace {
  position: fixed;
  z-index: 50;
  inset: auto clamp(30px, 4.5vw, 70px) clamp(322px, 47vh, 392px) auto;
  width: min(430px, 42vw);
  height: 236px;
  pointer-events: none;
}

.workspace-panel {
  position: absolute;
  display: block;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
  box-shadow: 0 14px 30px rgba(22, 34, 31, 0.1);
  transition: transform 520ms cubic-bezier(.2, .8, .2, 1), opacity 520ms ease;
}

.floating-companion-demo .workspace-panel,
.floating-companion-demo .workspace-card,
.floating-companion-demo .workspace-result {
  backdrop-filter: blur(12px);
}

.panel-calendar {
  top: 4px;
  right: 0;
  width: min(170px, 48%);
  height: 112px;
}

.panel-calendar::before,
.panel-approval::before {
  content: "";
  position: absolute;
  inset: 12px 12px auto;
  height: 10px;
  background: linear-gradient(90deg, var(--teal), rgba(18, 121, 111, 0.18));
  border-radius: 99px;
}

.panel-calendar::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  height: 54px;
  background:
    linear-gradient(90deg, rgba(216, 111, 69, 0.72) 0 20%, transparent 20% 28%, rgba(197, 150, 55, 0.72) 28% 55%, transparent 55% 64%, rgba(18, 121, 111, 0.72) 64%),
    linear-gradient(#dfe8e2, #dfe8e2);
  background-size: 100% 10px, 100% 1px;
  background-position: 0 0, 0 24px;
  background-repeat: repeat-y, no-repeat;
  border-radius: 6px;
}

.panel-approval {
  right: 22px;
  bottom: 8px;
  width: min(190px, 58%);
  height: 88px;
  opacity: 0.72;
}

.panel-approval::after {
  content: "";
  position: absolute;
  right: 14px;
  bottom: 14px;
  width: 42px;
  height: 24px;
  background: var(--coral);
  border-radius: 999px;
}

.workspace-card,
.workspace-result {
  position: absolute;
  z-index: 2;
  min-width: 106px;
  padding: 9px 11px;
  color: #263a34;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-left: 4px solid var(--teal);
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 850;
  box-shadow: 0 14px 26px rgba(22, 34, 31, 0.13);
  transition: transform 700ms cubic-bezier(.2, .8, .2, 1), opacity 420ms ease;
}

.card-one {
  top: 48px;
  left: 2%;
  transform: rotate(-1deg);
}

.card-two {
  top: 116px;
  left: 22%;
  border-left-color: var(--gold);
  transform: rotate(1.2deg);
}

.card-three {
  top: 176px;
  left: 4%;
  border-left-color: var(--coral);
  transform: rotate(-1.4deg);
}

.workspace-result {
  right: 4px;
  bottom: 118px;
  color: #fff;
  background: var(--teal-dark);
  border-color: transparent;
  border-left: 0;
  opacity: 0;
  transform: translateY(12px) scale(0.94);
}

.premium-demo-dock {
  position: absolute;
  left: 34px;
  right: 30px;
  bottom: 16px;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 1fr;
  gap: 8px;
}

.floating-companion-demo .premium-demo-dock {
  left: 10%;
  right: 17%;
  bottom: 76px;
}

.premium-demo-dock span {
  height: 10px;
  background: rgba(18, 121, 111, 0.13);
  border-radius: 999px;
  animation: dockPulse 3s ease-in-out infinite;
}

.premium-demo-dock span:nth-child(2) {
  animation-delay: -0.8s;
}

.premium-demo-dock span:nth-child(3) {
  animation-delay: -1.5s;
}

.premium-demo-actions {
  margin-top: 12px;
}

.floating-companion-demo .premium-demo-actions {
  width: min(520px, 100%);
  margin-top: 4px;
}

.premium-demo-actions button {
  flex: 1;
  min-height: 36px;
  color: var(--teal-dark);
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(18, 121, 111, 0.18);
  border-radius: 8px;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 850;
  cursor: pointer;
}

.premium-demo-actions button:hover,
.premium-demo-actions button:focus-visible,
.premium-demo-actions button.is-selected {
  color: #fff;
  background: var(--teal-dark);
  outline: none;
}

.premium-companion-demo[data-state="calendar"] .panel-calendar {
  transform: translateY(-6px) scale(1.04);
}

.premium-companion-demo[data-state="calendar"] .card-one {
  transform: translate(92px, -18px) rotate(-2deg);
}

.premium-companion-demo[data-state="approval"] .panel-approval {
  opacity: 1;
  transform: translate(-32px, -12px) scale(1.08);
}

.premium-companion-demo[data-state="approval"] .card-three {
  transform: translate(120px, -70px) rotate(3deg);
}

.premium-companion-demo[data-state="done"] .workspace-result {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.premium-companion-demo[data-state="done"] .workspace-card {
  opacity: 0.62;
  transform: translateX(140px) scale(0.92);
}

.promo-reel {
  position: relative;
  overflow: hidden;
  min-height: 0;
  padding: clamp(10px, 1.25vw, 14px);
  color: #18322d;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(236, 244, 241, 0.96)),
    #eef4f1;
  border: 1px solid rgba(18, 121, 111, 0.13);
  border-radius: 8px;
  box-shadow: 0 26px 76px rgba(22, 34, 31, 0.15);
}

.promo-reel::after {
  display: none;
}

.promo-reel-top {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  font-size: 0.78rem;
  font-weight: 760;
}

.promo-reel-top span {
  color: var(--teal-dark);
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.promo-reel-top strong {
  padding: 7px 10px;
  color: var(--teal-dark);
  background: rgba(18, 121, 111, 0.08);
  border: 1px solid rgba(18, 121, 111, 0.12);
  border-radius: 8px;
  white-space: nowrap;
}

.promo-video {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #101815;
  border: 8px solid rgba(23, 32, 28, 0.92);
  border-radius: 28px;
  box-shadow: 0 22px 52px rgba(22, 34, 31, 0.16);
}

.promo-storyboard {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
  margin: 0;
}

.promo-storyboard img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #101815;
  border: 1px solid rgba(23, 32, 28, 0.18);
  border-radius: 8px;
  box-shadow: 0 18px 46px rgba(22, 34, 31, 0.14);
}

.promo-storyboard figcaption {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.promo-storyboard figcaption span {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  padding: 6px 8px;
  color: #2f4841;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(18, 121, 111, 0.11);
  border-radius: 8px;
  font-size: 0.73rem;
  font-weight: 760;
  line-height: 1.15;
  text-align: center;
}

.promo-stage {
  position: relative;
  z-index: 1;
  display: grid;
  min-height: 220px;
  grid-template-columns: minmax(90px, 0.72fr) minmax(170px, 1fr);
  gap: 16px;
  align-items: center;
}

.promo-avatar-group {
  display: grid;
  gap: 12px;
  justify-items: center;
}

.promo-avatar-group img {
  width: clamp(82px, 10vw, 118px);
  height: clamp(82px, 10vw, 118px);
  object-fit: cover;
  background: #fff;
  border: 5px solid #fff;
  border-radius: 999px;
  box-shadow: 0 18px 42px rgba(22, 34, 31, 0.18);
  animation: avatarFloat 6s ease-in-out infinite;
}

.promo-avatar-group img + img {
  width: clamp(70px, 8vw, 94px);
  height: clamp(70px, 8vw, 94px);
  margin-top: -30px;
  margin-left: 48px;
  animation-delay: -2s;
}

.promo-phone {
  position: relative;
  display: grid;
  gap: 8px;
  min-height: 198px;
  padding: 28px 13px 14px;
  background: #f8fbf7;
  border: 9px solid #1f2926;
  border-radius: 28px;
  box-shadow: 0 22px 46px rgba(22, 34, 31, 0.24);
  animation: phonePulse 7s ease-in-out infinite;
}

.phone-speaker {
  position: absolute;
  top: 10px;
  left: 50%;
  width: 46px;
  height: 5px;
  background: rgba(31, 41, 38, 0.28);
  border-radius: 99px;
  transform: translateX(-50%);
}

.phone-message {
  max-width: 88%;
  padding: 8px 10px;
  font-size: clamp(0.76rem, 1.2vw, 0.88rem);
  font-weight: 750;
  line-height: 1.2;
  border-radius: 14px;
  box-shadow: 0 8px 18px rgba(22, 34, 31, 0.08);
  animation: messageLift 8s ease-in-out infinite;
}

.phone-message.user {
  justify-self: end;
  color: #fff;
  background: var(--teal-dark);
}

.phone-message.agent {
  color: #283a34;
  background: #fff;
  animation-delay: -1.5s;
}

.phone-message.alt {
  background: #fff4e8;
  animation-delay: -3s;
}

.phone-action {
  justify-self: start;
  min-height: 34px;
  padding: 8px 12px;
  color: #fff;
  background: var(--coral);
  border-radius: 8px;
  font-size: 0.8rem;
  font-weight: 900;
  animation: actionGlow 3.6s ease-in-out infinite;
}

.promo-task-stack {
  position: absolute;
  right: clamp(4px, 2vw, 18px);
  bottom: 0;
  display: grid;
  gap: 8px;
  width: min(220px, 44%);
  pointer-events: none;
}

.promo-task-stack span {
  padding: 8px 10px;
  color: #33443e;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 8px;
  font-size: 0.78rem;
  font-weight: 850;
  box-shadow: 0 10px 24px rgba(22, 34, 31, 0.1);
  animation: taskSlide 6s ease-in-out infinite;
}

.promo-task-stack span:nth-child(2) {
  animation-delay: -1.3s;
}

.promo-task-stack span:nth-child(3) {
  animation-delay: -2.6s;
}

.split-options {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.split-option {
  position: relative;
  display: grid;
  gap: 6px;
  min-height: 0;
  padding: clamp(14px, 1.55vw, 18px);
  color: inherit;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(216, 222, 214, 0.88);
  border-radius: 8px;
  text-decoration: none;
  box-shadow: var(--soft-shadow);
  transition: border-color 260ms ease, box-shadow 260ms ease, transform 260ms ease;
}

.split-option:hover {
  border-color: rgba(18, 121, 111, 0.45);
  box-shadow: var(--shadow);
}

.split-option.is-cliff-highlight {
  border-color: rgba(18, 121, 111, 0.54);
  box-shadow: 0 18px 50px rgba(18, 121, 111, 0.16);
  transform: translateY(-2px);
}

.split-option h2 {
  margin-bottom: 0;
  font-size: clamp(1.24rem, 1.55vw, 1.55rem);
  font-weight: 760;
  line-height: 1.08;
}

.split-option p {
  max-width: 720px;
  color: var(--muted);
  margin-bottom: 30px;
  font-size: 0.84rem;
  line-height: 1.34;
}

.card-cta {
  position: absolute;
  top: clamp(16px, 1.8vw, 20px);
  right: clamp(16px, 1.8vw, 20px);
  display: inline-flex;
  width: fit-content;
  min-height: 30px;
  align-items: center;
  padding: 6px 9px;
  color: var(--teal-dark);
  background: rgba(18, 121, 111, 0.08);
  border: 1px solid rgba(18, 121, 111, 0.12);
  border-radius: 8px;
  font-size: 0.8rem;
  font-weight: 760;
}

.split-option.business .card-cta {
  color: #813e26;
  background: rgba(216, 111, 69, 0.09);
  border-color: rgba(216, 111, 69, 0.14);
}

.split-agent-row {
  display: flex;
  align-items: center;
  min-height: 38px;
  margin-bottom: 0;
}

.split-agent-row img {
  width: 38px;
  height: 38px;
  object-fit: cover;
  border: 3px solid #fff;
  border-radius: 999px;
  box-shadow: 0 10px 24px rgba(22, 34, 31, 0.12);
}

.split-agent-row img + img {
  margin-left: -14px;
}

.split-agent-label {
  margin-left: 10px;
  color: var(--teal-dark);
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1.1;
}

.split-option.personal {
  background: #fffaf2;
}

.split-option.business {
  background: #eef4f0;
}

.hero-copy {
  min-width: 0;
  max-width: 760px;
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--teal-dark);
  font-size: 0.78rem;
  font-weight: 760;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

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

h1 {
  margin-bottom: 20px;
  max-width: 820px;
  font-size: clamp(3rem, 4.8vw, 4.55rem);
  font-weight: 760;
  line-height: 1;
  letter-spacing: 0;
  overflow-wrap: break-word;
}

h2 {
  margin-bottom: 14px;
  font-size: clamp(2rem, 4vw, 4.2rem);
  font-weight: 760;
  line-height: 1.04;
  letter-spacing: 0;
}

h3 {
  margin-bottom: 10px;
  font-size: 1.05rem;
  font-weight: 760;
}

.lead {
  max-width: 610px;
  color: #3f4d45;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  line-height: 1.55;
}

.hero-actions,
.trust-row,
.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 0 20px;
  font-weight: 760;
  text-decoration: none;
  cursor: pointer;
}

.primary {
  color: #fff;
  background: var(--teal);
}

.primary:hover {
  background: var(--teal-dark);
}

.secondary {
  color: var(--teal-dark);
  background: rgba(255, 255, 255, 0.66);
  border-color: var(--line);
}

.trust-row {
  margin-top: 28px;
}

.section-cta {
  margin-top: 24px;
}

.business-snapshot-section {
  padding: clamp(46px, 6vw, 76px) clamp(18px, 5vw, 72px);
  background:
    radial-gradient(circle at 16% 18%, rgba(0, 121, 107, 0.1), transparent 32%),
    linear-gradient(135deg, #eef6f1 0%, #f7faf7 48%, #eef3ef 100%);
  border-top: 1px solid rgba(216, 222, 214, 0.72);
  scroll-margin-top: 86px;
}

.business-snapshot-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(240px, 0.64fr) minmax(240px, 0.64fr);
  gap: 16px;
  max-width: 1180px;
  margin: 0 auto;
}

.business-snapshot-grid article {
  min-height: 0;
  padding: clamp(18px, 2.2vw, 28px);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
  box-shadow: 0 22px 46px rgba(20, 31, 26, 0.08);
}

.business-snapshot-grid .snapshot-main {
  grid-row: span 2;
  display: grid;
  align-content: center;
  position: relative;
  overflow: hidden;
  padding: clamp(28px, 4vw, 46px);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.88)),
    linear-gradient(135deg, rgba(0, 121, 107, 0.13), transparent 46%);
  border-color: rgba(0, 121, 107, 0.16);
}

.business-snapshot-grid .snapshot-main::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 6px;
  background: linear-gradient(180deg, var(--teal), #0f3d35);
}

.business-snapshot-grid .snapshot-main > * {
  position: relative;
}

.business-snapshot-grid h2 {
  max-width: 760px;
  font-size: clamp(2rem, 3vw, 2.92rem);
  line-height: 1.02;
}

.business-snapshot-grid h3 {
  margin-top: 8px;
  color: #16201a;
  font-size: clamp(1.04rem, 1.25vw, 1.24rem);
  line-height: 1.26;
}

.business-snapshot-grid p,
.snapshot-proof,
.compact-pill-list span,
.compact-metric-row span {
  color: var(--muted);
  line-height: 1.45;
}

.snapshot-card {
  display: flex;
  flex-direction: column;
}

.snapshot-card .eyebrow,
.snapshot-proof .eyebrow {
  color: rgba(0, 93, 82, 0.78);
}

.compact-pill-list,
.compact-metric-row,
.compact-process-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.compact-pill-list span,
.compact-metric-row span,
.compact-process-list span {
  padding: 8px 10px;
  background: #f8fbf8;
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
  font-size: 0.84rem;
  font-weight: 760;
}

.snapshot-card .compact-pill-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding-top: 12px;
}

.snapshot-card .compact-pill-list span {
  display: flex;
  align-items: center;
  min-height: 38px;
  color: #415149;
  background: linear-gradient(180deg, #ffffff, #f6faf7);
}

.snapshot-card .compact-pill-list span::before {
  content: "";
  flex: 0 0 auto;
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: var(--teal);
  opacity: 0.72;
}

.snapshot-proof {
  grid-column: 2 / 4;
  background:
    linear-gradient(135deg, #ffffff 0%, #f8fbf8 62%, rgba(0, 121, 107, 0.08) 100%);
}

.snapshot-proof h3 {
  max-width: 460px;
}

.compact-metric-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.compact-metric-row span {
  min-height: 76px;
  padding: 13px 12px;
  color: #526058;
  background: #ffffff;
  border-color: rgba(0, 121, 107, 0.14);
  box-shadow: 0 10px 22px rgba(20, 31, 26, 0.05);
}

.compact-metric-row strong {
  display: block;
  color: var(--teal-dark);
  font-size: 1.12rem;
  line-height: 1.05;
}

.compact-metric-row small {
  display: block;
  margin-top: 3px;
  color: #69766f;
  font-size: 0.74rem;
  line-height: 1.18;
}

.compact-process-list {
  max-width: 620px;
  margin-top: 20px;
}

.compact-process-list span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #ffffff;
}

.compact-process-list strong {
  display: inline-grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border-radius: 50%;
  background: var(--teal-dark);
  color: #ffffff;
  font-size: 0.78rem;
}

.home-proof-section,
.home-start-section {
  padding: clamp(52px, 7vw, 92px) clamp(18px, 5vw, 72px);
  border-top: 1px solid rgba(216, 222, 214, 0.72);
}

.home-proof-section {
  background:
    radial-gradient(circle at 12% 0%, rgba(0, 121, 107, 0.09), transparent 34%),
    linear-gradient(180deg, #f7faf7 0%, #eef4f0 100%);
}

.home-proof-heading,
.home-proof-grid,
.home-start-card,
.home-offer-grid {
  max-width: 1180px;
  margin: 0 auto;
}

.home-proof-heading {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(320px, 0.72fr);
  gap: clamp(20px, 4vw, 64px);
  align-items: end;
}

.home-proof-heading .eyebrow {
  grid-column: 1 / -1;
  margin-bottom: -4px;
}

.home-proof-heading h2 {
  max-width: 780px;
  margin-bottom: 0;
  font-size: clamp(2rem, 3.9vw, 3.8rem);
  line-height: 1.03;
}

.home-proof-heading p {
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.55;
}

.home-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: clamp(24px, 4vw, 44px);
}

.home-proof-grid article,
.home-offer-grid article,
.home-start-card {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
  box-shadow: 0 18px 38px rgba(20, 31, 26, 0.07);
}

.home-proof-grid article {
  display: grid;
  gap: 10px;
  min-height: 220px;
  padding: clamp(20px, 2.4vw, 30px);
}

.home-proof-grid span {
  width: max-content;
  padding: 6px 9px;
  color: var(--teal-dark);
  background: #edf7f3;
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 900;
}

.home-proof-grid h3,
.home-offer-grid h3 {
  margin-bottom: 0;
  font-size: clamp(1.18rem, 1.7vw, 1.62rem);
  line-height: 1.12;
}

.home-proof-grid p,
.home-offer-grid p {
  margin-bottom: 0;
  color: var(--muted);
  line-height: 1.48;
}

.home-start-section {
  background:
    linear-gradient(135deg, #fbf7ef 0%, #f4f7f2 52%, #edf4f0 100%);
}

.home-start-card {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(360px, 1fr);
  gap: clamp(22px, 4vw, 62px);
  align-items: center;
  padding: clamp(24px, 4vw, 42px);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.82)),
    linear-gradient(135deg, rgba(18, 121, 111, 0.12), transparent);
}

.home-start-card h2 {
  max-width: 580px;
  margin-bottom: 0;
  font-size: clamp(1.85rem, 3.4vw, 3.1rem);
}

.home-start-steps {
  display: grid;
  gap: 10px;
}

.home-start-steps span {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: center;
  min-height: 56px;
  padding: 10px 12px;
  color: #2d4038;
  background: #ffffff;
  border: 1px solid rgba(216, 222, 214, 0.88);
  border-radius: 8px;
  font-weight: 780;
}

.home-start-steps strong {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  color: #ffffff;
  background: var(--teal);
  border-radius: 50%;
  font-size: 0.9rem;
}

.home-offer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}

.home-offer-grid article {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 210px;
  padding: clamp(20px, 2.4vw, 30px);
}

.home-offer-grid .text-link {
  align-self: end;
  margin-top: 8px;
}

@media (max-width: 860px) {
  .business-snapshot-grid {
    grid-template-columns: 1fr;
  }

  .business-snapshot-grid .snapshot-main {
    grid-row: auto;
  }

  .snapshot-proof {
    grid-column: auto;
  }

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

  .home-proof-heading,
  .home-start-card,
  .home-offer-grid {
    grid-template-columns: 1fr;
  }

  .home-proof-grid {
    grid-template-columns: 1fr;
  }
}

.trust-row span {
  padding: 8px 12px;
  color: #47564d;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 700;
}

.assistant-panel {
  display: grid;
  gap: 16px;
  align-self: stretch;
  max-height: 720px;
}

.business-hero-photo {
  align-self: center;
  overflow: hidden;
  margin: 0;
  background: #0f1720;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.business-hero-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: 50% 50%;
}

.hero-agent-mosaic {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-self: center;
}

.hero-agent-mosaic article {
  display: grid;
  overflow: hidden;
  min-height: 310px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.hero-agent-mosaic img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

.hero-agent-mosaic div {
  padding: 18px;
}

.hero-agent-mosaic h2 {
  margin-bottom: 0;
  font-size: clamp(1.7rem, 3vw, 2.5rem);
}

.hero-agent-mosaic .status {
  margin-bottom: 6px;
  color: var(--teal-dark);
  font-size: 0.82rem;
  font-weight: 800;
}

.assistant-profile {
  display: grid;
  grid-template-columns: minmax(220px, 0.95fr) minmax(0, 1fr);
  overflow: hidden;
  min-height: 250px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 16px 34px rgba(22, 34, 31, 0.09);
}

.assistant-profile.featured {
  min-height: 300px;
  box-shadow: var(--shadow);
}

.assistant-profile img {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  object-fit: cover;
  object-position: 50% 50%;
  background: #fff7ef;
}

.assistant-meta {
  display: grid;
  align-content: center;
  padding: 26px;
}

.assistant-meta h2 {
  margin-bottom: 8px;
  font-size: clamp(1.8rem, 3vw, 3.1rem);
}

.assistant-meta p {
  color: var(--muted);
  line-height: 1.55;
}

.assistant-meta .status {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--teal-dark);
  font-size: 0.88rem;
  font-weight: 800;
}

.section,
.examples-section,
.audience-section,
.case-study-section,
.people-section,
.answer-section,
.booking-section,
.trust-section,
.why-section,
.workflow-section,
.model-section,
.control-section,
.pricing-section,
.case-hero,
.case-detail-section,
.case-quote-section {
  padding: clamp(72px, 8vw, 108px) clamp(18px, 5vw, 72px);
  border-top: 1px solid rgba(216, 222, 214, 0.72);
}

.section-heading {
  max-width: 850px;
}

.section-heading.subheading {
  margin-top: clamp(32px, 5vw, 54px);
}

.service-grid,
.example-list,
.audience-grid,
.people-gallery,
.teen-grid,
.case-study-grid,
.why-grid,
.workflow-grid,
.model-grid,
.control-grid,
.price-grid,
.case-detail-grid {
  display: grid;
  gap: 14px;
  margin-top: 28px;
}

.service-grid,
.audience-grid,
.people-gallery,
.teen-grid,
.model-grid,
.control-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

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

.case-study-grid {
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.72fr);
  gap: clamp(18px, 4vw, 42px);
}

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

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

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

.service-grid article,
.example-list span,
.audience-grid article,
.people-gallery article,
.teen-grid article,
.case-summary,
.testimonial-card,
.why-grid article,
.workflow-grid article,
.case-detail-grid article,
.case-metric-panel,
.model-grid article,
.control-grid article,
.price-grid article,
.booking-form,
.mini-card,
.assistant-option {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.service-grid article,
.audience-grid article,
.people-gallery article,
.teen-grid article,
.why-grid article,
.workflow-grid article,
.case-detail-grid article,
.control-grid article {
  min-height: 178px;
  padding: 22px;
  box-shadow: var(--soft-shadow);
}

.examples-section {
  background: var(--paper);
}

.audience-section {
  background: #fffaf2;
}

.people-section {
  background: #eef4f0;
}

.case-study-section {
  background: #eef4f0;
}

.answer-section {
  background: var(--paper);
}

.why-section {
  background: var(--paper);
}

.workflow-section {
  background: #fffaf2;
}

.personal-hero {
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.78fr);
  min-height: 0;
  align-items: center;
  padding-top: clamp(34px, 5vw, 64px);
  padding-bottom: clamp(30px, 4vw, 52px);
  background:
    linear-gradient(115deg, rgba(216, 111, 69, 0.1), rgba(197, 150, 55, 0.15) 48%, rgba(18, 121, 111, 0.1)),
    var(--paper);
}

.personal-hero .hero-copy {
  max-width: 720px;
}

.personal-hero-storyboard {
  width: 100%;
  max-width: 560px;
  margin: 0;
  justify-self: end;
}

.personal-hero-storyboard img {
  display: block;
  width: 100%;
  aspect-ratio: 1.18;
  object-fit: cover;
  object-position: center;
  border: 1px solid rgba(18, 121, 111, 0.18);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.case-detail-section {
  background: var(--paper);
}

.case-detail-section.alt {
  background: #eef4f0;
}

.case-quote-section {
  background: #fffaf2;
}

.example-list span {
  display: flex;
  align-items: center;
  min-height: 72px;
  padding: 16px 18px;
  color: #334139;
  font-weight: 800;
  box-shadow: var(--soft-shadow);
}

.service-grid p,
.audience-grid p,
.people-gallery p,
.teen-grid p,
.faq-list p,
.case-summary p,
.why-grid p,
.workflow-grid p,
.case-detail-grid p,
.case-metric-panel p,
.model-grid p,
.control-grid p,
.price-grid p,
.booking-copy p,
.trust-section p,
.form-note,
.pricing-note {
  color: var(--muted);
  line-height: 1.55;
}

.faq-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}

.faq-list article {
  min-height: 184px;
  padding: 22px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.faq-list a {
  color: var(--teal-dark);
  font-weight: 800;
  text-decoration: none;
}

.faq-list a:hover {
  text-decoration: underline;
}

.case-cta {
  width: fit-content;
  margin-top: 8px;
}

.teen-grid article {
  display: grid;
  align-content: start;
  min-height: 300px;
  padding: 18px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.people-gallery article {
  display: grid;
  min-height: 340px;
  align-content: start;
  padding: 18px;
}

.compact-persona-section {
  padding-top: clamp(36px, 5vw, 62px);
  padding-bottom: clamp(38px, 5vw, 66px);
}

.compact-payment-section {
  padding-top: clamp(38px, 5vw, 64px);
  padding-bottom: clamp(42px, 5vw, 68px);
  background: #fffaf2;
}

.compact-payment-section .section-heading {
  max-width: 680px;
}

.compact-payment-section .section-heading h2 {
  font-size: clamp(2rem, 4vw, 3.05rem);
}

.payment-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.payment-grid article {
  min-height: 0;
  padding: 20px;
}

.payment-grid h3 {
  margin: 0;
  font-size: 1.08rem;
}

.payment-grid p:not(.plan-label) {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.payment-grid strong {
  font-size: clamp(1.8rem, 3vw, 2.65rem);
}

.simple-payment-grid article {
  min-height: 178px;
}

.compact-persona-section .section-heading {
  max-width: 760px;
}

.compact-persona-section .section-heading h2 {
  font-size: clamp(2rem, 4vw, 3.1rem);
}

.avatar-strip {
  display: grid;
  grid-template-columns: repeat(7, minmax(88px, 1fr));
  gap: 12px;
  margin-top: 24px;
}

.avatar-strip article {
  display: grid;
  gap: 6px;
  justify-items: center;
  min-height: 0;
  padding: 10px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.avatar-strip .agent-avatar {
  width: 100%;
  max-width: 96px;
  margin-bottom: 0;
}

.avatar-strip h3 {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.1;
  text-align: center;
}

.avatar-strip p {
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}

.agent-avatar {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  margin-bottom: 18px;
  object-fit: cover;
  object-position: 50% 50%;
  background: #fff;
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
}

.teen-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}

.teen-gallery article {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 164px;
  padding: 18px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.teen-gallery .agent-avatar {
  margin-bottom: 0;
}

.teen-gallery p {
  color: var(--muted);
  line-height: 1.55;
}

.portrait,
.kid {
  position: relative;
  display: block;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 32%, rgba(255, 255, 255, 0.72), transparent 26%),
    linear-gradient(145deg, rgba(18, 121, 111, 0.14), rgba(216, 111, 69, 0.13));
}

.portrait {
  height: 174px;
  margin-bottom: 18px;
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
}

.portrait .head,
.portrait .hair,
.portrait .body {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.portrait .head {
  z-index: 2;
  top: 40px;
  width: 68px;
  height: 78px;
  background: var(--skin);
  border-radius: 45% 45% 48% 48%;
  box-shadow: inset -7px -8px 0 rgba(61, 35, 24, 0.08);
}

.portrait .hair {
  z-index: 3;
  top: 28px;
  width: 78px;
  height: 48px;
  background: var(--hair);
  border-radius: 44px 44px 18px 18px;
}

.portrait .body {
  bottom: -32px;
  width: 136px;
  height: 88px;
  background: var(--shirt);
  border-radius: 52px 52px 12px 12px;
}

.portrait.hair-curly .hair {
  top: 24px;
  width: 92px;
  height: 58px;
  border-radius: 50%;
  box-shadow:
    -18px 10px 0 -6px var(--hair),
    18px 10px 0 -6px var(--hair),
    -8px -8px 0 -9px var(--hair);
}

.portrait.hair-straight .hair {
  width: 88px;
  height: 64px;
  border-radius: 42px 42px 20px 20px;
}

.portrait.hair-bob .hair {
  top: 28px;
  width: 88px;
  height: 78px;
  border-radius: 44px 44px 30px 30px;
}

.portrait.hair-bob .head {
  top: 48px;
}

.portrait.hair-bob .body {
  bottom: -38px;
}

.kids-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.kid {
  width: 74px;
  height: 74px;
  border: 1px solid rgba(18, 121, 111, 0.18);
  border-radius: 8px;
}

.kid::before,
.kid::after {
  position: absolute;
  left: 50%;
  content: "";
  transform: translateX(-50%);
}

.kid::before {
  z-index: 2;
  top: 20px;
  width: 28px;
  height: 32px;
  background: var(--skin);
  border-radius: 46%;
}

.kid::after {
  bottom: -12px;
  width: 54px;
  height: 34px;
  background: var(--shirt);
  border-radius: 28px 28px 8px 8px;
}

.kid.hair-short {
  box-shadow: inset 0 16px 0 -4px var(--hair);
}

.kid.hair-bob {
  box-shadow: inset 0 24px 0 -5px var(--hair);
}

.kid.hair-curly {
  box-shadow: inset 0 19px 0 -3px var(--hair), inset 13px 8px 0 -5px var(--hair), inset -13px 8px 0 -5px var(--hair);
}

.kid.hair-puffs {
  box-shadow: inset 0 18px 0 -5px var(--hair);
}

.kid.hair-puffs span,
.kid.hair-puffs::before {
  box-shadow: -19px -6px 0 -8px var(--hair), 19px -6px 0 -8px var(--hair);
}

.skin-deep {
  --skin: #6a3f2b;
  --hair: #1b1512;
}

.skin-rich {
  --skin: #8a5536;
  --hair: #211513;
}

.skin-warm {
  --skin: #c9905f;
  --hair: #211712;
}

.skin-light {
  --skin: #d7a474;
  --hair: #171414;
}

.skin-tan {
  --skin: #b8754e;
  --hair: #2a1712;
}

.skin-fair {
  --skin: #e3b989;
  --hair: #7b5134;
}

.shirt-teal {
  --shirt: var(--teal);
}

.shirt-coral {
  --shirt: var(--coral);
}

.shirt-gold {
  --shirt: var(--gold);
}

.shirt-ink {
  --shirt: #26332d;
}

.case-summary,
.testimonial-card {
  padding: clamp(20px, 3vw, 30px);
  box-shadow: var(--soft-shadow);
}

.metric-card {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
  padding: 18px;
  background: #fffaf2;
  border: 1px solid rgba(18, 121, 111, 0.24);
  border-radius: 8px;
}

.metric-card div,
.case-metric-panel div {
  display: grid;
  gap: 3px;
}

.metric-card div + div,
.case-metric-panel div + div {
  padding-top: 12px;
  border-top: 1px solid rgba(18, 121, 111, 0.18);
}

.metric-card strong {
  color: var(--teal-dark);
  font-size: clamp(1.65rem, 3vw, 2.45rem);
  line-height: 0.95;
}

.metric-card span {
  color: #334139;
  font-weight: 800;
}

.text-link {
  display: inline-flex;
  margin-top: 18px;
  color: var(--teal-dark);
  font-weight: 800;
  text-decoration: none;
}

.text-link:hover {
  text-decoration: underline;
}

.workflow-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  margin-bottom: 18px;
  color: #fff;
  background: var(--teal);
  border-radius: 999px;
  font-weight: 800;
}

.case-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.36fr);
  gap: clamp(22px, 4vw, 52px);
  align-items: center;
  min-height: min(660px, calc(100vh - 67px));
  padding-top: clamp(46px, 6vw, 82px);
  padding-bottom: clamp(46px, 6vw, 82px);
  background:
    linear-gradient(115deg, rgba(18, 121, 111, 0.12), rgba(216, 111, 69, 0.1) 48%, rgba(197, 150, 55, 0.14)),
    var(--paper);
}

.case-hero h1 {
  max-width: 930px;
  margin-bottom: 18px;
  font-size: clamp(2.75rem, 5.15vw, 5.35rem);
  line-height: 0.98;
}

.case-hero .lead {
  max-width: 760px;
  font-size: clamp(1rem, 1.45vw, 1.18rem);
  line-height: 1.5;
}

.case-metric-panel {
  display: grid;
  gap: 10px;
  padding: clamp(20px, 3vw, 30px);
  box-shadow: var(--shadow);
}

.case-metric-panel strong {
  color: var(--teal-dark);
  font-size: clamp(1.9rem, 3vw, 3.05rem);
  line-height: 0.94;
}

.case-metric-panel span {
  color: var(--ink);
  font-size: 0.98rem;
  font-weight: 800;
}

.case-quote-section {
  display: grid;
  gap: 14px;
}

.case-quote-section blockquote {
  max-width: 980px;
  margin-bottom: 0;
}

.case-quote-section > p {
  color: var(--teal-dark);
  font-weight: 800;
}

.case-summary p:last-child,
.testimonial-card p {
  margin-bottom: 0;
}

.testimonial-card {
  display: grid;
  align-content: center;
  border-color: rgba(18, 121, 111, 0.32);
}

blockquote {
  margin: 0 0 18px;
  color: var(--ink);
  font-size: clamp(1.08rem, 1.7vw, 1.28rem);
  line-height: 1.55;
}

.testimonial-card p {
  color: var(--teal-dark);
  font-weight: 800;
}

.outcome-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
}

.outcome-row span {
  min-height: 70px;
  padding: 16px 18px;
  color: #334139;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-weight: 800;
}

.proof-row {
  margin-bottom: 24px;
}

.proof-row span {
  display: grid;
  gap: 4px;
  align-content: start;
  min-height: 116px;
  background: rgba(255, 255, 255, 0.86);
}

.proof-row strong {
  display: block;
  color: var(--teal-dark);
  font-size: clamp(1.2rem, 2.2vw, 2rem);
  line-height: 1;
}

.model-grid article {
  min-height: 230px;
  padding: 22px;
  box-shadow: var(--soft-shadow);
}

.model-grid span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  margin-bottom: 18px;
  color: #fff;
  background: var(--teal);
  border-radius: 8px;
  font-size: 0.84rem;
  font-weight: 800;
}

.price-grid article {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 250px;
  padding: 24px;
  box-shadow: var(--soft-shadow);
}

.price-grid article.recommended {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(18, 121, 111, 0.12), 0 18px 40px rgba(22, 34, 31, 0.1);
}

.plan-label {
  margin: 0;
  color: var(--teal-dark);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.price-grid strong {
  color: var(--ink);
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  line-height: 1;
}

.pricing-note {
  max-width: 850px;
  margin: 20px 0 0;
}

.trust-section {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.72fr);
  gap: clamp(24px, 5vw, 64px);
  align-items: center;
  background: #fffaf2;
  border-top: 1px solid rgba(216, 222, 214, 0.8);
  border-bottom: 1px solid rgba(216, 222, 214, 0.8);
}

.trust-section h2 {
  margin-bottom: 0;
  max-width: 850px;
}

.trust-section > p {
  max-width: 560px;
  margin: 0;
  padding: 22px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.model-section,
.pricing-section {
  background: var(--paper);
}

.control-section,
.booking-section {
  background: #eef4f0;
}

.booking-section {
  display: grid;
  min-height: 0;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.92fr);
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}

.booking-copy {
  position: sticky;
  top: 100px;
  max-width: 780px;
}

.mini-card {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  max-width: 560px;
  margin-top: 22px;
  padding: 16px;
}

.mini-card span {
  color: var(--teal-dark);
  font-weight: 800;
}

.start-price-card {
  background: #fffaf2;
}

.start-price-card span {
  color: var(--muted);
  font-weight: 700;
}

.booking-form {
  display: grid;
  gap: 16px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 16px 40px rgba(22, 34, 31, 0.08);
}

.start-flow-form {
  gap: 20px;
}

.start-flow-form fieldset,
.start-flow-form .guided-field,
.start-contact-panel,
.start-guardrail-note {
  padding: 16px;
  background: #fbfdfb;
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
}

.start-flow-form .assistant-picker {
  gap: 10px;
}

.start-flow-form .assistant-picker legend,
.start-flow-form .field-label {
  margin-bottom: 6px;
  color: var(--teal-dark);
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.03em;
}

.start-flow-form .support-picker .assistant-option {
  min-height: 82px;
}

.start-process-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.start-process-card {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 16px;
  background: #ffffff;
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
  box-shadow: 0 10px 24px rgba(20, 31, 26, 0.05);
}

.start-process-card.business {
  background: linear-gradient(180deg, #ffffff, #f7fbf9);
  border-color: rgba(18, 121, 111, 0.18);
}

.start-process-card h3 {
  margin-bottom: 0;
  font-size: clamp(1rem, 1.4vw, 1.22rem);
  line-height: 1.2;
}

.start-process-card .compact-process-list {
  display: grid;
  gap: 7px;
  margin-top: 0;
}

.start-process-card .compact-process-list span {
  min-height: 36px;
  padding: 7px 8px;
  font-size: 0.78rem;
  line-height: 1.18;
}

.start-process-card .compact-process-list strong {
  width: 20px;
  height: 20px;
  font-size: 0.7rem;
}

.start-process-card .button {
  min-height: 42px;
  margin-top: 2px;
  padding: 0 12px;
  font-size: 0.82rem;
}

.start-flow-form .guided-field {
  gap: 12px;
}

.start-contact-panel {
  display: grid;
  gap: 14px;
}

.start-contact-panel .form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.start-guardrail-note {
  display: grid;
  gap: 5px;
  color: #405149;
  background: #fffaf2;
  border-color: rgba(196, 147, 51, 0.2);
  line-height: 1.42;
}

.start-guardrail-note strong {
  color: #533a09;
}

.start-guardrail-note span {
  color: #5f655d;
  font-size: 0.9rem;
}

.start-choice-section {
  display: grid;
  align-content: start;
  gap: clamp(22px, 3.6vw, 38px);
  min-height: calc(100svh - 67px);
  padding: clamp(40px, 6vw, 78px) clamp(18px, 5vw, 72px);
  background:
    radial-gradient(circle at 14% 4%, rgba(18, 121, 111, 0.14), transparent 28%),
    radial-gradient(circle at 86% 8%, rgba(196, 147, 51, 0.16), transparent 30%),
    linear-gradient(135deg, #f8faf7 0%, #edf5f1 55%, #fbf4ea 100%);
}

.start-choice-heading,
.start-choice-grid,
.start-choice-note {
  width: min(100%, 1060px);
  margin-right: auto;
  margin-left: auto;
}

.start-choice-heading {
  display: grid;
  gap: 8px;
  text-align: center;
}

.start-choice-heading h1 {
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
  max-width: 720px;
  font-size: clamp(2.55rem, 5vw, 4.7rem);
  line-height: 0.98;
}

.start-choice-heading .lead {
  margin-right: auto;
  margin-left: auto;
  max-width: 520px;
  color: #46554d;
}

.start-path-switch {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: min(100%, 420px);
  margin: 16px auto 0;
  padding: 6px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
  box-shadow: 0 10px 26px rgba(22, 34, 31, 0.06);
}

.start-path-switch a {
  display: flex;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: var(--teal-dark);
  background: rgba(248, 252, 250, 0.92);
  border: 1px solid rgba(18, 121, 111, 0.1);
  border-radius: 7px;
  font-size: 0.86rem;
  font-weight: 850;
  text-decoration: none;
}

.start-path-switch a:hover {
  background: #fff;
  border-color: rgba(18, 121, 111, 0.28);
}

.start-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 2.4vw, 28px);
}

.start-choice-card {
  position: relative;
  display: grid;
  overflow: hidden;
  gap: 15px;
  align-content: start;
  min-height: 440px;
  padding: clamp(22px, 3vw, 36px);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 251, 244, 0.9)),
    #fffaf2;
  border: 1px solid rgba(216, 222, 214, 0.94);
  border-radius: 8px;
  box-shadow: 0 28px 70px rgba(20, 31, 26, 0.12);
}

.start-choice-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--gold), rgba(18, 121, 111, 0.54));
}

.start-choice-card > * {
  position: relative;
}

.start-choice-card.business {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(245, 251, 248, 0.92)),
    #f8fcfa;
  border-color: rgba(18, 121, 111, 0.2);
}

.start-choice-card.business::before {
  background: linear-gradient(90deg, var(--teal), rgba(196, 147, 51, 0.66));
}

.start-card-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.start-card-topline .split-agent-row {
  min-height: 44px;
}

.start-card-topline .split-agent-row img {
  width: 44px;
  height: 44px;
}

.start-card-topline span {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 7px 10px;
  color: var(--teal-dark);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
}

.start-choice-card h2 {
  margin-bottom: 0;
  font-size: clamp(1.85rem, 3vw, 2.7rem);
  line-height: 1.02;
}

.start-choice-card p {
  margin-bottom: 0;
  color: var(--muted);
  line-height: 1.5;
}

.start-price-line {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 4px 0 2px;
}

.start-choice-card.business .start-price-line {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.start-price-line span {
  display: grid;
  min-height: 68px;
  align-content: center;
  gap: 2px;
  padding: 12px;
  color: #425249;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(216, 222, 214, 0.9);
  border-radius: 8px;
  font-size: 0.84rem;
  line-height: 1.2;
}

.start-price-line strong {
  color: var(--teal-dark);
  font-size: 1.12rem;
}

.start-choice-card .button {
  min-height: 48px;
}

.start-choice-card .button.google {
  margin-top: 6px;
  border-color: rgba(18, 121, 111, 0.18);
  box-shadow: 0 10px 22px rgba(20, 31, 26, 0.05);
}

.start-choice-note {
  max-width: 820px;
  padding: 12px 16px;
  color: #58665e;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(216, 222, 214, 0.82);
  border-radius: 8px;
  text-align: center;
  line-height: 1.5;
}

.signup-actions {
  display: grid;
  gap: 10px;
}

.signup-actions-top {
  margin-top: 2px;
}

.button.google {
  gap: 10px;
  justify-content: center;
  border-color: #dadce0;
  background: #ffffff;
  color: #3c4043;
  box-shadow: 0 1px 2px rgba(60, 64, 67, 0.08);
}

.button.google:hover {
  border-color: #c5c8cc;
  background: #f8fafd;
  box-shadow: 0 2px 6px rgba(60, 64, 67, 0.14);
}

.google-mark {
  display: inline-grid;
  width: 20px;
  height: 20px;
  place-items: center;
  flex: 0 0 auto;
  line-height: 1;
}

.google-mark svg {
  display: block;
  width: 20px;
  height: 20px;
}

.form-divider {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
  color: var(--muted);
  font-size: 0.9rem;
  font-style: normal;
}

.form-divider span {
  height: 1px;
  background: var(--line);
}

.form-divider em {
  font-style: normal;
  white-space: nowrap;
}

.assistant-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  border: 0;
}

.assistant-picker legend {
  grid-column: 1 / -1;
  margin-bottom: 4px;
  color: #334139;
  font-size: 0.92rem;
  font-weight: 800;
}

.assistant-option {
  display: grid;
  grid-template-columns: 42px 1fr;
  align-items: center;
  gap: 8px;
  min-height: 58px;
  padding: 8px;
  cursor: pointer;
}

.support-picker .assistant-option {
  grid-template-columns: 1fr;
  padding: 14px;
}

.plan-picker .assistant-option {
  grid-template-columns: 1fr;
  padding: 14px;
}

.admin-shell {
  padding: clamp(48px, 6vw, 82px) clamp(18px, 5vw, 72px);
  background: #eef4f0;
}

.admin-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
}

.admin-heading-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}

.admin-heading h1 {
  max-width: 760px;
}

.admin-stats,
.admin-controls,
.admin-list {
  display: grid;
  gap: 14px;
  margin-top: 22px;
}

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

.admin-stats article,
.admin-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--soft-shadow);
}

.admin-stats article {
  display: grid;
  gap: 6px;
  padding: 18px;
}

.admin-stats span,
.admin-details dt {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
}

.admin-stats strong {
  color: var(--teal-dark);
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1;
}

.admin-controls {
  grid-template-columns: minmax(220px, 1fr) repeat(2, minmax(180px, 0.35fr));
}

.admin-card {
  display: grid;
  gap: 16px;
  padding: 20px;
}

.admin-card-top {
  display: flex;
  justify-content: space-between;
  gap: 18px;
}

.admin-card h2 {
  margin-bottom: 4px;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
}

.admin-card p,
.admin-details dd {
  color: var(--muted);
}

.admin-card-actions,
.admin-tags,
.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-card-actions {
  justify-content: flex-end;
}

.admin-tags span {
  padding: 7px 10px;
  color: #334139;
  background: #f8fbf7;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 800;
}

.admin-tags .status-good {
  color: #fff;
  background: var(--teal);
}

.admin-tags .status-warn {
  color: #17201c;
  background: #f4d99c;
}

.admin-tags .status-bad {
  color: #fff;
  background: #a84228;
}

.admin-actions .button {
  min-height: 36px;
  padding: 0 12px;
  font-size: 0.84rem;
}

.admin-runtime-outbox {
  display: grid;
  gap: 6px;
  padding: 12px;
  color: #26322c;
  background: #fff9ed;
  border: 1px solid #ecd7ad;
  border-radius: 8px;
}

.admin-runtime-outbox p {
  margin: 0;
}

.admin-runtime-outbox small {
  color: var(--muted);
  font-weight: 700;
}

.admin-support-job {
  background: #fff4d6;
  border-color: #d9b15e;
}

.provisioning-checklist {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.provisioning-checklist span {
  display: grid;
  gap: 3px;
  min-height: 54px;
  padding: 10px;
  color: var(--muted);
  background: #f8fbf7;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.88rem;
  line-height: 1.25;
}

.provisioning-checklist strong {
  color: #8b5d12;
  font-size: 0.72rem;
  text-transform: uppercase;
}

.provisioning-checklist .done {
  color: #21362f;
  background: #e6f4ef;
  border-color: rgba(18, 121, 111, 0.28);
}

.provisioning-checklist .done strong {
  color: var(--teal-dark);
}

.admin-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 18px;
  margin: 0;
}

.admin-details div {
  min-width: 0;
}

.admin-details dd {
  margin: 4px 0 0;
  overflow-wrap: anywhere;
}

.assistant-option.selected {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(18, 121, 111, 0.14);
}

.assistant-option input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.assistant-option img {
  width: 42px;
  height: 42px;
  object-fit: cover;
  object-position: 50% 18%;
  border-radius: 8px;
}

.assistant-option span {
  display: grid;
  gap: 4px;
  color: var(--muted);
  line-height: 1.35;
}

.assistant-option strong {
  color: var(--ink);
  font-size: 0.88rem;
  line-height: 1.1;
}

label {
  display: grid;
  gap: 8px;
  color: #334139;
  font-size: 0.92rem;
  font-weight: 800;
}

.guided-field {
  display: grid;
  gap: 12px;
}

.field-label {
  color: #334139;
  font-size: 0.92rem;
  font-weight: 760;
}

.field-helper {
  margin: -4px 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.4;
}

.prompt-bubbles,
.approval-defaults {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.prompt-bubbles button,
.approval-defaults span {
  display: inline-flex;
  min-height: 36px;
  align-items: center;
  justify-content: center;
  padding: 8px 11px;
  color: #273b34;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 121, 111, 0.14);
  border-radius: 8px;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 760;
  line-height: 1.15;
}

.prompt-bubbles button {
  cursor: pointer;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.prompt-bubbles button:hover,
.prompt-bubbles button:focus-visible,
.prompt-bubbles button.selected {
  color: #fff;
  background: var(--teal-dark);
  border-color: var(--teal-dark);
  outline: none;
  transform: translateY(-1px);
}

.approval-defaults span {
  color: var(--teal-dark);
  background: rgba(18, 121, 111, 0.075);
}

.optional-label {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.form-row > label {
  flex: 1 1 220px;
}

.form-row.compact {
  gap: 10px;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid #cbd5ce;
  border-radius: 8px;
  padding: 13px 14px;
  color: var(--ink);
  background: #fff;
  font: inherit;
}

section,
article,
form,
.assistant-profile,
.service-grid article,
.example-list span,
.audience-grid article,
.case-summary,
.testimonial-card,
.why-grid article,
.workflow-grid article,
.case-detail-grid article,
.outcome-row span,
.model-grid article,
.control-grid article,
.price-grid article,
.trust-section,
.trust-section > p,
.booking-form,
.mini-card {
  break-inside: avoid;
  page-break-inside: avoid;
}

textarea {
  resize: vertical;
}

.full {
  width: 100%;
}

body[data-avatar-state="start"] .live-companion {
  display: none;
}

.form-note {
  min-height: 24px;
  margin: 0;
  font-size: 0.95rem;
}

.brain-review-panel {
  display: grid;
  gap: 12px;
  margin: 14px 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 250, 242, 0.72);
}

.compact-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.9rem;
  line-height: 1.35;
}

.compact-check input {
  flex: 0 0 auto;
  width: auto;
  margin-top: 3px;
}

.pairing-panel {
  display: grid;
  gap: 12px;
  margin: 14px 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fffaf2;
}

.pairing-panel img {
  width: min(100%, 280px);
  aspect-ratio: 1;
  justify-self: center;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.desktop-connector-panel {
  display: grid;
  gap: 8px;
  margin: 14px 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf7;
}

.desktop-connector-panel > strong:first-child {
  color: var(--teal-dark);
  font-size: 0.8rem;
  text-transform: uppercase;
}

.customer-readiness {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0 16px;
}

.customer-readiness span {
  display: grid;
  gap: 3px;
  min-height: 52px;
  padding: 10px;
  color: var(--muted);
  background: #f8fbf7;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.86rem;
  line-height: 1.25;
}

.customer-readiness strong {
  color: #8b5d12;
  font-size: 0.72rem;
  text-transform: uppercase;
}

.customer-readiness .done {
  color: #21362f;
  background: #e6f4ef;
  border-color: rgba(18, 121, 111, 0.28);
}

.customer-readiness .done strong {
  color: var(--teal-dark);
}

.customer-dashboard-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 48px 0 64px;
}

.customer-dashboard-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: 24px;
  align-items: end;
  margin-bottom: 24px;
}

.customer-dashboard-header h1 {
  max-width: 760px;
  margin-bottom: 12px;
  font-size: clamp(2.35rem, 4vw, 4rem);
  line-height: 1.02;
  overflow-wrap: anywhere;
}

.customer-dashboard-header .lead {
  max-width: 720px;
}

.customer-dashboard-summary,
.customer-dashboard-panel {
  border: 1px solid rgba(24, 36, 32, 0.12);
  background: rgba(255, 255, 255, 0.96);
  border-radius: 8px;
  box-shadow: 0 12px 34px rgba(24, 36, 32, 0.07);
}

.customer-dashboard-summary {
  border-left: 4px solid var(--teal);
  padding: 20px;
}

.customer-dashboard-summary strong,
.customer-dashboard-summary span {
  display: block;
}

.customer-dashboard-summary span {
  margin-top: 8px;
  color: var(--muted);
  font-weight: 700;
}

.customer-command-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 28px;
}

.customer-command-strip article {
  display: grid;
  gap: 6px;
  min-height: 96px;
  align-content: center;
  padding: 18px;
  border: 1px solid rgba(18, 121, 111, 0.16);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 251, 250, 0.96));
  box-shadow: 0 14px 34px rgba(24, 36, 32, 0.06);
}

.customer-command-strip strong {
  color: var(--teal-dark);
  font-size: clamp(1.6rem, 2.6vw, 2.35rem);
  line-height: 1;
}

.customer-command-strip span {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.25;
}

.customer-proof-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: -12px 0 28px;
}

.customer-proof-strip article {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border: 1px solid rgba(214, 183, 91, 0.34);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 252, 244, 0.98), rgba(247, 251, 250, 0.92));
}

.customer-proof-strip strong {
  color: var(--charcoal);
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  line-height: 1;
}

.customer-proof-strip span {
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.25;
}

.dashboard-persona.is-loading img {
  opacity: 0;
}

.dashboard-persona.is-loading strong {
  color: var(--muted);
}

.support-ribbon {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
  margin: 0 0 28px;
}

.support-ribbon h2 {
  margin-bottom: 8px;
  font-size: clamp(1.18rem, 1.7vw, 1.45rem);
}

.support-ribbon p {
  margin-bottom: 0;
}

.support-ribbon-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, auto));
  gap: 10px;
  align-items: center;
  padding-top: 24px;
}

.support-ribbon-actions .muted-small {
  grid-column: 1 / -1;
  min-height: 18px;
}

.support-check-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 18px;
  margin-top: 8px;
}

.support-check-list .dashboard-step {
  padding: 7px 0;
}

.support-check-list .dashboard-step > small {
  display: none;
}

.customer-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
  gap: 20px;
}

.customer-dashboard-zone-heading {
  grid-column: 1 / -1;
  display: grid;
  gap: 6px;
  margin-top: 12px;
  padding: 20px 0 2px;
  border-top: 1px solid rgba(24, 36, 32, 0.12);
}

.customer-dashboard-zone-heading:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.customer-dashboard-zone-heading h2 {
  margin: 0;
  font-size: clamp(1.45rem, 2.2vw, 2.1rem);
  line-height: 1.08;
}

.customer-dashboard-zone-heading p:last-child {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-weight: 650;
}

.customer-dashboard-panel {
  padding: 22px;
  min-width: 0;
}

.customer-dashboard-panel h2 {
  margin: 6px 0 14px;
  font-size: 1.28rem;
  line-height: 1.16;
}

.primary-setup-panel {
  border-color: rgba(18, 121, 111, 0.24);
  background: linear-gradient(180deg, #ffffff 0%, #f7fbfa 100%);
}

.dashboard-persona {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 16px 0;
}

.dashboard-persona img {
  width: 74px;
  height: 74px;
  border-radius: 50%;
  object-fit: cover;
  background: #eef4f4;
  border: 1px solid rgba(24, 36, 32, 0.1);
}

.dashboard-persona strong,
.dashboard-persona span {
  display: block;
}

.dashboard-persona span {
  margin-top: 4px;
  color: var(--muted);
}

.dashboard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.dashboard-step-list {
  display: grid;
  gap: 10px;
}

.dashboard-step {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid rgba(24, 36, 32, 0.1);
}

.dashboard-step strong {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.dashboard-step strong span {
  display: inline-grid;
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid rgba(24, 36, 32, 0.14);
  border-radius: 50%;
  background: #fff;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
}

.dashboard-step:last-child {
  border-bottom: 0;
}

.dashboard-step > span {
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 700;
  text-align: right;
}

.dashboard-step > small {
  flex-basis: 100%;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
  padding-left: 38px;
}

.dashboard-step.done strong {
  color: var(--teal-dark);
}

.dashboard-step.done strong span {
  border-color: rgba(18, 121, 111, 0.28);
  background: rgba(18, 121, 111, 0.08);
  color: var(--teal-dark);
}

.dashboard-step.done > span {
  color: var(--teal-dark);
}

.dashboard-card-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.dashboard-mini-card {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid rgba(24, 36, 32, 0.1);
  border-radius: 8px;
  background: #fbfcfb;
}

.dashboard-mini-card strong {
  color: var(--ink);
  font-size: 0.94rem;
}

.dashboard-mini-card span,
.muted-small {
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.38;
}

.dashboard-mini-card small,
.dashboard-mini-card em {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  font-style: normal;
  line-height: 1.35;
}

.dashboard-mini-card small {
  color: var(--teal-dark);
  font-weight: 800;
}

.integrations-panel {
  grid-column: 1 / -1;
}

.connections-panel {
  grid-column: 1 / -1;
}

.workflow-library-panel {
  grid-column: 1 / -1;
}

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

.capability-card {
  background: #f8fcfb;
}

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

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

.connection-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
}

.connection-card-action {
  display: flex;
  align-items: center;
  gap: 10px;
}

.connection-card-action > span {
  color: var(--teal-dark);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.approval-inbox-list,
.compact-dashboard-list {
  align-content: start;
}

.approval-card {
  border-color: rgba(180, 119, 30, 0.2);
  background: #fffdf8;
}

.approval-card.done {
  border-color: rgba(18, 121, 111, 0.16);
  background: #f8fcfb;
}

.workflow-card {
  min-height: 118px;
  align-content: start;
}

.workflow-state {
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(18, 121, 111, 0.08);
}

.workflow-card.needs-connection .workflow-state {
  color: #8b5d12;
  background: rgba(197, 150, 55, 0.16);
}

.workflow-card.is-requested .workflow-state {
  color: var(--teal-dark);
  background: rgba(18, 121, 111, 0.12);
}

.workflow-card.is-ready .workflow-state {
  color: #274238;
  background: rgba(39, 66, 56, 0.08);
}

.workflow-card .button {
  width: fit-content;
  min-height: 34px;
  margin-top: 6px;
  padding: 0 12px;
  font-size: 0.78rem;
}

.button.disabled,
.button:disabled {
  cursor: default;
  opacity: 0.62;
  pointer-events: none;
}

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

.operational-dashboard-shell {
  padding-top: 42px;
}

.operational-header {
  align-items: center;
}

.operational-status span {
  text-transform: capitalize;
}

.operational-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 20px;
}

.operational-metrics article {
  padding: 18px;
  border: 1px solid rgba(24, 36, 32, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(24, 36, 32, 0.06);
}

.operational-metrics strong,
.operational-metrics span {
  display: block;
}

.operational-metrics strong {
  color: var(--teal-dark);
  font-size: 2rem;
  line-height: 1;
}

.operational-metrics span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.32;
}

.operational-grid {
  grid-template-columns: minmax(300px, 1fr) minmax(360px, 1.15fr);
}

.action-card {
  border-color: rgba(18, 121, 111, 0.2);
  background: #f7fbfa;
}

.compact-dashboard-list {
  grid-template-columns: 1fr;
}

.compact-list {
  margin-top: 12px;
}

.pairing-code {
  justify-self: center;
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  font-size: 1.8rem;
  letter-spacing: 0;
  text-align: center;
}

.checkbox-field {
  align-items: flex-start;
  display: flex;
  flex-direction: row;
  gap: 0.7rem;
  line-height: 1.45;
}

.checkbox-field input {
  margin-top: 0.2rem;
  min-height: auto;
  width: auto;
}

footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  padding: 26px clamp(18px, 5vw, 72px);
  color: var(--muted);
  background: var(--ink);
}

footer a,
footer span {
  color: #fff;
}

.landing-footer {
  min-height: 48px;
  align-items: center;
  gap: 12px 20px;
  padding-top: 12px;
  padding-bottom: 12px;
  color: #3f4f47;
  background: rgba(245, 247, 244, 0.96);
  border-top: 1px solid rgba(216, 222, 214, 0.9);
  font-size: 0.9rem;
  box-shadow: 0 -10px 34px rgba(22, 34, 31, 0.04);
}

.landing-footer a,
.landing-footer span {
  color: var(--teal-dark);
}

.landing-footer span {
  font-weight: 760;
}

body[data-live-avatar] main {
  padding-bottom: 140px;
}

.live-companion {
  --companion-shift-x: 0px;
  --companion-shift-y: 0px;
  position: fixed;
  right: 18px;
  bottom: 12px;
  z-index: 40;
  display: grid;
  grid-template-columns: minmax(116px, 168px) minmax(0, 205px);
  align-items: end;
  gap: 10px;
  max-width: min(94vw, 386px);
  transform: translate(var(--companion-shift-x), var(--companion-shift-y));
  transition: transform 900ms ease, opacity 220ms ease;
}

.live-companion-toggle {
  position: relative;
  display: grid;
  place-items: center;
  width: clamp(116px, 15vw, 168px);
  height: clamp(188px, 28vw, 286px);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  filter: drop-shadow(0 24px 26px rgba(8, 31, 38, 0.24));
  cursor: grab;
  touch-action: none;
}

.live-companion-toggle:active {
  cursor: grabbing;
}

.live-companion-orbit {
  position: absolute;
  right: 22%;
  bottom: 4%;
  width: 44%;
  height: 7%;
  border-radius: 999px;
  background: radial-gradient(ellipse, rgba(18, 122, 112, 0.24), transparent 68%);
  animation: companionShadow 3.8s ease-in-out infinite;
}

.live-companion-avatar {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 0;
  object-fit: contain;
  object-position: center bottom;
  border: 0;
  animation: companionBreathe 3.8s ease-in-out infinite;
}

.live-companion-sprite {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: none;
  overflow: hidden;
  pointer-events: none;
}

.live-companion-sprite img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 400%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: left bottom;
}

.cliff-action-pose-sprite img {
  width: 800%;
}

.live-companion-wave-hand {
  position: absolute;
  z-index: 2;
  right: 13%;
  top: 26%;
  width: 24%;
  aspect-ratio: 1;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 60% 48% 58% 48%;
  background:
    radial-gradient(circle at 63% 25%, rgba(255, 255, 255, 0.72) 0 8%, transparent 9%),
    linear-gradient(135deg, #f6c89d, #df9466);
  box-shadow: 0 8px 18px rgba(8, 31, 38, 0.18);
  opacity: 0;
  transform: rotate(-18deg) scale(0.78);
  transform-origin: 15% 82%;
  pointer-events: none;
}

.live-companion-gesture-hand {
  position: absolute;
  z-index: 3;
  width: 23%;
  aspect-ratio: 1.1;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 58% 48% 56% 46%;
  background:
    radial-gradient(circle at 62% 28%, rgba(255, 255, 255, 0.66) 0 8%, transparent 9%),
    linear-gradient(135deg, #f6c89d, #df9466);
  box-shadow: 0 8px 18px rgba(8, 31, 38, 0.18);
  opacity: 0;
  pointer-events: none;
}

.live-companion-gesture-hand.primary-hand {
  right: 10%;
  top: 42%;
  transform: rotate(-18deg) scale(0.78);
  transform-origin: 20% 82%;
}

.live-companion-gesture-hand.secondary-hand {
  left: 14%;
  top: 43%;
  transform: rotate(18deg) scale(0.78);
  transform-origin: 80% 82%;
}

.live-companion-action-icon,
.live-companion-action-card,
.live-companion-action-spark,
.live-companion-work-card {
  position: absolute;
  z-index: 3;
  opacity: 0;
  pointer-events: none;
}

.live-companion-action-icon {
  right: 4%;
  top: 12%;
  width: 48px;
  height: 38px;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(8, 31, 38, 0.18);
  transform: translateY(8px) scale(0.82);
}

.live-companion-action-card {
  left: 2%;
  bottom: 22%;
  width: 48px;
  height: 44px;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(8, 31, 38, 0.18);
  transform: translateY(8px) scale(0.82);
}

.live-companion-action-spark {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #d86f45;
  box-shadow: 0 0 0 4px rgba(216, 111, 69, 0.18);
}

.live-companion-action-spark.spark-one {
  left: 13%;
  top: 17%;
}

.live-companion-action-spark.spark-two {
  right: 8%;
  top: 27%;
  background: #28b487;
  box-shadow: 0 0 0 4px rgba(40, 180, 135, 0.16);
}

.live-companion-action-spark.spark-three {
  left: 42%;
  top: 4%;
  background: #f2b84b;
  box-shadow: 0 0 0 4px rgba(242, 184, 75, 0.18);
}

.live-companion-work-card {
  left: 2%;
  width: 54px;
  height: 32px;
  border: 2px solid rgba(18, 122, 112, 0.2);
  border-radius: 10px;
  background:
    linear-gradient(90deg, rgba(18, 122, 112, 0.18) 0 32%, transparent 33%),
    linear-gradient(#fff, #f4fbf9);
  box-shadow: 0 12px 24px rgba(8, 31, 38, 0.16);
  transform: translate(-8px, 12px) scale(0.84);
}

.live-companion-work-card::before,
.live-companion-work-card::after {
  content: "";
  position: absolute;
  left: 23px;
  right: 8px;
  height: 3px;
  border-radius: 999px;
  background: rgba(22, 45, 50, 0.26);
}

.live-companion-work-card::before {
  top: 9px;
}

.live-companion-work-card::after {
  top: 17px;
}

.work-card-one {
  bottom: 38%;
}

.work-card-two {
  bottom: 27%;
}

.work-card-three {
  bottom: 16%;
}

.live-companion-state {
  position: absolute;
  z-index: 2;
  right: 16%;
  top: 13%;
  width: 16px;
  height: 16px;
  border: 3px solid #fff;
  border-radius: 999px;
  background: #28b487;
  box-shadow: 0 0 0 6px rgba(40, 180, 135, 0.16);
}

.live-companion-cue {
  position: absolute;
  z-index: 3;
  left: 8%;
  top: 11%;
  max-width: 118px;
  min-height: 28px;
  padding: 6px 9px;
  border: 1px solid rgba(18, 122, 112, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--teal-dark);
  box-shadow: 0 12px 30px rgba(8, 31, 38, 0.16);
  font-size: 0.74rem;
  font-weight: 900;
  line-height: 1;
  opacity: 0;
  transform: translateY(5px) scale(0.96);
  transition: opacity 180ms ease, transform 180ms ease;
}

.live-companion[class*="is-action-"] .live-companion-cue {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.live-companion-panel {
  align-self: center;
  padding: 13px 14px 14px;
  border: 1px solid rgba(22, 45, 50, 0.11);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.93);
  box-shadow: 0 18px 48px rgba(8, 31, 38, 0.18);
  backdrop-filter: blur(14px);
}

.live-companion-kicker {
  display: block;
  margin-bottom: 3px;
  color: var(--teal);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.live-companion-name {
  display: block;
  color: var(--ink);
  font-size: 1rem;
}

.live-companion-message {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.live-companion-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.live-companion-actions button {
  min-height: 32px;
  padding: 6px 9px;
  border: 1px solid rgba(18, 122, 112, 0.18);
  border-radius: 999px;
  background: #f3fbf9;
  color: var(--teal-dark);
  font: inherit;
  font-size: 0.76rem;
  font-weight: 800;
  cursor: pointer;
}

.live-companion-actions button:hover,
.live-companion-actions button:focus-visible {
  background: #deefec;
  outline: none;
}

.live-companion.is-collapsed {
  grid-template-columns: 76px;
}

.live-companion.is-collapsed .live-companion-panel {
  display: none;
}

.live-companion.is-human {
  width: auto;
  grid-template-columns: clamp(110px, 12vw, 140px) minmax(0, 190px);
  right: 16px;
  bottom: -20px;
  justify-items: end;
}

.live-companion.is-human .live-companion-toggle {
  width: clamp(110px, 12vw, 140px);
  height: clamp(184px, 21vw, 238px);
}

.live-companion.is-human .live-companion-panel {
  display: block;
  align-self: center;
  margin-bottom: 50px;
}

.live-companion.is-action-wave .live-companion-avatar {
  animation: companionWaveBody 900ms ease-in-out 2;
}

.live-companion.is-action-wave .live-companion-wave-hand {
  animation: companionWaveHand 600ms ease-in-out 4;
}

.live-companion.is-action-work .live-companion-avatar {
  animation: companionAiWorkPose 1800ms ease-in-out 2;
}

.live-companion.is-human.is-action-work .live-companion-avatar,
.live-companion.is-human.is-action-work .live-companion-gesture-hand,
.live-companion.is-human.is-action-work .live-companion-work-card {
  opacity: 0;
  animation: none;
}

.live-companion.is-human.is-action-work .cliff-ai-work-sprite {
  display: block;
}

.live-companion.is-human.is-action-work .cliff-ai-work-sprite img {
  animation: cliffAiWorkSprite 3600ms linear 1 both;
}

.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-avatar,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-wave-hand,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-gesture-hand,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-action-icon,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-action-card,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-action-spark,
.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .live-companion-work-card {
  opacity: 0;
  animation: none;
}

.live-companion.is-human:is(.is-action-wave, .is-action-think, .is-action-celebrate, .is-action-nudge, .is-action-lock, .is-action-approval, .is-action-sort, .is-action-calendar) .cliff-action-pose-sprite {
  display: block;
  animation: companionPosePop 420ms ease-out 1 both;
}

.live-companion.is-human.is-action-wave .cliff-action-pose-sprite img {
  transform: translateX(0);
}

.live-companion.is-human.is-action-think .cliff-action-pose-sprite img {
  transform: translateX(-12.5%);
}

.live-companion.is-human.is-action-celebrate .cliff-action-pose-sprite img {
  transform: translateX(-25%);
}

.live-companion.is-human.is-action-nudge .cliff-action-pose-sprite img {
  transform: translateX(-37.5%);
}

.live-companion.is-human.is-action-lock .cliff-action-pose-sprite img {
  transform: translateX(-50%);
}

.live-companion.is-human.is-action-approval .cliff-action-pose-sprite img {
  transform: translateX(-62.5%);
}

.live-companion.is-human.is-action-sort .cliff-action-pose-sprite img {
  transform: translateX(-75%);
}

.live-companion.is-human.is-action-calendar .cliff-action-pose-sprite img {
  transform: translateX(-87.5%);
}

.live-companion.is-action-work .primary-hand {
  animation: companionWorkHandRight 1200ms ease-in-out 3;
}

.live-companion.is-action-work .secondary-hand {
  animation: companionWorkHandLeft 1200ms ease-in-out 3;
}

.live-companion.is-action-work .live-companion-work-card {
  animation: companionWorkCardSort 1200ms ease-in-out 3;
}

.live-companion.is-action-work .work-card-two {
  animation-delay: 110ms;
}

.live-companion.is-action-work .work-card-three {
  animation-delay: 220ms;
}

.live-companion.is-action-work .live-companion-state {
  animation: companionStatePulse 900ms ease-in-out 4;
}

.live-companion.is-human.is-action-work .primary-hand,
.live-companion.is-human.is-action-work .secondary-hand,
.live-companion.is-human.is-action-work .live-companion-work-card {
  opacity: 0;
  animation: none;
}

.live-companion.is-action-approval .live-companion-avatar {
  animation: companionPresentPose 1500ms ease-in-out 2;
}

.live-companion.is-action-approval .primary-hand {
  animation: companionPresentRight 1500ms ease-in-out 2;
}

.live-companion.is-action-approval .secondary-hand {
  animation: companionPresentLeft 1500ms ease-in-out 2;
}

.live-companion.is-action-approval .live-companion-action-card {
  animation: companionApprovalCard 1500ms ease-in-out 2;
}

.live-companion.is-action-approval .live-companion-action-card::before {
  content: "OK?";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--teal-dark);
  font-size: 0.82rem;
  font-weight: 900;
}

.live-companion.is-action-sort .live-companion-avatar {
  animation: companionAiWorkPose 1650ms ease-in-out 2;
}

.live-companion.is-action-sort .primary-hand {
  animation: companionWorkHandRight 1100ms ease-in-out 3;
}

.live-companion.is-action-sort .secondary-hand {
  animation: companionWorkHandLeft 1100ms ease-in-out 3;
}

.live-companion.is-action-sort .live-companion-work-card {
  animation: companionTaskCardSort 1100ms ease-in-out 3;
}

.live-companion.is-action-sort .work-card-two {
  animation-delay: 120ms;
}

.live-companion.is-action-sort .work-card-three {
  animation-delay: 240ms;
}

.live-companion.is-action-calendar .live-companion-avatar {
  animation: companionCalendarGlance 1500ms ease-in-out 2;
}

.live-companion.is-action-calendar .primary-hand {
  animation: companionPointCalendar 1500ms ease-in-out 2;
}

.live-companion.is-action-calendar .live-companion-action-card {
  animation: companionCalendarCard 1500ms ease-in-out 2;
}

.live-companion.is-action-calendar .live-companion-action-card::before {
  content: "";
  position: absolute;
  left: 9px;
  right: 9px;
  top: 10px;
  height: 6px;
  border-radius: 5px;
  background: #2f6f8f;
  box-shadow: 0 10px 0 rgba(47, 111, 143, 0.22), 12px 10px 0 rgba(47, 111, 143, 0.16);
}

.live-companion.is-action-calendar .live-companion-action-card::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 8px;
  height: 5px;
  border-radius: 999px;
  background: #28b487;
}

.live-companion.is-action-think .live-companion-avatar {
  animation: companionThinkPose 1200ms ease-in-out 1;
}

.live-companion.is-action-think .primary-hand {
  animation: companionChinHand 1200ms ease-in-out 1;
}

.live-companion.is-action-think .live-companion-action-icon {
  animation: companionThoughtBubble 1200ms ease-in-out 1;
}

.live-companion.is-action-think .live-companion-action-icon::before {
  content: "?";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--teal-dark);
  font-size: 1.15rem;
  font-weight: 900;
}

.live-companion.is-action-think .live-companion-action-icon::after {
  content: "";
  position: absolute;
  left: 8px;
  bottom: -9px;
  width: 12px;
  height: 12px;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 999px;
  background: #fff;
}

.live-companion.is-action-celebrate .live-companion-avatar {
  animation: companionCelebrate 900ms ease-in-out 2;
}

.live-companion.is-action-celebrate .primary-hand {
  animation: companionCheerRight 900ms ease-in-out 2;
}

.live-companion.is-action-celebrate .secondary-hand {
  animation: companionCheerLeft 900ms ease-in-out 2;
}

.live-companion.is-action-celebrate .live-companion-action-spark {
  animation: companionSparkPop 760ms ease-out 3;
}

.live-companion.is-action-celebrate .spark-two {
  animation-delay: 90ms;
}

.live-companion.is-action-celebrate .spark-three {
  animation-delay: 150ms;
}

.live-companion.is-action-nudge .live-companion-avatar {
  animation: companionLeanNudge 760ms ease-in-out 2;
}

.live-companion.is-action-nudge .primary-hand {
  animation: companionPointNudge 760ms ease-in-out 3;
}

.live-companion.is-action-nudge .live-companion-action-card {
  animation: companionReminderBell 760ms ease-in-out 3;
}

.live-companion.is-action-nudge .live-companion-action-card::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 9px;
  width: 16px;
  height: 16px;
  border: 3px solid var(--teal-dark);
  border-bottom: 0;
  border-radius: 14px 14px 4px 4px;
}

.live-companion.is-action-nudge .live-companion-action-card::after {
  content: "";
  position: absolute;
  left: 16px;
  bottom: 8px;
  width: 12px;
  height: 4px;
  border-radius: 999px;
  background: var(--teal-dark);
  box-shadow: 5px 5px 0 -2px var(--teal-dark);
}

.live-companion.is-action-lock .live-companion-avatar {
  animation: companionGuardPose 1100ms ease-in-out 1;
}

.live-companion.is-action-lock .primary-hand {
  animation: companionStopHand 1100ms ease-in-out 1;
}

.live-companion.is-action-lock .live-companion-action-card {
  animation: companionPrivacyLock 1100ms ease-in-out 1;
}

.live-companion.is-action-lock .live-companion-action-card::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 7px;
  width: 16px;
  height: 14px;
  border: 3px solid #2f6f8f;
  border-bottom: 0;
  border-radius: 14px 14px 0 0;
}

.live-companion.is-action-lock .live-companion-action-card::after {
  content: "";
  position: absolute;
  left: 11px;
  bottom: 8px;
  width: 24px;
  height: 20px;
  border-radius: 7px;
  background: #2f6f8f;
  box-shadow: inset 0 -5px 0 rgba(255, 255, 255, 0.16);
}

.live-companion.is-action-lock .live-companion-state {
  background: #2f6f8f;
  box-shadow: 0 0 0 6px rgba(47, 111, 143, 0.18);
}

.live-companion.is-collapsed .live-companion-toggle {
  width: 76px;
  height: 76px;
  border-radius: 999px;
  background: linear-gradient(145deg, #ffffff, #eaf4f3);
  box-shadow: 0 18px 42px rgba(8, 31, 38, 0.24);
  filter: none;
}

.live-companion.is-collapsed .live-companion-avatar {
  width: 66px;
  height: 66px;
  border: 3px solid #fff;
  border-radius: 999px;
  object-fit: cover;
  object-position: center top;
}

.live-companion.is-human.is-collapsed.is-action-work {
  grid-template-columns: min(50vw, 194px);
  right: 2px;
  bottom: -20px;
}

.live-companion.is-human.is-collapsed.is-action-work .live-companion-toggle {
  width: min(50vw, 194px);
  height: min(72vw, 280px);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 20px 24px rgba(8, 31, 38, 0.22));
}

.live-companion.is-human.is-collapsed.is-action-work .cliff-ai-work-sprite {
  display: block;
}

.live-companion.is-collapsed .live-companion-wave-hand {
  right: -6px;
  top: 7px;
  width: 26px;
  border-width: 2px;
}

.live-companion.is-collapsed .live-companion-gesture-hand,
.live-companion:not(.is-human) .live-companion-gesture-hand {
  width: 24px;
  border-width: 2px;
}

.live-companion.is-collapsed .primary-hand,
.live-companion:not(.is-human) .primary-hand {
  right: -4px;
  top: 34px;
}

.live-companion.is-collapsed .secondary-hand,
.live-companion:not(.is-human) .secondary-hand {
  left: -4px;
  top: 35px;
}

.live-companion.is-collapsed .live-companion-action-icon,
.live-companion:not(.is-human) .live-companion-action-icon {
  right: -8px;
  top: -7px;
  width: 34px;
  height: 28px;
  border-width: 2px;
}

.live-companion.is-collapsed .live-companion-action-card,
.live-companion:not(.is-human) .live-companion-action-card {
  left: -8px;
  bottom: 2px;
  width: 34px;
  height: 32px;
  border-width: 2px;
  border-radius: 10px;
}

.live-companion.is-collapsed .live-companion-action-spark,
.live-companion:not(.is-human) .live-companion-action-spark {
  width: 9px;
  height: 9px;
}

.live-companion.is-collapsed .live-companion-work-card,
.live-companion:not(.is-human) .live-companion-work-card {
  left: -11px;
  width: 34px;
  height: 22px;
  border-radius: 7px;
}

.live-companion.is-collapsed .work-card-one,
.live-companion:not(.is-human) .work-card-one {
  bottom: 47px;
}

.live-companion.is-collapsed .work-card-two,
.live-companion:not(.is-human) .work-card-two {
  bottom: 34px;
}

.live-companion.is-collapsed .work-card-three,
.live-companion:not(.is-human) .work-card-three {
  bottom: 21px;
}

.live-companion.is-collapsed .live-companion-orbit {
  inset: -7px;
  width: auto;
  height: auto;
  border: 1px solid rgba(18, 122, 112, 0.32);
  background: transparent;
  animation: companionOrbit 4.8s linear infinite;
}

.live-companion:not(.is-human) {
  grid-template-columns: 84px minmax(0, 190px);
}

.live-companion:not(.is-human) .live-companion-toggle {
  width: 84px;
  height: 84px;
  border-radius: 999px;
  background: linear-gradient(145deg, #ffffff, #eaf4f3);
  box-shadow: 0 18px 42px rgba(8, 31, 38, 0.24);
  filter: none;
}

.live-companion:not(.is-human) .live-companion-avatar {
  width: 74px;
  height: 74px;
  border: 3px solid #fff;
  border-radius: 999px;
  object-fit: cover;
  object-position: center top;
}

.live-companion:not(.is-human) .live-companion-wave-hand {
  right: -5px;
  top: 8px;
  width: 26px;
  border-width: 2px;
}

.live-companion:not(.is-human) .live-companion-orbit {
  inset: -7px;
  width: auto;
  height: auto;
  border: 1px solid rgba(18, 122, 112, 0.32);
  background: transparent;
  animation: companionOrbit 4.8s linear infinite;
}

.live-companion:not(.is-human) .live-companion-state {
  right: 6px;
  top: auto;
  bottom: 8px;
}

.live-presence-card {
  position: relative;
  overflow: hidden;
  padding: 22px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 18% 12%, rgba(35, 149, 137, 0.16), transparent 28%),
    linear-gradient(135deg, #f7fbfa, #ffffff);
  border: 1px solid rgba(22, 45, 50, 0.1);
  box-shadow: var(--shadow);
}

.live-presence-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.45rem, 4vw, 2rem);
}

.live-presence-card p {
  color: var(--muted);
}

.presence-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

.presence-row span {
  min-height: 76px;
  padding: 12px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(22, 45, 50, 0.08);
  color: var(--ink);
  font-size: 0.86rem;
  line-height: 1.35;
}

@keyframes avatarFloat {
  0%,
  100% {
    transform: translateY(0) rotate(-1deg);
  }

  50% {
    transform: translateY(-8px) rotate(1deg);
  }
}

@keyframes screenCliffIdleMobileFrames {
  to {
    background-position: 100% 0;
  }
}

@keyframes screenCliffAttentionMobileFrames {
  to {
    background-position: 100% 0;
  }
}

@keyframes cliffPresenceGlow {
  0%,
  100% {
    opacity: 0.68;
    transform: translateY(7px) scale(0.96);
  }

  48% {
    opacity: 0.92;
    transform: translateY(2px) scale(1.04);
  }
}

@keyframes cliffPresenceReact {
  0% {
    opacity: 0.5;
    transform: translateY(8px) scale(0.9);
  }

  58% {
    opacity: 1;
    transform: translateY(0) scale(1.08);
  }

  100% {
    opacity: 0.82;
    transform: translateY(6px) scale(1);
  }
}

@keyframes cliffPanelReact {
  0% {
    transform: translateY(3px);
  }

  52% {
    transform: translateY(-7px);
  }

  100% {
    transform: translateY(-4px);
  }
}

@keyframes dockPulse {
  0%,
  100% {
    opacity: 0.38;
    transform: scaleX(0.88);
  }

  50% {
    opacity: 1;
    transform: scaleX(1);
  }
}

@keyframes guideFloat {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-5px) scale(1.01);
  }
}

@keyframes cliffCtaPulse {
  0%,
  100% {
    transform: translateY(0);
  }

  45% {
    transform: translateY(-2px);
  }
}

@keyframes companionBreathe {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-3px) scale(1.025);
  }
}

@keyframes companionOrbit {
  from {
    transform: rotate(0deg) scale(1);
  }

  50% {
    transform: rotate(180deg) scale(1.04);
  }

  to {
    transform: rotate(360deg) scale(1);
  }
}

@keyframes companionShadow {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.74;
  }

  50% {
    transform: scale(0.86);
    opacity: 0.46;
  }
}

@keyframes companionWaveBody {
  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  35% {
    transform: translateY(-4px) rotate(-4deg);
  }

  70% {
    transform: translateY(-2px) rotate(4deg);
  }
}

@keyframes companionWaveHand {
  0%,
  100% {
    opacity: 0;
    transform: rotate(-22deg) scale(0.78);
  }

  12%,
  86% {
    opacity: 1;
  }

  26% {
    transform: rotate(28deg) scale(1);
  }

  50% {
    transform: rotate(-18deg) scale(1.03);
  }

  74% {
    transform: rotate(30deg) scale(1);
  }
}

@keyframes cliffAiWorkSprite {
  0%,
  22% {
    transform: translateX(0);
  }

  30%,
  48% {
    transform: translateX(-25%);
  }

  56%,
  74% {
    transform: translateX(-50%);
  }

  84%,
  100% {
    transform: translateX(-75%);
  }
}

@keyframes companionPosePop {
  0% {
    opacity: 0;
    transform: translateY(6px) scale(0.96);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes companionAiWorkPose {
  0%,
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
    filter: saturate(1);
  }

  24% {
    transform: translate(-4px, -5px) rotate(-2deg) scale(1.025);
    filter: saturate(1.08);
  }

  54% {
    transform: translate(5px, -4px) rotate(2deg) scale(1.03);
    filter: saturate(1.1);
  }

  78% {
    transform: translateY(-6px) rotate(0deg) scale(1.02);
  }
}

@keyframes companionWorkHandRight {
  0%,
  100% {
    opacity: 0;
    transform: translate(12px, 12px) rotate(-18deg) scale(0.72);
  }

  10%,
  88% {
    opacity: 1;
  }

  28% {
    transform: translate(-18px, -10px) rotate(-48deg) scale(0.96);
  }

  58% {
    transform: translate(-4px, 10px) rotate(-18deg) scale(0.92);
  }

  78% {
    transform: translate(-24px, 0) rotate(-54deg) scale(0.98);
  }
}

@keyframes companionWorkHandLeft {
  0%,
  100% {
    opacity: 0;
    transform: translate(-12px, 12px) rotate(18deg) scale(0.72);
  }

  14%,
  86% {
    opacity: 1;
  }

  34% {
    transform: translate(16px, 6px) rotate(42deg) scale(0.94);
  }

  64% {
    transform: translate(24px, -12px) rotate(58deg) scale(0.98);
  }
}

@keyframes companionWorkCardSort {
  0%,
  100% {
    opacity: 0;
    transform: translate(-8px, 12px) scale(0.84);
  }

  12%,
  88% {
    opacity: 1;
  }

  32% {
    transform: translate(16px, -5px) scale(1);
  }

  58% {
    transform: translate(50px, -1px) scale(1.02);
  }

  78% {
    transform: translate(28px, 5px) scale(0.96);
  }
}

@keyframes companionStatePulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 6px rgba(40, 180, 135, 0.16);
  }

  50% {
    transform: scale(1.16);
    box-shadow: 0 0 0 10px rgba(40, 180, 135, 0.12);
  }
}

@keyframes companionPresentPose {
  0%,
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
  }

  38%,
  76% {
    transform: translateY(-4px) rotate(0deg) scale(1.025);
  }
}

@keyframes companionPresentRight {
  0%,
  100% {
    opacity: 0;
    transform: translate(14px, 12px) rotate(-18deg) scale(0.72);
  }

  16%,
  84% {
    opacity: 1;
  }

  40%,
  72% {
    transform: translate(-20px, -8px) rotate(-38deg) scale(0.98);
  }
}

@keyframes companionPresentLeft {
  0%,
  100% {
    opacity: 0;
    transform: translate(-14px, 12px) rotate(18deg) scale(0.72);
  }

  18%,
  82% {
    opacity: 1;
  }

  40%,
  72% {
    transform: translate(18px, -7px) rotate(38deg) scale(0.96);
  }
}

@keyframes companionApprovalCard {
  0%,
  100% {
    opacity: 0;
    transform: translateY(10px) scale(0.82);
  }

  18%,
  86% {
    opacity: 1;
  }

  42%,
  72% {
    transform: translate(36px, -24px) scale(1.08);
    box-shadow: 0 0 0 8px rgba(40, 180, 135, 0.12), 0 12px 24px rgba(8, 31, 38, 0.18);
  }
}

@keyframes companionTaskCardSort {
  0%,
  100% {
    opacity: 0;
    transform: translate(-14px, 12px) scale(0.82);
  }

  12%,
  90% {
    opacity: 1;
  }

  30% {
    transform: translate(24px, -12px) scale(1.02);
  }

  58% {
    transform: translate(66px, 5px) scale(1.04);
  }

  78% {
    transform: translate(38px, -2px) scale(0.98);
  }
}

@keyframes companionCalendarGlance {
  0%,
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
  }

  35%,
  76% {
    transform: translate(4px, -4px) rotate(3deg) scale(1.025);
  }
}

@keyframes companionPointCalendar {
  0%,
  100% {
    opacity: 0;
    transform: translate(12px, 12px) rotate(-18deg) scale(0.72);
  }

  16%,
  86% {
    opacity: 1;
  }

  40%,
  74% {
    transform: translate(-22px, -28px) rotate(-58deg) scale(1);
  }
}

@keyframes companionCalendarCard {
  0%,
  100% {
    opacity: 0;
    transform: translateY(10px) scale(0.82);
  }

  18%,
  86% {
    opacity: 1;
  }

  45%,
  76% {
    transform: translate(32px, -42px) scale(1.06);
  }
}

@keyframes companionThoughtBubble {
  0%,
  100% {
    opacity: 0;
    transform: translateY(8px) scale(0.82);
  }

  18%,
  82% {
    opacity: 1;
  }

  45% {
    transform: translateY(-8px) scale(1.04);
  }
}

@keyframes companionThinkPose {
  0%,
  100% {
    transform: translateY(0) rotate(0deg) scale(1);
  }

  45%,
  72% {
    transform: translateY(-5px) rotate(-3deg) scale(1.035);
    filter: saturate(1.08);
  }
}

@keyframes companionChinHand {
  0%,
  100% {
    opacity: 0;
    transform: translate(10px, 12px) rotate(-28deg) scale(0.72);
  }

  18%,
  84% {
    opacity: 1;
  }

  45%,
  72% {
    transform: translate(-4px, -10px) rotate(-42deg) scale(0.9);
  }
}

@keyframes companionFocus {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-6px) scale(1.04);
    filter: saturate(1.08);
  }
}

@keyframes companionCelebrate {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  45% {
    transform: translateY(-12px) scale(1.05) rotate(-2deg);
  }

  75% {
    transform: translateY(-4px) scale(1.02) rotate(2deg);
  }
}

@keyframes companionCheerRight {
  0%,
  100% {
    opacity: 0;
    transform: translateY(12px) rotate(-20deg) scale(0.72);
  }

  16%,
  84% {
    opacity: 1;
  }

  42% {
    transform: translate(-2px, -42px) rotate(28deg) scale(1);
  }

  72% {
    transform: translate(2px, -30px) rotate(12deg) scale(0.94);
  }
}

@keyframes companionCheerLeft {
  0%,
  100% {
    opacity: 0;
    transform: translateY(12px) rotate(20deg) scale(0.72);
  }

  16%,
  84% {
    opacity: 1;
  }

  42% {
    transform: translate(2px, -42px) rotate(-28deg) scale(1);
  }

  72% {
    transform: translate(-2px, -30px) rotate(-12deg) scale(0.94);
  }
}

@keyframes companionSparkPop {
  0%,
  100% {
    opacity: 0;
    transform: translateY(8px) scale(0.35);
  }

  20% {
    opacity: 1;
    transform: translateY(-4px) scale(1.1);
  }

  65% {
    opacity: 1;
    transform: translateY(-14px) scale(0.92);
  }
}

@keyframes companionLeanNudge {
  0%,
  100% {
    transform: translateX(0) translateY(0) rotate(0deg);
  }

  35% {
    transform: translateX(-5px) translateY(-2px) rotate(-2deg);
  }

  70% {
    transform: translateX(5px) translateY(-2px) rotate(2deg);
  }
}

@keyframes companionPointNudge {
  0%,
  100% {
    opacity: 0;
    transform: translate(12px, 12px) rotate(-18deg) scale(0.74);
  }

  15%,
  86% {
    opacity: 1;
  }

  34% {
    transform: translate(-16px, -2px) rotate(-54deg) scale(0.94);
  }

  58% {
    transform: translate(-22px, 0) rotate(-58deg) scale(0.98);
  }
}

@keyframes companionNudge {
  0%,
  100% {
    transform: translateX(0) translateY(0);
  }

  35% {
    transform: translateX(-4px) translateY(-2px);
  }

  70% {
    transform: translateX(4px) translateY(-2px);
  }
}

@keyframes companionReminderBell {
  0%,
  100% {
    opacity: 0;
    transform: translateY(8px) rotate(0deg) scale(0.82);
  }

  15%,
  85% {
    opacity: 1;
  }

  32% {
    transform: translateY(-4px) rotate(-10deg) scale(1);
  }

  56% {
    transform: translateY(-4px) rotate(10deg) scale(1);
  }
}

@keyframes companionGuardPose {
  0%,
  100% {
    transform: translateY(0) scale(1);
    filter: none;
  }

  45%,
  76% {
    transform: translateY(-3px) scale(0.99);
    filter: saturate(0.9);
  }
}

@keyframes companionStopHand {
  0%,
  100% {
    opacity: 0;
    transform: translate(12px, 8px) rotate(-18deg) scale(0.72);
  }

  18%,
  86% {
    opacity: 1;
  }

  45%,
  76% {
    transform: translate(-8px, -18px) rotate(6deg) scale(1.02);
  }
}

@keyframes companionLock {
  0%,
  100% {
    transform: translateY(0) scale(1);
    filter: none;
  }

  45% {
    transform: translateY(-3px) scale(0.985);
    filter: saturate(0.9);
  }
}

@keyframes companionPrivacyLock {
  0%,
  100% {
    opacity: 0;
    transform: translateY(8px) scale(0.82);
  }

  18%,
  86% {
    opacity: 1;
  }

  45% {
    transform: translateY(-5px) scale(1.04);
    box-shadow: 0 0 0 8px rgba(47, 111, 143, 0.12), 0 12px 24px rgba(8, 31, 38, 0.18);
  }
}

@keyframes phonePulse {
  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-5px) rotate(-1deg);
  }
}

@keyframes messageLift {
  0%,
  100% {
    opacity: 0.88;
    transform: translateY(0);
  }

  45% {
    opacity: 1;
    transform: translateY(-5px);
  }
}

@keyframes actionGlow {
  0%,
  100% {
    box-shadow: 0 0 0 rgba(216, 111, 69, 0);
    transform: scale(1);
  }

  50% {
    box-shadow: 0 0 28px rgba(216, 111, 69, 0.3);
    transform: scale(1.03);
  }
}

@keyframes taskSlide {
  0%,
  100% {
    opacity: 0.8;
    transform: translateX(0);
  }

  50% {
    opacity: 1;
    transform: translateX(-8px);
  }
}

@media (max-width: 920px) {
  .hero,
  .split-hero,
  .case-hero,
  .booking-section {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .business-hero {
    gap: 22px;
    padding-bottom: 28px;
  }

  .business-hero-offer {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 520px;
  }

  .business-snapshot-section {
    padding-top: 38px;
  }

  .personal-hero-storyboard {
    max-width: 680px;
    justify-self: start;
  }

  .split-hero {
    min-height: auto;
  }

  .assistant-panel {
    align-self: auto;
    max-height: none;
  }

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

  .hero-agent-mosaic article {
    min-height: 0;
  }

  .booking-copy {
    position: static;
  }

  .service-grid,
  .example-list,
  .audience-grid,
  .people-gallery,
  .teen-grid,
  .teen-gallery,
  .faq-list,
  .case-study-grid,
  .why-grid,
  .workflow-grid,
  .case-detail-grid,
  .model-grid,
  .control-grid,
  .price-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .trust-section {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .avatar-strip {
    grid-template-columns: repeat(4, minmax(72px, 1fr));
  }

  .split-hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 18px;
    min-height: 0;
    padding-top: 24px;
    padding-bottom: 28px;
  }

  .split-copy,
  .hero-media-stack {
    width: 100%;
    max-width: 760px;
  }

  .split-copy {
    padding-top: 0;
  }

  .split-copy h1 {
    max-width: 720px;
    font-size: clamp(2.32rem, 4.7vw, 3.15rem);
    line-height: 1.02;
  }

  .split-copy .lead {
    max-width: 720px;
  }

  .hero-media-stack {
    gap: 10px;
    justify-self: start;
  }

  .promo-video {
    border-width: 1px;
    border-radius: 8px;
  }

  .premium-companion-demo {
    min-height: 390px;
  }

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

@media (min-width: 1181px) and (max-height: 820px) {
  .site-header {
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .case-hero {
    min-height: 0;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.34fr);
    gap: clamp(18px, 3.2vw, 36px);
    padding-top: clamp(28px, 4vw, 46px);
    padding-bottom: clamp(28px, 4vw, 46px);
  }

  .case-hero h1 {
    max-width: 780px;
    margin-bottom: 12px;
    font-size: clamp(2.65rem, 4.55vw, 4.65rem);
    line-height: 0.98;
  }

  .case-hero .lead {
    max-width: 680px;
    font-size: 0.96rem;
    line-height: 1.42;
  }

  .case-metric-panel {
    gap: 8px;
    padding: 18px;
  }

  .case-metric-panel strong {
    font-size: clamp(1.75rem, 2.7vw, 2.55rem);
  }

  .case-metric-panel span,
  .case-metric-panel p {
    font-size: 0.88rem;
    line-height: 1.34;
  }

  .split-hero {
    min-height: calc(100svh - 59px);
    grid-template-columns: minmax(0, 0.74fr) minmax(320px, 0.9fr);
    gap: clamp(12px, 2vw, 22px) clamp(16px, 2.4vw, 28px);
    padding-top: clamp(16px, 2.5vw, 30px);
    padding-bottom: clamp(16px, 2.5vw, 28px);
  }

  .split-copy {
    padding-top: 0;
  }

  .split-copy h1 {
    margin-bottom: 10px;
    font-size: clamp(2.35rem, 3.3vw, 3.25rem);
    line-height: 1.02;
  }

  .split-copy .lead {
    font-size: 0.98rem;
    line-height: 1.42;
  }

  .hero-media-stack {
    gap: 10px;
  }

  .promo-reel {
    min-height: 0;
    padding: 10px;
  }

  .promo-storyboard img {
    border-width: 1px;
    border-radius: 8px;
  }

  .promo-storyboard figcaption span {
    min-height: 32px;
    font-size: 0.72rem;
  }

  .promo-stage {
    min-height: 178px;
    gap: 12px;
  }

  .promo-avatar-group img {
    width: 82px;
    height: 82px;
  }

  .promo-avatar-group img + img {
    width: 70px;
    height: 70px;
    margin-top: -24px;
    margin-left: 36px;
  }

  .promo-phone {
    min-height: 168px;
    padding: 24px 11px 12px;
    border-width: 8px;
  }

  .phone-message {
    padding: 7px 9px;
    font-size: 0.74rem;
  }

  .phone-action {
    min-height: 30px;
    padding: 6px 10px;
    font-size: 0.74rem;
  }

  .promo-task-stack span {
    padding: 7px 9px;
    font-size: 0.72rem;
  }

  .split-option {
    padding: 13px 14px;
  }

  .split-agent-row {
    min-height: 36px;
  }

  .split-agent-row img {
    width: 36px;
    height: 36px;
  }

  .split-option h2 {
    font-size: clamp(1.2rem, 1.8vw, 1.45rem);
  }

  .split-option p {
    font-size: 0.84rem;
    line-height: 1.34;
  }
}

@media (max-width: 760px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .customer-dashboard-header,
  .customer-dashboard-grid {
    grid-template-columns: 1fr;
    min-width: 0;
    width: 100%;
    max-width: calc(100vw - 24px);
  }

  .customer-dashboard-shell {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    padding: 32px 0;
    overflow-x: hidden;
  }

  .customer-dashboard-header h1 {
    max-width: 100%;
    font-size: clamp(1.8rem, 7.8vw, 2.18rem);
    line-height: 1.08;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  .customer-dashboard-header .lead {
    font-size: 1rem;
    line-height: 1.42;
  }

  .customer-dashboard-header .lead,
  .customer-dashboard-summary,
  .customer-dashboard-panel,
  .customer-dashboard-zone-heading,
  .customer-command-strip,
  .customer-proof-strip,
  .support-ribbon {
    width: 100%;
    max-width: calc(100vw - 24px);
    overflow-wrap: anywhere;
  }

  .customer-proof-strip {
    grid-template-columns: 1fr;
    gap: 10px;
    margin: -8px 0 22px;
  }

  .customer-command-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 22px;
  }

  .customer-command-strip article {
    min-height: 82px;
    padding: 14px;
  }

  .support-ribbon {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 22px;
  }

  .customer-dashboard-panel h2,
  .support-ribbon h2,
  .customer-dashboard-zone-heading h2 {
    font-size: 1.12rem;
    line-height: 1.18;
    overflow-wrap: anywhere;
  }

  .support-ribbon-actions {
    grid-template-columns: 1fr;
    padding-top: 0;
  }

  .customer-dashboard-panel,
  .customer-dashboard-panel * {
    min-width: 0;
    max-width: 100%;
  }

  .customer-dashboard-panel textarea,
  .customer-dashboard-panel input,
  .customer-dashboard-panel button,
  .customer-dashboard-panel .button {
    max-width: 100%;
  }

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

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

  .dashboard-step {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .dashboard-step strong,
  .dashboard-step > span,
  .dashboard-step > small {
    width: 100%;
  }

  .dashboard-step > span {
    text-align: left;
  }

  .integration-list {
    grid-template-columns: 1fr;
  }

  .support-check-list,
  .capability-now-list,
  .connection-list,
  .workflow-library-list {
    grid-template-columns: 1fr;
  }

  .connection-card {
    grid-template-columns: 1fr;
  }

  .dashboard-step > small {
    padding-left: 0;
  }

  .connection-card-action {
    align-items: stretch;
    flex-direction: column;
  }

  .avatar-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .avatar-strip article {
    padding: 8px;
  }

  .avatar-strip .agent-avatar {
    max-width: 74px;
  }

  .avatar-strip h3 {
    font-size: 0.78rem;
  }

  .avatar-strip p {
    font-size: 0.66rem;
    line-height: 1.15;
  }

  .payment-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .payment-grid article {
    padding: 18px;
  }

  .payment-grid strong {
    font-size: clamp(1.65rem, 8vw, 2.1rem);
  }

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

  .assistant-option {
    grid-template-columns: 34px 1fr;
    min-height: 48px;
    gap: 6px;
    padding: 6px;
  }

  .assistant-option img {
    width: 34px;
    height: 34px;
  }

  .assistant-option strong {
    font-size: 0.78rem;
  }

  body[data-live-avatar] main {
    padding-bottom: 210px;
  }

  .live-companion {
    right: max(10px, env(safe-area-inset-right));
    bottom: max(10px, env(safe-area-inset-bottom));
    left: max(10px, env(safe-area-inset-left));
    width: auto;
    max-width: none;
    grid-template-columns: 66px minmax(0, 1fr);
    align-items: end;
    justify-items: stretch;
    gap: 8px;
    transform: none;
  }

  .live-companion.is-human {
    right: max(10px, env(safe-area-inset-right));
    bottom: max(10px, env(safe-area-inset-bottom));
    left: max(10px, env(safe-area-inset-left));
    width: auto;
    grid-template-columns: 66px minmax(0, 1fr);
    justify-items: stretch;
  }

  .live-companion-toggle {
    width: 66px;
    height: 106px;
    justify-self: end;
  }

  .live-companion.is-human .live-companion-toggle {
    width: 66px;
    height: 106px;
  }

  .live-companion-avatar {
    width: 100%;
    height: 100%;
  }

  .live-companion-panel {
    display: block;
    align-self: center;
    min-width: 0;
    padding: 9px 10px 10px;
    border-radius: 14px;
  }

  .live-companion.is-collapsed {
    width: 64px;
    left: auto;
    grid-template-columns: 64px;
  }

  .live-companion.is-collapsed .live-companion-panel {
    display: none;
  }

  .live-companion.is-collapsed .live-companion-toggle {
    width: 64px;
    height: 64px;
  }

  .live-companion.is-collapsed .live-companion-avatar {
    width: 56px;
    height: 56px;
  }

  .live-companion-kicker {
    margin-bottom: 1px;
    font-size: 0.62rem;
    letter-spacing: 0.07em;
  }

  .live-companion-name {
    font-size: 0.9rem;
  }

  .live-companion-message {
    display: -webkit-box;
    overflow: hidden;
    margin-top: 1px;
    font-size: 0.76rem;
    line-height: 1.25;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .live-companion-actions {
    gap: 5px;
    margin-top: 7px;
  }

  .live-companion-actions button {
    min-height: 28px;
    padding: 5px 8px;
    font-size: 0.7rem;
  }

  .live-companion-cue {
    left: -2px;
    top: 8px;
    max-width: 84px;
    min-height: 24px;
    padding: 5px 7px;
    font-size: 0.64rem;
  }

  .live-companion:not(.is-human) {
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .live-companion:not(.is-human) .live-companion-toggle {
    width: 56px;
    height: 56px;
  }

  .live-companion:not(.is-human) .live-companion-avatar {
    width: 52px;
    height: 52px;
  }

  .live-companion.is-human.is-collapsed.is-action-work {
    right: 2px;
    bottom: -72px;
    left: auto;
    width: min(44vw, 170px);
    grid-template-columns: min(44vw, 170px);
  }

  .live-companion.is-human.is-collapsed.is-action-work .live-companion-toggle {
    width: min(44vw, 170px);
    height: min(63vw, 244px);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    filter: drop-shadow(0 20px 24px rgba(8, 31, 38, 0.22));
  }

  .live-companion.is-human.is-collapsed.is-action-work .live-companion-avatar {
    width: 100%;
    height: 100%;
  }

  .presence-row {
    grid-template-columns: 1fr;
  }

  .site-header {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-right: 24px;
    padding-left: 24px;
  }

  nav {
    width: 100%;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 18px;
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
    white-space: nowrap;
  }

  nav::-webkit-scrollbar {
    display: none;
  }

  .hero,
  .split-hero,
  .section,
  .examples-section,
  .audience-section,
  .people-section,
  .answer-section,
  .case-study-section,
  .booking-section,
  .trust-section,
  .why-section,
  .workflow-section,
  .case-hero,
  .case-detail-section,
  .case-quote-section,
  .model-section,
  .control-section,
  .pricing-section {
    padding-right: 24px;
    padding-left: 24px;
  }

  .split-hero {
    gap: 12px;
    padding-top: 16px;
    padding-bottom: 18px;
  }

  .section,
  .examples-section,
  .audience-section,
  .people-section,
  .answer-section,
  .case-study-section,
  .booking-section,
  .trust-section,
  .why-section,
  .workflow-section,
  .case-detail-section,
  .case-quote-section,
  .model-section,
  .control-section,
  .pricing-section {
    padding-top: 46px;
    padding-bottom: 52px;
  }

  .section-heading h2 {
    font-size: clamp(2rem, 9vw, 2.65rem);
    line-height: 1.03;
  }

  .hero-copy,
  .split-copy,
  .booking-copy,
  .split-options,
  .assistant-panel,
  .business-hero-photo,
  .hero-agent-mosaic,
  .hero-media-stack,
  .business-hero-offer,
  .assistant-profile,
  .premium-companion-demo,
  .promo-reel,
  .lead,
  .button,
  .trust-row,
  .service-grid,
  .example-list,
  .audience-grid,
  .people-gallery,
  .teen-grid,
  .teen-gallery,
  .faq-list,
  .case-study-grid,
  .why-grid,
  .workflow-grid,
  .case-detail-grid,
  .outcome-row,
  .model-grid,
  .control-grid,
  .price-grid,
  .mini-card,
  .booking-form {
    max-width: 342px;
  }

  .split-copy .lead {
    font-size: 0.9rem;
    line-height: 1.34;
  }

  .ownership-note {
    margin-top: 6px;
    font-size: 0.82rem;
  }

  .split-copy .hero-actions {
    gap: 8px;
    margin-top: 12px;
  }

  .split-copy .button {
    min-height: 38px;
    padding: 0 14px;
    font-size: 0.86rem;
  }

  .help-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    margin-top: 10px;
  }

  .help-stack span {
    min-height: 30px;
    padding: 5px 8px;
    font-size: 0.72rem;
  }

  .booking-copy,
  .mini-card {
    width: 100%;
  }

  .mini-card {
    display: grid;
    gap: 8px;
  }

  .hero-media-stack,
  .premium-companion-demo {
    width: 100%;
    min-width: 0;
    justify-self: start;
  }

  .service-grid article,
  .example-list span,
  .audience-grid article,
  .people-gallery article,
  .teen-grid article,
  .teen-gallery article,
  .faq-list article,
  .case-summary,
  .testimonial-card,
  .why-grid article,
  .workflow-grid article,
  .case-detail-grid article,
  .outcome-row span,
  .model-grid article,
  .control-grid article,
  .price-grid article {
    min-width: 0;
  }

  .price-grid {
    gap: 12px;
    margin-top: 22px;
  }

  .price-grid article {
    min-height: 0;
    padding: 22px;
  }

  .price-grid strong {
    font-size: clamp(1.9rem, 9vw, 2.35rem);
    line-height: 1.06;
  }

  h1 {
    font-size: clamp(2.25rem, 10vw, 2.65rem);
    line-height: 0.94;
  }

  .case-hero h1 {
    font-size: clamp(2.25rem, 10vw, 2.75rem);
    line-height: 0.98;
  }

  .case-hero .lead {
    font-size: 1rem;
    line-height: 1.5;
  }

  .split-copy h1 {
    margin-bottom: 8px;
    font-size: clamp(1.95rem, 9vw, 2.35rem);
    line-height: 1.02;
  }

  .split-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .split-option {
    min-height: 0;
    gap: 5px;
    padding: 10px;
  }

  .card-cta {
    position: static;
    min-height: 26px;
    margin-top: 0;
    padding: 5px 7px;
    font-size: 0.66rem;
  }

  .promo-reel {
    min-height: 0;
    padding: 8px;
  }

  .premium-companion-demo {
    min-height: 360px;
    padding: 12px;
  }

  .floating-companion-demo {
    min-height: 300px;
    padding: 0;
  }

  .floating-companion-demo .avatar-engine {
    right: max(18px, env(safe-area-inset-right));
    bottom: max(18px, env(safe-area-inset-bottom));
    left: auto;
    --avatar-scale: 0.34;
  }

  .screen-cliff {
    display: none;
  }

  .screen-cliff-panel {
    display: none;
  }

  .screen-cliff .avatar-engine {
    --avatar-scale: 0.34;
  }

  .screen-cliff-static {
    width: 66px;
    height: 100px;
  }

  .screen-cliff-idle-sprite {
    width: 70px;
    height: 106px;
    overflow: hidden;
    filter: drop-shadow(0 13px 13px rgba(22, 34, 31, 0.16));
  }

  .screen-cliff-idle-sprite video {
    display: none;
  }

  .screen-cliff-fallback-sheet {
    position: absolute;
    right: 0;
    bottom: 0;
    display: block;
    width: 70px;
    height: 106px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
  }

  .screen-cliff-fallback-sheet img {
    display: none;
  }

  .screen-cliff-fallback-idle {
    opacity: 1;
    background-image: url("assets/cliff-idle-loop-v3-1-grounded.png");
    background-size: 800% 100%;
    background-position: 0 0;
    animation: screenCliffIdleMobileFrames 4.2s steps(8) infinite;
  }

  .screen-cliff-fallback-attention {
    background-image: url("assets/cliff-listen-attention-v2-1-no-wink-registered.png");
    background-size: 1600% 100%;
    background-position: 0 0;
    animation: screenCliffAttentionMobileFrames 4.36s steps(16) 1 both;
  }

  .screen-cliff.is-screen-attention .screen-cliff-fallback-idle {
    opacity: 0;
  }

  .screen-cliff.is-screen-attention .screen-cliff-fallback-attention {
    opacity: 1;
  }

  .screen-cliff[data-screen-path="business"].is-reacting {
    right: max(4px, env(safe-area-inset-right));
    bottom: max(2px, env(safe-area-inset-bottom));
    width: 78px;
    height: 108px;
  }

  .screen-cliff[data-screen-path="business"].is-reacting .avatar-engine {
    right: 0;
    --avatar-scale: 0.34;
  }

  .screen-cliff[data-screen-path="business"].is-reacting .screen-cliff-panel {
    opacity: 0;
    pointer-events: none;
  }

  .companion-guide {
    right: 14px;
    left: 14px;
    bottom: 88px;
    width: auto;
    max-width: none;
    padding: 10px;
    animation: none;
    transform: none;
  }

  .companion-guide::after {
    right: 46px;
    bottom: -9px;
    border-top: 0;
    border-bottom: 1px solid rgba(18, 121, 111, 0.18);
  }

  .companion-guide p {
    font-size: 0.76rem;
  }

  .companion-guide div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 5px;
    margin-top: 8px;
  }

  .companion-guide button {
    min-height: 28px;
    font-size: 0.66rem;
    min-width: 0;
  }

  .premium-demo-top {
    align-items: flex-start;
    flex-direction: column;
  }

  .premium-demo-scene {
    min-height: 252px;
  }

  .premium-workspace {
    inset: 18px 12px 48px 34%;
  }

  .floating-companion-demo .premium-workspace {
    display: none;
  }

  .floating-companion-demo .premium-demo-dock {
    bottom: 86px;
  }

  .workspace-card,
  .workspace-result {
    min-width: 84px;
    padding: 7px 8px;
    font-size: 0.68rem;
  }

  .panel-calendar {
    width: 128px;
    height: 86px;
  }

  .panel-approval {
    right: 0;
    bottom: 0;
    width: 136px;
    height: 72px;
  }

  .card-one {
    top: 34px;
    left: 2px;
  }

  .card-two {
    top: 88px;
    left: 18%;
  }

  .card-three {
    top: 130px;
    left: 6%;
  }

  .workspace-result {
    right: 0;
    bottom: 82px;
  }

  .premium-demo-actions {
    flex-wrap: wrap;
  }

  .premium-demo-actions button {
    flex: 1 1 calc(50% - 6px);
  }

  .promo-reel-top {
    align-items: center;
    flex-direction: row;
    gap: 8px;
    margin-bottom: 8px;
    font-size: 0.66rem;
  }

  .promo-reel-top strong {
    padding: 5px 7px;
    font-size: 0.66rem;
  }

  .promo-storyboard img {
    aspect-ratio: 2.25 / 1;
  }

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

  .promo-stage {
    grid-template-columns: 1fr;
  }

  .promo-avatar-group {
    display: flex;
    justify-content: flex-start;
    padding-left: 4px;
  }

  .promo-avatar-group img + img {
    margin-top: 0;
    margin-left: -30px;
  }

  .promo-phone {
    min-height: 188px;
  }

  .promo-task-stack {
    position: static;
    width: 100%;
    margin-top: 10px;
  }

  .split-agent-row img {
    width: 32px;
    height: 32px;
    border-width: 2px;
  }

  .split-agent-row img + img {
    margin-left: -11px;
  }

  .split-agent-label {
    flex: 1 1 120px;
    min-width: 0;
    margin-left: 12px;
    font-size: 0.82rem;
  }

  .split-option p {
    max-width: 100%;
    margin-bottom: 0;
    font-size: 0.72rem;
    line-height: 1.24;
  }

  .split-option h2 {
    font-size: clamp(1.02rem, 5vw, 1.18rem);
    line-height: 1.05;
  }

  h2 {
    max-width: 342px;
    font-size: clamp(2rem, 9vw, 2.45rem);
    line-height: 1.02;
  }

  .service-grid,
  .example-list,
  .audience-grid,
  .people-gallery,
  .teen-grid,
  .teen-gallery,
  .faq-list,
  .case-study-grid,
  .why-grid,
  .workflow-grid,
  .case-detail-grid,
  .model-grid,
  .control-grid,
  .price-grid {
    grid-template-columns: 1fr;
  }

  .outcome-row {
    grid-template-columns: 1fr;
  }

  .teen-gallery article {
    grid-template-columns: 96px minmax(0, 1fr);
    padding: 14px;
  }

  .trust-section > p {
    max-width: 342px;
    padding: 18px;
  }

  .assistant-profile,
  .assistant-profile.featured {
    grid-template-columns: 1fr;
    min-height: 0;
  }

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

  .hero-agent-mosaic div {
    padding: 12px;
  }

  .hero-agent-mosaic h2 {
    font-size: 1.35rem;
  }

  .assistant-profile img {
    height: 300px;
    object-fit: contain;
    object-position: 50% 50%;
  }

  .business-hero-photo img {
    aspect-ratio: 16 / 9;
  }

  .button {
    width: 100%;
  }

  .admin-heading,
  .admin-card-top {
    display: grid;
  }

  .admin-stats,
  .admin-controls,
  .admin-details,
  .provisioning-checklist,
  .customer-readiness {
    grid-template-columns: 1fr;
  }

  .admin-card-actions {
    justify-content: flex-start;
  }
}

@media (prefers-reduced-motion: reduce) {
  .live-companion,
  .live-companion-avatar,
  .live-companion-orbit,
  .premium-companion-demo *,
  .premium-companion-demo *::before,
  .premium-companion-demo *::after,
  .screen-cliff-idle-sprite img,
  .screen-cliff-idle-sprite video {
    animation: none;
    transition: none;
  }
}

@media (max-width: 620px) {
  .business-hero-offer {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .business-hero-offer span {
    min-height: 48px;
    padding: 8px 9px;
    font-size: 0.72rem;
  }

  .business-hero-offer strong {
    font-size: 0.84rem;
  }

  .home-proof-section,
  .home-start-section {
    padding-top: 42px;
    padding-bottom: 46px;
  }

  .home-proof-heading,
  .home-proof-grid,
  .home-start-card,
  .home-offer-grid {
    max-width: 342px;
  }

  .home-proof-heading h2,
  .home-start-card h2 {
    font-size: clamp(1.78rem, 8vw, 2.22rem);
    line-height: 1.04;
  }

  .home-proof-heading p {
    font-size: 0.9rem;
    line-height: 1.42;
  }

  .home-proof-grid article,
  .home-offer-grid article {
    min-height: 0;
    padding: 18px;
  }

  .home-start-card {
    padding: 18px;
  }

  .home-start-steps span {
    min-height: 48px;
    grid-template-columns: 30px 1fr;
    font-size: 0.82rem;
    line-height: 1.22;
  }

  .home-start-steps strong {
    width: 30px;
    height: 30px;
  }

  .start-flow-form {
    gap: 12px;
  }

  .start-flow-form fieldset,
  .start-flow-form .guided-field,
  .start-contact-panel,
  .start-guardrail-note {
    padding: 12px;
  }

  .start-flow-form .support-picker {
    grid-template-columns: 1fr;
  }

  .start-flow-form .assistant-picker {
    grid-template-columns: 1fr;
  }

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

  .start-process-card {
    padding: 12px;
  }

  .start-flow-form .support-picker .assistant-option {
    min-height: 0;
  }

  .start-contact-panel .form-row {
    grid-template-columns: 1fr;
  }

  .start-choice-section {
    min-height: 0;
    padding-top: 34px;
    padding-bottom: 46px;
  }

  .start-choice-heading {
    text-align: left;
  }

  .start-choice-heading h1,
  .start-choice-heading .lead {
    margin-left: 0;
  }

  .start-path-switch {
    width: 100%;
    margin-top: 12px;
    margin-left: 0;
  }

  .start-path-switch a {
    min-height: 38px;
    font-size: 0.8rem;
  }

  .start-choice-grid {
    grid-template-columns: 1fr;
  }

  .start-choice-card {
    min-height: 0;
    gap: 12px;
    padding: 18px;
  }

  .start-card-topline {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .start-card-topline .split-agent-row {
    min-height: 38px;
  }

  .start-card-topline .split-agent-row img {
    width: 38px;
    height: 38px;
  }

  .start-choice-card.business .start-price-line,
  .start-price-line {
    grid-template-columns: 1fr;
  }

  .start-price-line span {
    min-height: 48px;
  }

  .start-choice-note {
    text-align: left;
  }
}

@media print {
  @page {
    size: A4;
    margin: 14mm;
  }

  html {
    scroll-behavior: auto;
  }

  body {
    background: #fff;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .site-header,
  .booking-copy {
    position: static;
  }

  .site-header {
    padding: 0 0 12px;
    margin-bottom: 18px;
    background: #fff;
  }

  .hero,
  .section,
  .examples-section,
  .audience-section,
  .people-section,
  .answer-section,
  .case-study-section,
  .booking-section,
  .trust-section,
  .why-section,
  .workflow-section,
  .case-hero,
  .case-detail-section,
  .case-quote-section,
  .model-section,
  .control-section,
  .pricing-section {
    padding: 0;
  }

  .hero {
    min-height: 0;
    grid-template-columns: 1fr;
    gap: 22px;
    margin-bottom: 28px;
    background: #fff;
  }

  .assistant-panel {
    max-height: none;
  }

  .assistant-profile,
  .assistant-profile.featured {
    min-height: 0;
    grid-template-columns: 180px 1fr;
    box-shadow: none;
  }

  .assistant-profile img {
    min-height: 190px;
  }

  h1 {
    font-size: 58px;
    line-height: 0.95;
  }

  h2 {
    font-size: 34px;
    line-height: 1.05;
  }

  .section,
  .examples-section,
  .audience-section,
  .answer-section,
  .case-study-section,
  .booking-section,
  .trust-section,
  .model-section,
  .control-section,
  .pricing-section {
    margin-top: 28px;
  }

  .service-grid,
  .example-list,
  .audience-grid,
  .people-gallery,
  .teen-grid,
  .teen-gallery,
  .faq-list,
  .case-study-grid,
  .model-grid,
  .control-grid,
  .price-grid,
  .booking-section,
  .trust-section {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .service-grid article,
  .example-list span,
  .audience-grid article,
  .people-gallery article,
  .teen-grid article,
  .teen-gallery article,
  .faq-list article,
  .case-summary,
  .testimonial-card,
  .outcome-row span,
  .model-grid article,
  .control-grid article,
  .price-grid article,
  .trust-section > p,
  .booking-form {
    box-shadow: none;
  }

  .button {
    min-height: 42px;
  }

  footer {
    margin-top: 24px;
    padding: 16px 0;
  }
}

@media (max-width: 760px) {
  .customer-dashboard-shell,
  .customer-dashboard-header,
  .customer-dashboard-grid,
  .customer-dashboard-panel,
  .customer-dashboard-summary,
  .customer-command-strip,
  .customer-proof-strip,
  .support-ribbon {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .customer-dashboard-shell {
    padding-right: 12px;
    padding-left: 12px;
  }

  .customer-command-strip {
    grid-template-columns: 1fr !important;
  }

  .customer-proof-strip {
    grid-template-columns: 1fr !important;
  }

  .customer-command-strip article {
    min-height: 74px;
  }

  .customer-dashboard-header h1,
  .customer-dashboard-header .lead,
  .customer-dashboard-panel h2,
  .support-ribbon h2,
  .dashboard-card-list,
  .dashboard-mini-card,
  .dashboard-mini-card *,
  .dashboard-step,
  .dashboard-step *,
  .support-ribbon-actions,
  .support-ribbon-actions *,
  .customer-readiness,
  .customer-readiness *,
  .inline-form,
  .inline-form * {
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: normal;
    white-space: normal;
  }

  .dashboard-mini-card,
  .dashboard-mini-card span,
  .dashboard-mini-card small,
  .dashboard-mini-card em,
  .inline-form textarea,
  .inline-form input {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .split-options,
  .home-proof-grid,
  .home-offer-grid,
  .start-choice-grid {
    grid-template-columns: 1fr;
  }

  .split-option {
    min-height: 0;
    padding: 16px;
  }

  .split-option p {
    font-size: 0.9rem;
    line-height: 1.35;
  }

  .split-option .card-cta {
    align-self: flex-start;
    min-height: 34px;
    padding: 8px 10px;
    font-size: 0.75rem;
  }
}
