/* BuiltByTom landing — aligned with builtbytom.uk: mesh gradient, soft glow, animations */
._index_1g8wc_2 {
  --bbt-ink-900: #0f172a;
  --bbt-ink-700: #334155;
  --bbt-ink-500: #64748b;
  --bbt-ink-200: #e2e8f0;
  --bbt-primary-400: #38bdf8;
  --bbt-primary-500: #0ea5e9;
  --bbt-primary-600: #0284c7;
  --bbt-primary-50: #f0f9ff;
  --bbt-tom: #BBE2F8;
  /* Mesh gradient (light) - matches builtbytom */
  --mesh-light: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 40%, #f8fafc 100%);
  /* Soft glow - radial ellipse at top */
  --soft-glow-light: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(14, 165, 233, 0.12), transparent);
  --soft-glow-dark: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(14, 165, 233, 0.08), transparent);
  height: 100dvh;
  height: 100vh;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: center;
  padding: 0;
  background: var(--mesh-light);
  font-family: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  box-sizing: border-box;
  overflow-y: auto;
  position: relative;
}

._index_1g8wc_2::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--soft-glow-light);
  opacity: 0.85;
  pointer-events: none;
}

._index_1g8wc_2::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, currentColor 1px, transparent 0);
  background-size: 48px 48px;
  opacity: 0.04;
  pointer-events: none;
}

[data-theme="dark"] ._index_1g8wc_2 {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #334155 100%);
}

[data-theme="dark"] ._index_1g8wc_2::before {
  background: var(--soft-glow-dark);
  opacity: 0.8;
}

[data-theme="dark"] ._index_1g8wc_2::after {
  opacity: 0.03;
}

/* Theme toggle — landing page only (not in Shopify admin embed) */
._themeToggleWrap_1g8wc_65 {
  position: fixed;
  bottom: 6rem;
  right: 1.5rem;
  z-index: 40;
}

._themeToggleWrap_1g8wc_65 .theme-toggle {
  width: 3.5rem;
  height: 3.5rem;
  padding: 1rem;
  border-radius: 9999px;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease, background 0.2s;
}

._themeToggleWrap_1g8wc_65 .theme-toggle:hover {
  transform: scale(1.1);
}

._themeToggleWrap_1g8wc_65 .theme-toggle:active {
  transform: scale(0.95);
}

._themeToggleWrap_1g8wc_65 .theme-toggle svg {
  width: 1.5rem;
  height: 1.5rem;
}

[data-theme="dark"] ._themeToggleWrap_1g8wc_65 .theme-toggle {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
}

/* Header — matches builtbytom Layout: border-b, bg/backdrop, h-20 md:h-24, image + BrandLogo */
._header_1g8wc_99 {
  position: relative;
  z-index: 2;
  width: 100%;
  flex-shrink: 0;
  border-bottom: 1px solid var(--bbt-ink-200);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

[data-theme="dark"] ._header_1g8wc_99 {
  border-bottom-color: var(--bbt-ink-800, #1e293b);
  background: rgba(2, 6, 23, 0.95);
}

/* container-content + flex justify-between items-center h-20 md:h-24 */
._headerInner_1g8wc_116 {
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 5rem;
}

@media (min-width: 640px) {
  ._headerInner_1g8wc_116 {
    padding: 0 1.5rem;
  }
}

@media (min-width: 768px) {
  ._headerInner_1g8wc_116 {
    min-height: 6rem;
  }
}

@media (min-width: 1024px) {
  ._headerInner_1g8wc_116 {
    padding: 0 2rem;
  }
}

@media (min-width: 1280px) {
  ._headerInner_1g8wc_116 {
    padding: 0 3rem;
  }
}

/* Builtbytom: flex items-center space-x-3 group */
._headerLogoLink_1g8wc_152 {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  color: inherit;
}

._headerLogoLink_1g8wc_152:hover {
  color: inherit;
}

/* Match builtbytom: w-10 h-10 md:w-11 md:h-11 rounded-lg; use contain so image is never clipped */
._headerLogoImg_1g8wc_165 {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: 0.5rem;
  object-fit: contain;
  object-position: center;
  transition: transform 0.3s ease;
}

._headerLogoLink_1g8wc_152:hover ._headerLogoImg_1g8wc_165 {
  transform: scale(1.05);
}

@media (min-width: 768px) {
  ._headerLogoImg_1g8wc_165 {
    width: 2.75rem;
    height: 2.75rem;
  }
}

/* font-logo font-bold text-xl */
._headerLogoText_1g8wc_187 {
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
}

/* text-ink-900 dark:text-[#fff] */
._logoBuiltby_1g8wc_194 {
  color: #0f172a;
}

[data-theme="dark"] ._logoBuiltby_1g8wc_194 {
  color: #fff;
}

/* text-[#BBE2F8] */
._logoTom_1g8wc_203 {
  color: #BBE2F8;
}

/* Two-column hero — same container as builtbytom (max-w-7xl = 80rem, px-4 sm:px-6 lg:px-8 xl:px-12) */
._heroWrap_1g8wc_208 {
  position: relative;
  z-index: 1;
  flex: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 2rem 1rem;
  display: grid;
  gap: 2rem;
  align-items: center;
}

@media (min-width: 640px) {
  ._heroWrap_1g8wc_208 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

@media (min-width: 1024px) {
  ._heroWrap_1g8wc_208 {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    padding: 3rem 2rem;
  }
}

@media (min-width: 1280px) {
  ._heroWrap_1g8wc_208 {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

._heroLeft_1g8wc_243 {
  order: 2;
  text-align: left;
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  ._heroLeft_1g8wc_243 {
    order: 1;
  }
}

._heroRight_1g8wc_256 {
  order: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (min-width: 1024px) {
  ._heroRight_1g8wc_256 {
    order: 2;
    justify-content: flex-end;
    align-items: center;
  }
}

._formCard_1g8wc_271 {
  width: 100%;
  max-width: 28rem;
  padding: 2rem;
  border-radius: 1rem;
  border: 1px solid var(--bbt-ink-200);
  background: rgba(255, 255, 255, 0.6);
  text-align: left;
}

[data-theme="dark"] ._formCard_1g8wc_271 {
  border-color: var(--bbt-ink-700, #334155);
  background: rgba(15, 23, 42, 0.5);
}

._formTitle_1g8wc_286 {
  margin: 0 0 0.75rem 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--bbt-ink-900);
}

[data-theme="dark"] ._formTitle_1g8wc_286 {
  color: #f1f5f9;
}

._formSteps_1g8wc_297 {
  margin: 0 0 1.25rem 0;
  font-size: 0.95rem;
  color: var(--bbt-ink-700);
  line-height: 1.65;
}

[data-theme="dark"] ._formSteps_1g8wc_297 {
  color: #94a3b8;
}

._formStep_1g8wc_297 {
  font-weight: 600;
  color: var(--bbt-primary-600);
}

[data-theme="dark"] ._formStep_1g8wc_297 {
  color: var(--bbt-primary-400);
}

._heroRight_1g8wc_256 ._formCard_1g8wc_271 {
  margin-left: 0;
}

@media (min-width: 1024px) {
  ._heroRight_1g8wc_256 ._formCard_1g8wc_271 {
    margin-left: auto;
  }
}

/* Reveal animation — matches builtbytom fade-up */
._reveal_1g8wc_328 {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

._reveal_1g8wc_328._revealed_1g8wc_334 {
  opacity: 1;
  transform: translateY(0);
}

._revealDelay1_1g8wc_339 { transition-delay: 80ms; }
._revealDelay2_1g8wc_340 { transition-delay: 160ms; }
._revealDelay3_1g8wc_341 { transition-delay: 240ms; }
._revealDelay4_1g8wc_342 { transition-delay: 320ms; }
._revealDelay5_1g8wc_343 { transition-delay: 400ms; }
._revealDelay6_1g8wc_344 { transition-delay: 480ms; }
._revealDelay7_1g8wc_345 { transition-delay: 560ms; }

._logo_1g8wc_194 {
  font-weight: 700;
  font-size: 2.25rem;
  letter-spacing: -0.02em;
  margin: 0;
}

@media (min-width: 36rem) {
  ._logo_1g8wc_194 {
    font-size: 2.5rem;
  }
}

._logoBuiltby_1g8wc_194 {
  color: var(--bbt-ink-900);
}

[data-theme="dark"] ._logoBuiltby_1g8wc_194 {
  color: #f1f5f9;
}

._logoTom_1g8wc_203 {
  color: var(--bbt-tom);
}

/* Hero heading — matches builtbytom "Hi, I'm Tom." (font-display text-5xl → xl:text-8xl, bold, tracking-tight, leading-[0.95]) */
._heading_1g8wc_373 {
  margin: 0;
  font-size: 3rem;
  font-weight: 700;
  color: var(--bbt-ink-900);
  line-height: 0.95;
  letter-spacing: -0.025em;
}

._heading_1g8wc_373 ._logoBuiltby_1g8wc_194 {
  color: #fff;
}

._heading_1g8wc_373 ._logoTom_1g8wc_203 {
  color: var(--bbt-tom);
}

@media (min-width: 640px) {
  ._heading_1g8wc_373 {
    font-size: 3.75rem;
  }
}

@media (min-width: 1024px) {
  ._heading_1g8wc_373 {
    font-size: 4.5rem;
  }
}

@media (min-width: 1280px) {
  ._heading_1g8wc_373 {
    font-size: 6rem;
  }
}

[data-theme="dark"] ._heading_1g8wc_373 {
  color: #f1f5f9;
}

._text_1g8wc_412 {
  margin: 0;
  font-size: 1.15rem;
  color: var(--bbt-ink-700);
  line-height: 1.65;
}

[data-theme="dark"] ._text_1g8wc_412 {
  color: #94a3b8;
}

._link_1g8wc_423 {
  color: var(--bbt-primary-600);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s, color 0.2s;
}

._link_1g8wc_423:hover {
  border-bottom-color: var(--bbt-primary-500);
  color: var(--bbt-primary-500);
}

[data-theme="dark"] ._link_1g8wc_423 {
  color: var(--bbt-primary-400, #38bdf8);
}

[data-theme="dark"] ._link_1g8wc_423:hover {
  border-bottom-color: var(--bbt-primary-400);
  color: var(--bbt-primary-300, #7dd3fc);
}

._form_1g8wc_271 {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1rem;
  margin: 0;
  width: 100%;
  text-align: left;
}

._label_1g8wc_455 {
  display: grid;
  gap: 0.35rem;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--bbt-ink-900);
}

[data-theme="dark"] ._label_1g8wc_455 {
  color: #e2e8f0;
}

._label_1g8wc_455 span:last-child {
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--bbt-ink-500);
}

[data-theme="dark"] ._label_1g8wc_455 span:last-child {
  color: #64748b;
}

._input_1g8wc_477 {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid var(--bbt-ink-200);
  border-radius: 0.5rem;
  font-size: 1rem;
  background: #fff;
  color: var(--bbt-ink-900);
  box-sizing: border-box;
  transition: border-color 0.2s, box-shadow 0.2s;
}

[data-theme="dark"] ._input_1g8wc_477 {
  background: var(--bbt-ink-900, #0f172a);
  border-color: var(--bbt-ink-700, #334155);
  color: #f1f5f9;
}

._input_1g8wc_477:focus {
  outline: none;
  border-color: var(--bbt-primary-500);
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.2);
}

._input_1g8wc_477._inputError_1g8wc_501 {
  border-color: #dc2626;
}

._input_1g8wc_477._inputError_1g8wc_501:focus {
  border-color: #dc2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.2);
}

[data-theme="dark"] ._input_1g8wc_477._inputError_1g8wc_501 {
  border-color: #f87171;
}

[data-theme="dark"] ._input_1g8wc_477._inputError_1g8wc_501:focus {
  box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.25);
}

._input_1g8wc_477::placeholder {
  color: var(--bbt-ink-500);
}

[data-theme="dark"] ._input_1g8wc_477::placeholder {
  color: #64748b;
}

._inputHint_1g8wc_526 {
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--bbt-ink-500);
}

[data-theme="dark"] ._inputHint_1g8wc_526 {
  color: #64748b;
}

._fieldError_1g8wc_536 {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #dc2626;
}

[data-theme="dark"] ._fieldError_1g8wc_536 {
  color: #f87171;
}

/* Button — builtbytom btn-primary style (rounded-lg, transition 300ms) */
._button_1g8wc_548 {
  width: 100%;
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  background: var(--bbt-primary-500);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background 0.3s, transform 0.2s;
  box-sizing: border-box;
}

._button_1g8wc_548:hover {
  background: var(--bbt-primary-400, #38bdf8);
}

._button_1g8wc_548:active {
  transform: scale(0.98);
}

._button_1g8wc_548:disabled {
  cursor: not-allowed;
  opacity: 0.9;
}

[data-theme="dark"] ._button_1g8wc_548:hover {
  background: var(--bbt-primary-400);
}

._buttonLoading_1g8wc_579 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

._spinner_1g8wc_586 {
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: _spin_1g8wc_586 0.7s linear infinite;
}

@keyframes _spin_1g8wc_586 {
  to {
    transform: rotate(360deg);
  }
}

/* Full-screen loading overlay — builtbytom-style (logo + progress bar) */
._loadingOverlay_1g8wc_602 {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

[data-theme="dark"] ._loadingOverlay_1g8wc_602 {
  background: rgba(15, 23, 42, 0.97);
}

._loadingContent_1g8wc_618 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  max-width: 18rem;
  text-align: center;
}

._loadingLogo_1g8wc_627 {
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  font-weight: 700;
  font-size: 2rem;
}

._loadingLogo_1g8wc_627 ._logoBuiltby_1g8wc_194 {
  color: var(--bbt-ink-900);
}

[data-theme="dark"] ._loadingLogo_1g8wc_627 ._logoBuiltby_1g8wc_194 {
  color: #fff;
}

._loadingLogo_1g8wc_627 ._logoTom_1g8wc_203 {
  color: var(--bbt-tom);
}

._loadingText_1g8wc_645 {
  margin: 0;
  font-size: 1rem;
  color: var(--bbt-ink-700);
}

[data-theme="dark"] ._loadingText_1g8wc_645 {
  color: #94a3b8;
}

._loadingBarWrap_1g8wc_655 {
  width: 12rem;
  height: 4px;
  background: var(--bbt-ink-200);
  border-radius: 9999px;
  overflow: hidden;
}

[data-theme="dark"] ._loadingBarWrap_1g8wc_655 {
  background: var(--bbt-ink-700, #334155);
}

._loadingBar_1g8wc_655 {
  height: 100%;
  width: 40%;
  background: var(--bbt-primary-500);
  border-radius: 9999px;
  animation: _loadingBar_1g8wc_655 1.2s ease-in-out infinite;
}

[data-theme="dark"] ._loadingBar_1g8wc_655 {
  background: var(--bbt-primary-400);
}

@keyframes _loadingBar_1g8wc_655 {
  0% {
    transform: translateX(-100%);
  }
  50% {
    transform: translateX(150%);
  }
  100% {
    transform: translateX(-100%);
  }
}

._list_1g8wc_691 {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 0;
  display: grid;
  gap: 1rem;
  text-align: left;
}

._list_1g8wc_691 > li {
  font-size: 1.05rem;
  color: var(--bbt-ink-700);
  padding-left: 1.25rem;
  position: relative;
  line-height: 1.55;
}

[data-theme="dark"] ._list_1g8wc_691 > li {
  color: #94a3b8;
}

._list_1g8wc_691 > li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--bbt-primary-500);
  font-weight: 700;
}

._list_1g8wc_691 > li strong {
  color: var(--bbt-ink-900);
}

[data-theme="dark"] ._list_1g8wc_691 > li strong {
  color: #f1f5f9;
}

._footer_1g8wc_728 {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  padding: 1.5rem 1rem;
  margin-top: auto;
  border-top: 1px solid var(--bbt-ink-200);
  text-align: center;
  font-size: 0.875rem;
}

[data-theme="dark"] ._footer_1g8wc_728 {
  border-top-color: var(--bbt-ink-700, #334155);
}

._footerLink_1g8wc_743 {
  color: var(--bbt-primary-600);
  text-decoration: none;
  font-weight: 500;
}

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

[data-theme="dark"] ._footerLink_1g8wc_743 {
  color: var(--bbt-primary-400);
}

._footerSep_1g8wc_757 {
  margin: 0 0.5rem;
  color: var(--bbt-ink-500);
}

