/* LocalShouts — public onboarding.
   colors_and_type.css is loaded via a separate <link> in index.html so the
   browser can fetch it in parallel with this file instead of waiting for the
   @import to be discovered (chained imports were the dominant LCP cost). */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
button { font-family: inherit; cursor: pointer; }
a { color: inherit; }

/* ── Topbar ── */
.lp-top {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.82);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(30,27,75,.06);
}
.lp-top-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 14px 20px;
  display: flex; align-items: center; gap: 18px;
}
.lp-top img.logo { height: 28px; }
.lp-top-nav { display: flex; gap: 4px; margin-left: auto; align-items: center; }
.lp-top-nav a {
  padding: 8px 12px; border-radius: 8px;
  font: 500 14px/1 var(--font-sans); color: var(--fg-2);
  text-decoration: none; transition: background var(--t-fast);
}
.lp-top-nav a:hover { background: var(--bg-alt); color: var(--fg); }
.lp-top-nav .cta {
  background: var(--fg); color: var(--fg-inv); padding: 9px 14px;
}
.lp-top-nav .cta:hover { background: var(--brand-navy-700); color: var(--fg-inv); }
.lp-top-nav .desktop-only { display: inline-flex; }
@media (max-width: 720px){
  .lp-top-nav .desktop-only { display: none; }
  .lp-top-inner { padding: 12px 16px; gap: 10px; }
}

/* ── Sections ── */
.lp-section {
  padding: 80px 20px;
  position: relative;
}
@media (max-width: 720px){
  .lp-section { padding: 56px 16px; }
}
.lp-wrap { max-width: 1180px; margin: 0 auto; }
.lp-narrow { max-width: 880px; margin: 0 auto; }

/* ── Hero ── */
.hero {
  position: relative;
  padding: 80px 20px 48px;
  overflow: hidden;
}
.hero::before {
  content: ''; position: absolute; inset: -10% -10% auto -10%; height: 70%;
  background:
    radial-gradient(60% 60% at 25% 30%, rgba(124,58,237,.18), transparent 70%),
    radial-gradient(50% 50% at 80% 10%, rgba(167,139,250,.20), transparent 70%),
    radial-gradient(60% 60% at 60% 80%, rgba(253,224,71,.10), transparent 70%);
  pointer-events: none; z-index: 0;
}
.hero-inner { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
@media (max-width: 960px){ .hero-inner { grid-template-columns: 1fr; gap: 36px; } }
@media (max-width: 720px){ .hero { padding: 48px 16px 32px; } }

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px;
  background: #fff; border: 1px solid var(--brand-purple-200);
  border-radius: 999px; font: 600 12px/1 var(--font-sans);
  color: var(--brand-purple-700);
  box-shadow: var(--shadow-purple-soft);
}
.hero-eyebrow .dot {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--brand-purple); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.hero h1 {
  font: 800 58px/1.02 var(--font-sans);
  letter-spacing: -.025em; color: var(--brand-navy);
  margin: 22px 0 18px;
}
.hero h1 .grad {
  background: linear-gradient(120deg, var(--brand-purple) 0%, var(--brand-lavender) 60%, var(--brand-purple) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: shimmer 6s linear infinite;
}
@keyframes shimmer { 0%{background-position:0% 50%;} 100%{background-position:200% 50%;} }
@media (max-width: 720px){ .hero h1 { font-size: 38px; } }

.hero p.lead {
  font: 400 18px/1.55 var(--font-sans); color: var(--fg-2);
  max-width: 560px; margin: 0 0 28px;
}
@media (max-width: 720px){ .hero p.lead { font-size: 16px; } }

.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.hero-trust { display: flex; align-items: center; gap: 12px; margin-top: 26px; color: var(--fg-3); font: 500 13px/1.4 var(--font-sans); flex-wrap: wrap; }
.hero-stack {
  display: flex; align-items: center;
}
.hero-stack span {
  width: 28px; height: 28px; border-radius: 50%; background: var(--brand-purple-100);
  border: 2px solid #fff; margin-left: -8px; display: inline-flex;
  align-items: center; justify-content: center;
  font: 700 11px/1 var(--font-sans); color: var(--brand-purple-700);
}
.hero-stack span:first-child { margin-left: 0; }

/* ── Buttons ── */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 18px;
  border-radius: 12px; border: 1px solid transparent; font: 600 14.5px/1 var(--font-sans);
  transition: transform var(--t-fast) var(--ease-out), background var(--t-fast), box-shadow var(--t-fast);
  white-space: nowrap;
}
.btn-primary { background: var(--brand-purple); color: #fff; box-shadow: var(--shadow-purple); }
.btn-primary:hover { background: var(--brand-purple-600); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(124,58,237,.30); }
.btn-dark { background: var(--brand-navy); color: #fff; }
.btn-dark:hover { background: var(--brand-navy-700); }
.btn-outline { background: #fff; border-color: var(--line-strong); color: var(--fg); }
.btn-outline:hover { border-color: var(--brand-purple-200); color: var(--brand-purple-700); }
.btn-ghost { background: transparent; color: var(--fg-2); }
.btn-lg { padding: 14px 22px; font-size: 15px; border-radius: 14px; }
.btn-sm { padding: 8px 12px; font-size: 13px; border-radius: 8px; }
.btn:disabled { opacity: .55; cursor: not-allowed; transform: none !important; }

/* ── Hero preview card ── */
.hero-preview {
  position: relative; border-radius: 24px;
  background: linear-gradient(160deg, #fff 0%, #fbfaf7 100%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-xl);
  padding: 18px;
  overflow: hidden;
}
.hero-preview-tab {
  display: flex; gap: 6px; align-items: center; margin-bottom: 14px;
}
.hero-preview-tab span { width: 10px; height: 10px; border-radius: 50%; background: #f1f1ee; }
.hero-preview-tab .url {
  margin-left: 12px; flex: 1; height: 28px; border-radius: 8px; background: #f5f4f0;
  padding: 0 12px; display: flex; align-items: center;
  font: 500 12px/1 var(--font-mono); color: var(--fg-3);
}

/* ── Live preview section ── */
.live-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 32px; align-items: stretch; }
@media (max-width: 960px){ .live-grid { grid-template-columns: 1fr; gap: 24px; } }

.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field label { font: 600 12px/1 var(--font-sans); color: var(--fg-2); }
.field input, .field select, .field textarea {
  padding: 12px 14px; border: 1px solid var(--line-strong); border-radius: 10px;
  font: 500 14px/1.4 var(--font-sans); color: var(--fg); background: #fff;
  outline: none; transition: border-color var(--t-fast), box-shadow var(--t-fast);
  font-family: inherit;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--brand-purple); box-shadow: var(--ring-focus);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px){ .field-row { grid-template-columns: 1fr; } }
.chip-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.chip {
  padding: 6px 10px; border-radius: 999px; background: #fff;
  border: 1px solid var(--line-strong); font: 500 12px/1 var(--font-sans);
  color: var(--fg-2); cursor: pointer; transition: all var(--t-fast);
}
.chip.on { background: var(--brand-purple); color: #fff; border-color: var(--brand-purple); }
.chip:hover:not(.on) { border-color: var(--brand-purple-200); color: var(--brand-purple-700); }

.kw-input { display: flex; gap: 8px; align-items: center; }
.kw-input input { flex: 1; }

/* preview tab strip */
.tabs { display: inline-flex; padding: 4px; background: var(--bg-alt); border-radius: 999px; gap: 2px; }
.tabs button {
  padding: 8px 14px; border-radius: 999px; border: none; background: transparent;
  font: 600 13px/1 var(--font-sans); color: var(--fg-3); transition: all var(--t-fast);
}
.tabs button.on { background: #fff; color: var(--brand-purple); box-shadow: var(--shadow-sm); }
.tabs button:hover:not(.on) { color: var(--fg); }

/* ── Phone bezel ── */
.phone {
  width: 320px; max-width: 100%; aspect-ratio: 320/640;
  margin: 0 auto;
  background: #1e1b4b;
  border-radius: 36px; padding: 10px;
  box-shadow: 0 30px 60px -20px rgba(30,27,75,.35), 0 12px 24px rgba(30,27,75,.10);
}
.phone-screen {
  width: 100%; height: 100%; border-radius: 28px; overflow: hidden;
  background: #fff; position: relative;
}

/* ── Cards ── */
.card { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 22px; }
@media (max-width: 480px){ .card { padding: 18px; border-radius: 16px; } }

/* ── Free generator ── */
.gen-shell {
  background: linear-gradient(180deg, #fff, #faf8ff);
  border: 1px solid var(--brand-purple-200);
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 30px 80px -30px rgba(124,58,237,.18);
}
@media (max-width: 720px){ .gen-shell { padding: 20px; border-radius: 20px; } }
.gen-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 24px; }
@media (max-width: 880px){ .gen-grid { grid-template-columns: 1fr; } }

.review-out {
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  padding: 18px; min-height: 200px; display: flex; flex-direction: column; gap: 12px;
  position: relative;
}
.review-out .out-text {
  font: 400 15px/1.65 var(--font-sans); color: var(--fg);
  white-space: pre-wrap;
}
.empty {
  display: flex; flex-direction: column; gap: 8px; align-items: center; justify-content: center;
  flex: 1; color: var(--fg-3); text-align: center; padding: 24px;
}

/* ── Steps strip ── */
.steps {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
@media (max-width: 880px){ .steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .steps { grid-template-columns: 1fr; } }
.step {
  background: #fff; border: 1px solid var(--line); border-radius: 16px;
  padding: 22px; display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.step:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.step .n {
  width: 32px; height: 32px; border-radius: 10px; background: var(--brand-purple-100);
  color: var(--brand-purple-700); display: flex; align-items: center; justify-content: center;
  font: 800 14px/1 var(--font-sans);
}
.step h4 { margin: 0; font: 700 16px/1.2 var(--font-sans); color: var(--fg); }
.step p { margin: 0; font: 400 13.5px/1.5 var(--font-sans); color: var(--fg-3); }

/* ── Footer band ── */
.cta-band {
  background: linear-gradient(135deg, var(--brand-navy) 0%, var(--brand-purple) 100%);
  color: #fff; padding: 80px 20px;
  text-align: center; position: relative; overflow: hidden;
}
.cta-band::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(60% 60% at 30% 30%, rgba(255,255,255,.10), transparent 70%);
}
.cta-band-inner { max-width: 720px; margin: 0 auto; position: relative; }
.cta-band h2 { font: 800 40px/1.1 var(--font-sans); letter-spacing: -.02em; margin: 0 0 14px; }
@media (max-width: 720px){ .cta-band h2 { font-size: 30px; } .cta-band { padding: 56px 16px; } }
.cta-band p { font: 400 17px/1.5 var(--font-sans); color: rgba(255,255,255,.8); margin: 0 0 24px; }

/* ── Section heading ── */
.section-h {
  text-align: center; max-width: 720px; margin: 0 auto 44px;
}
.section-h .eyebrow {
  display: inline-block; padding: 4px 10px; border-radius: 999px;
  background: var(--brand-purple-100); color: var(--brand-purple-700);
  font: 700 11px/1 var(--font-sans); letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 14px;
}
.section-h h2 { font: 800 38px/1.1 var(--font-sans); letter-spacing: -.02em; margin: 0 0 14px; color: var(--brand-navy); }
.section-h p { font: 400 16.5px/1.55 var(--font-sans); color: var(--fg-2); margin: 0; }
@media (max-width: 720px){ .section-h h2 { font-size: 28px; } .section-h { margin-bottom: 30px; } }

/* ── Modal ── */
.modal-bg {
  position: fixed; inset: 0; background: rgba(30,27,75,.5);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; z-index: 100;
  animation: fadeIn 200ms var(--ease-out);
}
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
.modal {
  background: #fff; border-radius: 22px; max-width: 520px; width: 100%;
  max-height: 90vh; overflow: hidden; display: flex; flex-direction: column;
  box-shadow: var(--shadow-xl);
  animation: pop 240ms var(--ease-out);
}
@keyframes pop { from{transform:translateY(20px) scale(.95); opacity:0;} to{transform:none; opacity:1;} }
@media (max-width: 540px){
  .modal-bg { align-items: flex-end; padding: 0; }
  .modal { border-radius: 22px 22px 0 0; max-height: 92vh; }
}

/* ── Pulse loader for AI ── */
.ai-typing { display: inline-flex; gap: 4px; align-items: center; }
.ai-typing span {
  width: 6px; height: 6px; border-radius: 50%; background: var(--brand-purple);
  animation: blink 1.2s infinite ease-in-out both;
}
.ai-typing span:nth-child(2){ animation-delay: .15s; }
.ai-typing span:nth-child(3){ animation-delay: .3s; }
@keyframes blink { 0%,80%,100%{opacity:.2; transform:scale(.85);} 40%{opacity:1; transform:scale(1);} }

.fade-in { animation: fadeUp 320ms var(--ease-out) both; }
@keyframes fadeUp { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }

/* utility */
.row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.spread { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.muted { color: var(--fg-3); }
.center { text-align: center; }
