.launch-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 22px;
  background: #f7f5ef;
  color: #172026;
  transition: opacity 180ms ease, visibility 0s linear 180ms;
}

img {
  background-color: #f1efe8;
  max-width: 100%;
}

img.asset-fallback-image {
  object-fit: cover;
  background: #f1efe8;
}

html {
  scroll-behavior: smooth;
}

body {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

section,
[id] {
  scroll-margin-top: 92px;
}

a,
button,
input,
select,
textarea {
  -webkit-tap-highlight-color: transparent;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid currentColor;
  outline-offset: 4px;
}

a.button,
.button,
.action,
button,
input[type="submit"],
.mobile-contact-bar a {
  min-height: 44px;
}

input,
select,
textarea {
  font: inherit;
}

.site-demo-disclosure {
  max-width: min(1120px, calc(100% - 40px));
  margin: 0 auto 24px;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .78);
  color: inherit;
  display: grid;
  grid-template-columns: minmax(220px, .78fr) minmax(320px, 1.22fr);
  gap: 16px;
  align-items: stretch;
  box-shadow: 0 16px 42px rgba(23, 32, 38, .08);
  overflow: hidden;
}

.site-demo-copy {
  min-width: 0;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.site-demo-copy-text {
  min-width: 0;
  display: grid;
  gap: 9px;
}

.site-demo-disclosure strong {
  flex: 0 0 auto;
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.site-demo-disclosure span {
  color: inherit;
  opacity: .76;
  font-size: 14px;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.site-demo-disclosure a {
  color: inherit;
  font-weight: 800;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.site-demo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.site-demo-action {
  min-height: 40px;
  padding: 0 13px;
  border-radius: 7px;
  border: 1px solid rgba(23, 32, 38, .16);
  background: #172026;
  color: #fff !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  white-space: normal;
}

.site-demo-action.secondary {
  background: rgba(255, 255, 255, .76);
  color: inherit !important;
}

.site-demo-points {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.site-demo-points span {
  min-height: 68px;
  padding: 10px 12px;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(246, 248, 247, .72);
  display: flex;
  flex-direction: column;
  gap: 4px;
  justify-content: center;
  overflow-wrap: anywhere;
  min-width: 0;
}

.site-demo-points b {
  color: inherit;
  font-size: 13px;
}

.site-quick-scan {
  max-width: min(1120px, calc(100% - 40px));
  margin: -18px auto 30px;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .86);
  color: inherit;
  box-shadow: 0 18px 44px rgba(23, 32, 38, .1);
  display: grid;
  grid-template-columns: minmax(260px, .88fr) minmax(360px, 1.12fr);
  gap: 16px;
  align-items: stretch;
}

.site-quick-scan__copy,
.site-quick-scan__points article {
  min-width: 0;
}

.site-quick-scan__copy {
  display: grid;
  gap: 9px;
  align-content: center;
}

.site-quick-scan__copy span {
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .72;
}

.site-quick-scan__copy h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.05;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.site-quick-scan__copy p {
  margin: 0;
  color: inherit;
  opacity: .74;
  font-size: 15px;
  line-height: 1.6;
}

.site-quick-scan__copy a {
  width: fit-content;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 7px;
  background: #172026;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.15;
}

.site-quick-scan__points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.site-quick-scan__points article {
  min-height: 138px;
  padding: 16px;
  border-radius: 7px;
  border: 1px solid rgba(23, 32, 38, .1);
  background: rgba(246, 248, 247, .7);
  display: grid;
  align-content: start;
  gap: 8px;
}

.site-quick-scan__points b {
  font-size: 14px;
  line-height: 1.25;
}

.site-quick-scan__points p {
  margin: 0;
  color: inherit;
  opacity: .72;
  font-size: 14px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.site-quick-scan[data-theme="barber"] .site-quick-scan__copy a,
.site-demo-disclosure[data-theme="barber"] .site-demo-action {
  background: #a65e3b;
}

.site-quick-scan[data-theme="restaurant"] .site-quick-scan__copy a,
.site-demo-disclosure[data-theme="restaurant"] .site-demo-action {
  background: #526c46;
}

.site-quick-scan[data-theme="construction"] .site-quick-scan__copy a,
.site-demo-disclosure[data-theme="construction"] .site-demo-action {
  background: #345e8c;
}

.site-quick-scan[data-theme="dental"] .site-quick-scan__copy a,
.site-demo-disclosure[data-theme="dental"] .site-demo-action {
  background: #25706c;
}

.site-contact-assurance {
  max-width: min(1120px, calc(100% - 40px));
  margin: 26px auto;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: #fff;
  color: inherit;
  box-shadow: 0 18px 44px rgba(23, 32, 38, .08);
  display: grid;
  grid-template-columns: minmax(260px, .92fr) minmax(360px, 1.08fr);
  gap: 16px;
  align-items: stretch;
}

.site-contact-assurance__copy,
.site-contact-assurance__points article {
  min-width: 0;
}

.site-contact-assurance__copy {
  display: grid;
  gap: 9px;
  align-content: center;
}

.site-contact-assurance__copy span {
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .72;
}

.site-contact-assurance__copy h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.site-contact-assurance__copy p {
  margin: 0;
  color: inherit;
  opacity: .74;
  line-height: 1.62;
  font-size: 15px;
  overflow-wrap: anywhere;
}

.site-contact-assurance__copy a {
  width: fit-content;
  min-height: 42px;
  padding: 0 15px;
  border-radius: 7px;
  background: #172026;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
}

.site-contact-assurance__right {
  min-width: 0;
  display: grid;
  gap: 10px;
}

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

.site-contact-assurance__points article {
  min-height: 118px;
  padding: 13px;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(246, 248, 247, .76);
  display: grid;
  align-content: start;
  gap: 7px;
}

.site-contact-assurance__points b {
  font-size: 13px;
  line-height: 1.25;
}

.site-contact-assurance__points p {
  margin: 0;
  color: inherit;
  opacity: .72;
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.site-contact-assurance__meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.site-contact-assurance__meta span {
  min-width: 0;
  min-height: 58px;
  padding: 11px 13px;
  border-radius: 7px;
  border: 1px solid rgba(23, 32, 38, .1);
  background: rgba(255, 255, 255, .72);
  color: inherit;
  font-size: 13px;
  line-height: 1.42;
  overflow-wrap: anywhere;
}

.site-contact-assurance__meta b {
  display: block;
  margin-bottom: 3px;
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .72;
}

.site-contact-assurance[data-theme="barber"] .site-contact-assurance__copy a {
  background: #a65e3b;
}

.site-contact-assurance[data-theme="restaurant"] .site-contact-assurance__copy a {
  background: #526c46;
}

.site-contact-assurance[data-theme="construction"] .site-contact-assurance__copy a {
  background: #345e8c;
}

.site-contact-assurance[data-theme="dental"] .site-contact-assurance__copy a {
  background: #25706c;
}

.site-offer-snapshot {
  max-width: min(1120px, calc(100% - 40px));
  margin: 22px auto 34px;
  padding: 20px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255, 255, 255, .92), rgba(246, 248, 247, .82));
  color: inherit;
  display: grid;
  grid-template-columns: minmax(250px, .72fr) minmax(360px, 1.28fr);
  gap: 18px;
  box-shadow: 0 20px 52px rgba(23, 32, 38, .1);
  overflow: hidden;
}

.site-offer-snapshot__lead,
.site-offer-snapshot__card,
.site-offer-snapshot__note {
  min-width: 0;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(255, 255, 255, .76);
  overflow-wrap: anywhere;
}

.site-offer-snapshot__lead {
  padding: 22px;
  display: grid;
  gap: 12px;
  align-content: center;
}

.site-offer-snapshot__lead span {
  color: #2f6f57;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.site-offer-snapshot__lead h2 {
  margin: 0;
  font-size: clamp(25px, 3vw, 37px);
  line-height: 1.08;
  letter-spacing: 0;
}

.site-offer-snapshot__lead p {
  margin: 0;
  color: rgba(23, 32, 38, .72);
  font-size: 15px;
  line-height: 1.6;
}

.site-offer-snapshot__grid {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.site-offer-snapshot__card {
  min-height: 158px;
  padding: 16px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.site-offer-snapshot__card b {
  color: #172026;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.site-offer-snapshot__card strong {
  color: #172026;
  font-size: 17px;
  line-height: 1.18;
}

.site-offer-snapshot__card p {
  margin: 0;
  color: rgba(23, 32, 38, .68);
  font-size: 14px;
  line-height: 1.5;
}

.site-offer-snapshot__note {
  grid-column: 1 / -1;
  padding: 14px 16px;
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  color: rgba(23, 32, 38, .74);
  font-size: 14px;
  line-height: 1.45;
}

.site-offer-snapshot__note b {
  color: #172026;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: normal;
}

.site-offer-snapshot__note a {
  min-width: 170px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 7px;
  background: #172026;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
}

.site-offer-snapshot[data-theme="barber"] {
  border-color: rgba(166, 94, 59, .2);
  background: linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(250, 244, 239, .86));
}

.site-offer-snapshot[data-theme="barber"] .site-offer-snapshot__lead span,
.site-offer-snapshot[data-theme="barber"] .site-offer-snapshot__card b {
  color: #a65e3b;
}

.site-offer-snapshot[data-theme="barber"] .site-offer-snapshot__note a {
  background: #a65e3b;
}

.site-offer-snapshot[data-theme="restaurant"] {
  border-color: rgba(168, 77, 63, .2);
  background: linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(248, 243, 238, .86));
}

.site-offer-snapshot[data-theme="restaurant"] .site-offer-snapshot__lead span,
.site-offer-snapshot[data-theme="restaurant"] .site-offer-snapshot__card b {
  color: #a84d3f;
}

.site-offer-snapshot[data-theme="restaurant"] .site-offer-snapshot__note a {
  background: #a84d3f;
}

.site-offer-snapshot[data-theme="construction"] {
  border-color: rgba(52, 94, 140, .22);
  background: linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(240, 245, 250, .86));
}

.site-offer-snapshot[data-theme="construction"] .site-offer-snapshot__lead span,
.site-offer-snapshot[data-theme="construction"] .site-offer-snapshot__card b {
  color: #345e8c;
}

.site-offer-snapshot[data-theme="construction"] .site-offer-snapshot__note a {
  background: #345e8c;
}

.site-offer-snapshot[data-theme="dental"] {
  border-color: rgba(37, 112, 108, .22);
  background: linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(239, 248, 247, .86));
}

.site-offer-snapshot[data-theme="dental"] .site-offer-snapshot__lead span,
.site-offer-snapshot[data-theme="dental"] .site-offer-snapshot__card b {
  color: #25706c;
}

.site-offer-snapshot[data-theme="dental"] .site-offer-snapshot__note a {
  background: #25706c;
}

.site-presentation-close {
  max-width: min(1120px, calc(100% - 40px));
  margin: 28px auto 22px;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: #ffffff;
  color: #172026;
  display: grid;
  grid-template-columns: minmax(240px, .78fr) minmax(320px, 1.22fr);
  gap: 14px;
  box-shadow: 0 16px 38px rgba(23, 32, 38, .07);
}

.site-presentation-close__copy,
.site-presentation-close__grid article {
  min-width: 0;
}

.site-presentation-close__copy {
  display: grid;
  align-content: center;
  gap: 10px;
}

.site-presentation-close__copy span {
  color: #2f6f57;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.site-presentation-close__copy h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 35px);
  line-height: 1.08;
  letter-spacing: 0;
}

.site-presentation-close__copy p {
  margin: 0;
  color: rgba(23, 32, 38, .72);
  font-size: 15px;
  line-height: 1.62;
}

.site-presentation-close__copy a {
  width: fit-content;
  min-height: 42px;
  padding: 0 15px;
  border-radius: 7px;
  background: #2f6f57;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
}

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

.site-presentation-close__grid article {
  min-height: 126px;
  padding: 14px;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(246, 248, 247, .8);
  display: grid;
  align-content: start;
  gap: 8px;
}

.site-presentation-close__grid b {
  color: #172026;
  font-size: 13px;
  line-height: 1.25;
}

.site-presentation-close__grid p {
  margin: 0;
  color: rgba(23, 32, 38, .68);
  font-size: 13px;
  line-height: 1.48;
}

.site-presentation-close[data-theme="barber"] {
  border-color: rgba(166, 94, 59, .22);
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(250,244,239,.88));
}

.site-presentation-close[data-theme="barber"] .site-presentation-close__copy span {
  color: #a65e3b;
}

.site-presentation-close[data-theme="barber"] .site-presentation-close__copy a {
  background: #a65e3b;
}

.site-presentation-close[data-theme="restaurant"] {
  border-color: rgba(168, 77, 63, .22);
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,243,238,.88));
}

.site-presentation-close[data-theme="restaurant"] .site-presentation-close__copy span {
  color: #a84d3f;
}

.site-presentation-close[data-theme="restaurant"] .site-presentation-close__copy a {
  background: #a84d3f;
}

.site-presentation-close[data-theme="construction"] {
  border-color: rgba(52, 94, 140, .24);
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(240,245,250,.88));
}

.site-presentation-close[data-theme="construction"] .site-presentation-close__copy span {
  color: #345e8c;
}

.site-presentation-close[data-theme="construction"] .site-presentation-close__copy a {
  background: #345e8c;
}

.site-presentation-close[data-theme="dental"] {
  border-color: rgba(37, 112, 108, .24);
  background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(239,248,247,.9));
}

.site-presentation-close[data-theme="dental"] .site-presentation-close__copy span {
  color: #25706c;
}

.site-presentation-close[data-theme="dental"] .site-presentation-close__copy a {
  background: #25706c;
}

.site-local-proof {
  max-width: min(1120px, calc(100% - 40px));
  margin: 22px auto 30px;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .9);
  color: inherit;
  box-shadow: 0 18px 44px rgba(23, 32, 38, .08);
  display: grid;
  grid-template-columns: minmax(240px, .74fr) minmax(400px, 1.26fr);
  gap: 16px;
  align-items: stretch;
}

.site-local-proof__copy,
.site-local-proof__item {
  min-width: 0;
}

.site-local-proof__copy {
  display: grid;
  align-content: center;
  gap: 9px;
}

.site-local-proof__copy span {
  color: inherit;
  opacity: .72;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.site-local-proof__copy h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 35px);
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.site-local-proof__copy p {
  margin: 0;
  color: inherit;
  opacity: .74;
  font-size: 15px;
  line-height: 1.62;
  overflow-wrap: anywhere;
}

.site-local-proof__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.site-local-proof__item {
  min-height: 132px;
  padding: 14px;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(246, 248, 247, .76);
  display: grid;
  align-content: start;
  gap: 8px;
}

.site-local-proof__item b {
  color: inherit;
  font-size: 13px;
  line-height: 1.25;
}

.site-local-proof__item p {
  margin: 0;
  color: inherit;
  opacity: .72;
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.site-local-proof[data-theme="barber"] .site-local-proof__copy span {
  color: #a65e3b;
  opacity: 1;
}

.site-local-proof[data-theme="restaurant"] .site-local-proof__copy span {
  color: #526c46;
  opacity: 1;
}

.site-local-proof[data-theme="construction"] .site-local-proof__copy span {
  color: #345e8c;
  opacity: 1;
}

.site-local-proof[data-theme="dental"] .site-local-proof__copy span {
  color: #25706c;
  opacity: 1;
}

.site-objection-band {
  max-width: min(1120px, calc(100% - 40px));
  margin: 28px auto 22px;
  padding: 18px;
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .88);
  color: inherit;
  box-shadow: 0 18px 44px rgba(23, 32, 38, .08);
  display: grid;
  grid-template-columns: minmax(250px, .8fr) minmax(380px, 1.2fr);
  gap: 16px;
  align-items: stretch;
}

.site-objection-band__copy,
.site-objection-band__item {
  min-width: 0;
}

.site-objection-band__copy {
  display: grid;
  align-content: center;
  gap: 9px;
}

.site-objection-band__copy span {
  color: inherit;
  opacity: .72;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.site-objection-band__copy h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 35px);
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.site-objection-band__copy p {
  margin: 0;
  color: inherit;
  opacity: .74;
  font-size: 15px;
  line-height: 1.62;
  overflow-wrap: anywhere;
}

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

.site-objection-band__item {
  min-height: 150px;
  padding: 14px;
  border: 1px solid rgba(23, 32, 38, .1);
  border-radius: 7px;
  background: rgba(246, 248, 247, .76);
  display: grid;
  align-content: start;
  gap: 8px;
}

.site-objection-band__item b {
  color: inherit;
  font-size: 13px;
  line-height: 1.25;
}

.site-objection-band__item p {
  margin: 0;
  color: inherit;
  opacity: .72;
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.site-objection-band__item strong {
  align-self: end;
  color: inherit;
  font-size: 12px;
  line-height: 1.3;
  opacity: .88;
}

.site-objection-band[data-theme="barber"] .site-objection-band__copy span {
  color: #a65e3b;
  opacity: 1;
}

.site-objection-band[data-theme="restaurant"] .site-objection-band__copy span {
  color: #526c46;
  opacity: 1;
}

.site-objection-band[data-theme="construction"] .site-objection-band__copy span {
  color: #345e8c;
  opacity: 1;
}

.site-objection-band[data-theme="dental"] .site-objection-band__copy span {
  color: #25706c;
  opacity: 1;
}

.site-launch-readiness {
  max-width: min(1120px, calc(100% - 40px));
  margin: 0 auto 24px;
  display: grid;
  grid-template-columns: minmax(260px, .92fr) minmax(320px, 1.08fr);
  gap: 1px;
  background: rgba(23, 32, 38, .14);
  border: 1px solid rgba(23, 32, 38, .14);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 18px 46px rgba(23, 32, 38, .08);
}

.site-launch-readiness__copy,
.site-launch-readiness__item {
  min-width: 0;
  background: rgba(255, 255, 255, .86);
}

.site-launch-readiness__copy {
  padding: 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 13px;
}

.site-launch-readiness__copy span {
  width: fit-content;
  max-width: 100%;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(23, 32, 38, .08);
  color: #172026;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.1;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.site-launch-readiness__copy h2 {
  margin: 0;
  font-size: clamp(26px, 4vw, 42px);
  line-height: 1.06;
  letter-spacing: 0;
}

.site-launch-readiness__copy p {
  margin: 0;
  color: rgba(23, 32, 38, .72);
  font-size: 15px;
  line-height: 1.62;
}

.site-launch-readiness__copy a {
  min-height: 42px;
  padding: 0 15px;
  border-radius: 7px;
  background: #172026;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
}

.site-launch-readiness__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
}

.site-launch-readiness__item {
  min-height: 142px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}

.site-launch-readiness__item b {
  display: block;
  color: #172026;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.site-launch-readiness__item p {
  margin: 0;
  color: rgba(23, 32, 38, .7);
  font-size: 14px;
  line-height: 1.5;
}

.site-launch-readiness[data-theme="barber"] .site-launch-readiness__copy span {
  color: #a65e3b;
  background: rgba(166, 94, 59, .1);
}

.site-launch-readiness[data-theme="barber"] .site-launch-readiness__copy a {
  background: #a65e3b;
}

.site-launch-readiness[data-theme="restaurant"] .site-launch-readiness__copy span {
  color: #a84d3f;
  background: rgba(168, 77, 63, .1);
}

.site-launch-readiness[data-theme="restaurant"] .site-launch-readiness__copy a {
  background: #a84d3f;
}

.site-launch-readiness[data-theme="construction"] .site-launch-readiness__copy span {
  color: #345e8c;
  background: rgba(52, 94, 140, .1);
}

.site-launch-readiness[data-theme="construction"] .site-launch-readiness__copy a {
  background: #345e8c;
}

.site-launch-readiness[data-theme="dental"] .site-launch-readiness__copy span {
  color: #25706c;
  background: rgba(37, 112, 108, .1);
}

.site-launch-readiness[data-theme="dental"] .site-launch-readiness__copy a {
  background: #25706c;
}

@media (max-width: 860px) {
  .site-demo-disclosure {
    grid-template-columns: 1fr;
  }

  .site-quick-scan,
  .site-contact-assurance,
  .site-offer-snapshot,
  .site-local-proof,
  .site-presentation-close,
  .site-objection-band,
  .site-launch-readiness {
    grid-template-columns: 1fr;
    margin-top: 18px;
  }

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

@media (max-width: 560px) {
  .site-demo-disclosure {
    max-width: calc(100% - 24px);
    padding: 14px;
    gap: 12px;
  }

  .site-demo-copy {
    display: grid;
    gap: 8px;
  }

  .site-demo-actions,
  .site-demo-action {
    width: 100%;
  }

  .site-demo-points {
    grid-template-columns: 1fr;
  }

  .site-demo-points span {
    min-height: auto;
  }

  .site-quick-scan,
  .site-contact-assurance,
  .site-offer-snapshot,
  .site-local-proof,
  .site-presentation-close,
  .site-objection-band,
  .site-launch-readiness {
    max-width: calc(100% - 24px);
    padding: 15px;
    gap: 12px;
  }

  .site-offer-snapshot {
    padding: 12px;
    gap: 10px;
  }

  .site-offer-snapshot__lead {
    padding: 14px;
    gap: 9px;
  }

  .site-offer-snapshot__lead h2 {
    font-size: clamp(22px, 7.2vw, 29px);
    line-height: 1.08;
  }

  .site-offer-snapshot__lead p {
    font-size: 14px;
    line-height: 1.52;
  }

  .site-offer-snapshot__card {
    padding: 13px;
    gap: 7px;
  }

  .site-offer-snapshot__card strong {
    font-size: 16px;
  }

  .site-offer-snapshot__card p {
    font-size: 13px;
    line-height: 1.45;
  }

  .site-quick-scan__copy a,
  .site-contact-assurance__copy a,
  .site-presentation-close__copy a,
  .site-launch-readiness__copy a {
    width: 100%;
  }

  .site-quick-scan__points,
  .site-contact-assurance__points,
  .site-contact-assurance__meta,
  .site-offer-snapshot__grid,
  .site-local-proof__grid,
  .site-presentation-close__grid,
  .site-objection-band__grid,
  .site-launch-readiness__grid {
    grid-template-columns: 1fr;
  }

  .site-quick-scan__points article,
  .site-contact-assurance__points article,
  .site-contact-assurance__meta span,
  .site-offer-snapshot__card,
  .site-local-proof__item,
  .site-presentation-close__grid article,
  .site-objection-band__item,
  .site-launch-readiness__item {
    min-height: auto;
  }

  .site-offer-snapshot__note {
    display: grid;
    gap: 10px;
    justify-items: start;
    padding: 13px;
    line-height: 1.38;
  }

  .site-offer-snapshot__note a {
    min-width: 0;
    min-height: 44px;
    width: 100%;
  }

  body.has-mobile-contact-assurance {
    padding-bottom: calc(112px + env(safe-area-inset-bottom)) !important;
  }

  .mobile-contact-bar[data-assurance] {
    left: 50% !important;
    right: auto !important;
    bottom: calc(10px + env(safe-area-inset-bottom)) !important;
    width: min(360px, calc(100vw - 20px)) !important;
    max-width: calc(100vw - 20px);
    box-sizing: border-box;
    grid-template-rows: minmax(12px, auto) minmax(42px, auto);
    align-items: stretch;
    gap: 5px 6px;
    padding: 7px !important;
    transform: translateX(-50%) !important;
  }

  .mobile-contact-bar[data-assurance]::before {
    content: attr(data-assurance);
    grid-column: 1 / -1;
    min-width: 0;
    padding: 0 10px;
    color: rgba(255, 255, 255, .78);
    font-size: 10.75px;
    font-weight: 800;
    line-height: 1.12;
    text-align: center;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    white-space: normal;
    overflow: hidden;
    overflow-wrap: anywhere;
  }

  .mobile-contact-bar[data-assurance-tone="dark"]::before {
    color: rgba(23, 32, 38, .76);
  }

  .mobile-contact-bar[data-assurance] a {
    min-height: 42px !important;
    padding-inline: 10px !important;
    font-size: 13px !important;
    line-height: 1.1 !important;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  @media (max-width: 380px) {
    .mobile-contact-bar[data-assurance] {
      width: calc(100vw - 16px) !important;
      max-width: calc(100vw - 16px);
    }
  }
}

.launch-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.launch-loader::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .72;
  background:
    linear-gradient(90deg, rgba(23,32,38,.055) 1px, transparent 1px),
    linear-gradient(0deg, rgba(23,32,38,.055) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at center, black, transparent 72%);
}

.launch-card {
  position: relative;
  width: min(520px, 100%);
  min-height: 430px;
  border-radius: 8px;
  border: 1px solid rgba(23,32,38,.14);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(20px);
  display: grid;
  place-items: center;
  padding: 34px;
  box-shadow: 0 30px 90px rgba(23,32,38,.16);
  overflow: hidden;
}

.launch-visual {
  position: relative;
  width: min(260px, 70vw);
  height: 210px;
  margin-bottom: 28px;
}

.launch-title {
  margin: 0;
  font-size: clamp(26px, 6vw, 42px);
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
}

.launch-kicker {
  margin: 0 0 10px;
  color: #65717a;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-align: center;
}

.launch-progress {
  width: min(260px, 70vw);
  height: 4px;
  margin-top: 26px;
  border-radius: 999px;
  background: rgba(23,32,38,.12);
  overflow: hidden;
}

.launch-progress span {
  display: block;
  height: 100%;
  width: 100%;
  transform-origin: left;
  transform: scaleX(0);
  background: currentColor;
  animation: launchProgress 1450ms ease forwards;
}

.launch-loader[data-theme="restaurant"] {
  background: #f7f5ef;
  color: #a84d3f;
}

.plate {
  position: absolute;
  left: 50%;
  bottom: 22px;
  width: 190px;
  height: 62px;
  border: 10px solid #526c46;
  border-radius: 50%;
  transform: translateX(-50%);
  background: #fff;
  box-shadow: inset 0 0 0 15px #f7f5ef;
}

.cloche {
  position: absolute;
  left: 50%;
  bottom: 72px;
  width: 152px;
  height: 86px;
  transform: translateX(-50%);
  border-radius: 90px 90px 12px 12px;
  background: #a84d3f;
  animation: clocheLift 1450ms cubic-bezier(.2,.8,.2,1) forwards;
}

.cloche::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -20px;
  width: 36px;
  height: 28px;
  border-radius: 50% 50% 0 0;
  background: #a84d3f;
  transform: translateX(-50%);
}

.steam {
  position: absolute;
  left: 50%;
  top: 34px;
  width: 8px;
  height: 54px;
  border-radius: 999px;
  border-left: 3px solid #b38a42;
  opacity: 0;
  animation: steamRise 1300ms ease 280ms infinite;
}

.steam.one { transform: translateX(-46px) rotate(10deg); }
.steam.two { transform: translateX(-5px) rotate(-8deg); animation-delay: 420ms; }
.steam.three { transform: translateX(38px) rotate(12deg); animation-delay: 560ms; }

.launch-loader[data-theme="construction"] {
  background: #f3f6f7;
  color: #345e8c;
}

.blueprint {
  position: absolute;
  inset: 18px 12px 18px 12px;
  border: 2px solid #345e8c;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(52,94,140,.12) 1px, transparent 1px),
    linear-gradient(0deg, rgba(52,94,140,.12) 1px, transparent 1px);
  background-size: 18px 18px;
}

.crane-mast {
  position: absolute;
  left: 62px;
  bottom: 34px;
  width: 12px;
  height: 142px;
  background: #d69a28;
}

.crane-arm {
  position: absolute;
  left: 63px;
  top: 42px;
  width: 158px;
  height: 10px;
  background: #d69a28;
  transform-origin: left center;
  animation: craneSweep 1500ms ease-in-out infinite alternate;
}

.crane-cable {
  position: absolute;
  right: 34px;
  top: 52px;
  width: 2px;
  height: 74px;
  background: #17212b;
}

.crane-load {
  position: absolute;
  right: 18px;
  top: 122px;
  width: 34px;
  height: 28px;
  background: #8a4d3b;
  animation: loadDrop 1450ms ease-in-out infinite alternate;
}

.launch-loader[data-theme="barber"] {
  background: #252220;
  color: #a65e3b;
}

.launch-loader[data-theme="barber"] .launch-card {
  background: rgba(245,241,234,.92);
}

.barber-pole {
  position: absolute;
  left: 50%;
  top: 20px;
  width: 82px;
  height: 176px;
  border: 8px solid #181614;
  border-radius: 999px;
  overflow: hidden;
  transform: translateX(-50%);
  background: repeating-linear-gradient(135deg, #fff 0 18px, #a65e3b 18px 36px, #687466 36px 54px);
  background-size: 120px 120px;
  animation: barberSpin 850ms linear infinite;
}

.scissor {
  position: absolute;
  left: 50%;
  bottom: 12px;
  width: 150px;
  height: 48px;
  transform: translateX(-50%);
}

.scissor::before,
.scissor::after {
  content: "";
  position: absolute;
  top: 18px;
  left: 28px;
  width: 104px;
  height: 5px;
  border-radius: 999px;
  background: #181614;
  transform-origin: left center;
  animation: scissorCut 900ms ease-in-out infinite alternate;
}

.scissor::after { transform: rotate(-18deg); animation-name: scissorCutAlt; }

.ring {
  position: absolute;
  top: 5px;
  width: 34px;
  height: 34px;
  border: 5px solid #181614;
  border-radius: 50%;
}

.ring.left { left: 0; }
.ring.right { left: 40px; }

.launch-loader[data-theme="dental"] {
  background: #f4f8f7;
  color: #25706c;
}

.tooth {
  position: absolute;
  left: 50%;
  top: 30px;
  width: 124px;
  height: 152px;
  transform: translateX(-50%);
  background: #fff;
  border: 8px solid #25706c;
  border-radius: 52px 52px 42px 42px;
  animation: toothPulse 1100ms ease-in-out infinite alternate;
}

.tooth::before,
.tooth::after {
  content: "";
  position: absolute;
  bottom: -32px;
  width: 44px;
  height: 62px;
  background: #fff;
  border: 8px solid #25706c;
  border-top: 0;
}

.tooth::before { left: 10px; border-radius: 0 0 28px 28px; }
.tooth::after { right: 10px; border-radius: 0 0 28px 28px; }

.spark {
  position: absolute;
  width: 18px;
  height: 18px;
  transform: rotate(45deg) scale(.2);
  background: #cc6b5a;
  opacity: 0;
  animation: sparkle 1200ms ease-in-out infinite;
}

.spark.one { left: 34px; top: 46px; }
.spark.two { right: 42px; top: 88px; animation-delay: 260ms; }
.spark.three { left: 84px; bottom: 20px; animation-delay: 520ms; }

.launch-loader[data-theme="portfolio"] {
  background: #f6f8f7;
  color: #172026;
}

.showcase-stack {
  position: absolute;
  inset: 24px 18px;
}

.showcase-tile {
  position: absolute;
  width: 132px;
  height: 92px;
  border-radius: 8px;
  border: 1px solid rgba(23,32,38,.14);
  background: #fff;
  box-shadow: 0 18px 45px rgba(23,32,38,.14);
  animation: tileFloat 1500ms ease-in-out infinite alternate;
}

.showcase-tile:nth-child(1) { left: 6px; top: 16px; background: #f7f5ef; }
.showcase-tile:nth-child(2) { right: 4px; top: 48px; background: #f3f6f7; animation-delay: 160ms; }
.showcase-tile:nth-child(3) { left: 62px; bottom: 22px; background: #f5f1ea; animation-delay: 320ms; }

@keyframes launchProgress {
  to { transform: scaleX(1); }
}

@keyframes clocheLift {
  0%, 45% { transform: translateX(-50%) translateY(0); }
  100% { transform: translateX(-50%) translateY(-22px); }
}

@keyframes steamRise {
  0% { opacity: 0; transform: translateY(18px) scaleY(.5); }
  45% { opacity: .85; }
  100% { opacity: 0; transform: translateY(-28px) scaleY(1); }
}

@keyframes craneSweep {
  to { transform: rotate(-5deg); }
}

@keyframes loadDrop {
  to { transform: translateY(14px); }
}

@keyframes barberSpin {
  to { background-position: 0 120px; }
}

@keyframes scissorCut {
  to { transform: rotate(18deg); }
}

@keyframes scissorCutAlt {
  to { transform: rotate(-32deg); }
}

@keyframes toothPulse {
  to { transform: translateX(-50%) scale(1.04); }
}

@keyframes sparkle {
  0%, 100% { opacity: 0; transform: rotate(45deg) scale(.2); }
  45%, 70% { opacity: 1; transform: rotate(45deg) scale(1); }
}

@keyframes tileFloat {
  to { transform: translateY(-12px); }
}

@media (prefers-reduced-motion: reduce) {
  .launch-loader,
  .launch-progress span,
  .cloche,
  .steam,
  .crane-arm,
  .crane-load,
  .barber-pole,
  .scissor::before,
  .scissor::after,
  .tooth,
  .spark,
  .showcase-tile {
    animation: none;
    transition: none;
  }
}

@media (max-width: 560px) {
  .launch-card {
    min-height: 380px;
    padding: 24px;
  }

  .launch-visual {
    height: 190px;
  }

  .site-demo-disclosure {
    max-width: calc(100% - 28px);
    margin-bottom: 78px;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .site-demo-copy {
    flex-direction: column;
    gap: 6px;
  }

  .site-demo-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .site-demo-points {
    grid-template-columns: 1fr;
  }

  .site-demo-points span {
    min-height: auto;
  }
}
