/* ============================================================
   OurLoveSong - design system (cloned from PrayerSong teardown)
   To re-skin: change --brand, --bg tokens + the brand name in HTML.
   ============================================================ */
:root{
  --bg:#FBF1E2;            /* cream landing bg */
  --bg-funnel:#FCF8E6;     /* pale yellow funnel bg */
  --brand:#B85419;         /* rust / burnt sienna CTA */
  --brand-dark:#9C4413;
  --ink:#1B2236;           /* near-black navy headings/body */
  --muted:#5A6473;         /* slate sub-text */
  --green:#2E9E6B;         /* guarantee checks */
  --card:#ffffff;
  --line:#e7ddc9;
  --shadow:0 10px 30px rgba(27,34,54,.08);
  --radius:18px;
  --radius-sm:11px;
  --font-display:"Playfair Display",Georgia,"Times New Roman",serif;
  --font-body:"Poppins","Segoe UI",system-ui,-apple-system,sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.center{text-align:center}

/* ---------- typography ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:800;line-height:1.1;color:var(--ink)}
h1{font-size:clamp(2.1rem,5vw,3.5rem)}
h2{font-size:clamp(1.8rem,4vw,2.8rem)}
h3{font-size:1.15rem}
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;font-weight:600;color:var(--muted)}
.sub{color:var(--muted);font-size:1.05rem;max-width:620px;margin:14px auto 0}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--brand);color:#fff;font-family:var(--font-body);font-weight:600;font-size:1.02rem;border:none;border-radius:var(--radius-sm);padding:15px 26px;cursor:pointer;transition:.15s transform,.15s background;box-shadow:0 8px 18px rgba(184,84,25,.28)}
.btn:hover{background:var(--brand-dark);transform:translateY(-1px)}
.btn-lg{padding:18px 34px;font-size:1.12rem}
.btn-block{width:100%}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{background:#faf6ec;color:var(--ink)}

/* ---------- top urgency bar ---------- */
.topbar{background:var(--brand);color:#fff;text-align:center;font-size:.92rem;font-weight:500;padding:9px 14px}
.topbar a{font-weight:700;text-decoration:underline;margin-left:6px}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:var(--bg);border-bottom:1px solid var(--line)}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-family:var(--font-display);font-size:1.5rem;font-weight:800}
.logo .script{font-style:italic;font-weight:700}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-size:.95rem;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
@media(max-width:720px){.nav-links a:not(.btn){display:none}}

/* ---------- hero ---------- */
.hero{padding:46px 0 30px;text-align:center}
.hero h1{margin:14px auto 0;max-width:760px}
.hero .sub{font-size:1.18rem}
.hero-cta{margin-top:26px}
.hero-micro{margin-top:12px;color:var(--muted);font-size:.9rem}
.stars{color:#E8A317;letter-spacing:2px;font-size:1.1rem}
.proof{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;flex-wrap:wrap}
.avatars{display:flex}
.avatars span{width:34px;height:34px;border-radius:50%;border:2px solid var(--bg);margin-left:-10px;background:linear-gradient(135deg,#d9b38c,#b8804f);display:inline-block}
.proof small{color:var(--muted);font-weight:600}

/* ---------- vinyl player ---------- */
.player{background:var(--card);border-radius:24px;box-shadow:var(--shadow);max-width:380px;margin:34px auto 0;padding:30px 28px 26px}
.record{position:relative;width:230px;height:230px;margin:0 auto;border-radius:50%;
  background:repeating-radial-gradient(circle at center,#111 0,#111 3px,#1c1c1c 4px,#111 6px);
  box-shadow:0 0 0 6px #0a0a0a,0 14px 30px rgba(0,0,0,.35)}
.record.spin{animation:spin 4s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.record .label{position:absolute;inset:0;margin:auto;width:92px;height:92px;border-radius:50%;background:var(--bg);border:4px solid #cdd9ef;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-weight:700;font-size:.9rem;text-align:center;color:var(--ink)}
.player-bar{display:flex;align-items:center;gap:10px;margin-top:22px;color:var(--muted);font-size:.82rem;font-weight:600}
.track{flex:1;height:5px;border-radius:6px;background:#e9e2d2;position:relative}
.track i{position:absolute;left:0;top:50%;transform:translateY(-50%);width:13px;height:13px;border-radius:50%;background:var(--brand)}
.player-controls{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:18px}
.play{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,#E8922F,#d2731a);color:#fff;font-size:1.5rem;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(210,115,26,.4)}
.skip{background:none;border:none;color:#9aa3b2;font-size:1.2rem;cursor:pointer}

/* ---------- trust bar ---------- */
.trust{padding:26px 0 8px;text-align:center}
.trust-logos{display:flex;gap:30px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:12px;opacity:.55;font-weight:800;font-size:1.1rem;filter:grayscale(1)}

/* ---------- section base ---------- */
section{padding:56px 0}
.section-dark{background:#16110d;color:#fff}
.section-dark h2{color:#fff}

/* ---------- how it works ---------- */
.steps{max-width:560px;margin:34px auto 0;display:flex;flex-direction:column;gap:22px}
.step{display:flex;gap:16px;align-items:flex-start}
.step .num{flex:none;width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-body)}
.step h3{font-family:var(--font-body);font-size:1.12rem;font-weight:600;margin-bottom:2px}
.step p{color:rgba(255,255,255,.7);font-size:.95rem}
.section-dark .step h3{color:#fff}

/* ---------- use-case grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px}
.tile{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;padding:16px;color:#fff;font-weight:600;font-size:1.05rem;background:linear-gradient(160deg,#6b5440,#2c2118)}
.tile:nth-child(3n+1){background:linear-gradient(160deg,#7a5a48,#332014)}
.tile:nth-child(3n+2){background:linear-gradient(160deg,#5e5142,#221d16)}
.tile span{position:relative;z-index:2;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent,rgba(0,0,0,.45))}
@media(max-width:640px){.grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- what you get ---------- */
.feature-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:820px;margin:36px auto 0;text-align:center}
.feature-cols .ic{width:40px;height:40px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-weight:700}
.feature-cols h3{font-family:var(--font-body);font-size:1.05rem;font-weight:700}
.feature-cols p{color:var(--muted);font-size:.92rem;margin-top:4px}
@media(max-width:640px){.feature-cols{grid-template-columns:1fr;gap:26px}}
.riskstrip{text-align:center;color:var(--muted);font-size:.95rem;margin-top:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px}

/* ---------- testimonials ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.review{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.review .stars{font-size:1rem}
.review p{font-size:.95rem;margin:10px 0 14px}
.review .who{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.9rem}
.review .who span{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#d9b38c,#b8804f)}
.badge{font-size:.72rem;color:var(--green);font-weight:700}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:30px auto 0}
.faq details{border-bottom:1px solid var(--line);padding:18px 4px}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:1.15rem;font-weight:700}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--brand)}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--muted);margin-top:12px;font-size:.96rem}

/* ---------- footer ---------- */
.footer{background:#16110d;color:rgba(255,255,255,.72);text-align:center;padding:50px 0 36px}
.footer .logo{color:#fff;margin-bottom:14px}
.footer .mission{max-width:560px;margin:0 auto 26px;font-size:.95rem}
.footer-cols{display:flex;justify-content:center;gap:54px;flex-wrap:wrap;margin-bottom:24px}
.footer-cols h4{color:#fff;font-family:var(--font-body);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px}
.footer-cols a{display:block;font-size:.9rem;margin-bottom:6px;color:rgba(255,255,255,.7)}
.footer-cols a:hover{color:#fff}
.copyright{font-size:.8rem;color:rgba(255,255,255,.4);margin-top:18px}

/* ============================================================
   FUNNEL  (create.html)
   ============================================================ */
.funnel-body{background:var(--bg-funnel)}
.progress-wrap{max-width:720px;margin:30px auto 0;padding:0 22px}
.progress-top{display:flex;justify-content:space-between;font-size:.9rem;color:var(--muted);margin-bottom:8px;font-weight:500}
.bar{height:6px;border-radius:6px;background:#e7e0c9;overflow:hidden}
.bar i{display:block;height:100%;background:var(--brand);width:20%;transition:width .35s ease}
.step-card{max-width:720px;margin:26px auto;padding:0 22px;text-align:center;min-height:54vh;display:flex;flex-direction:column;justify-content:center}
.step-card h2{margin-bottom:6px}
.step-card .q{text-align:left;margin-top:26px}
.step-card label.q-label{display:block;font-weight:600;margin-bottom:12px}
.req{color:var(--brand)}
.pills{display:flex;flex-wrap:wrap;gap:11px}
.pill{border:1px solid var(--line);background:#fff;border-radius:40px;padding:11px 20px;cursor:pointer;font-size:.96rem;transition:.12s;user-select:none}
.pill:hover{border-color:var(--brand)}
.pill.sel{background:var(--brand);color:#fff;border-color:var(--brand)}
input[type=text],input[type=email],textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:14px 16px;font-family:var(--font-body);font-size:1rem;background:#fff;color:var(--ink)}
input:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(184,84,25,.12)}
textarea{min-height:150px;resize:vertical}
.hint{color:var(--muted);font-size:.85rem;margin-top:8px}
.nav-btns{display:flex;justify-content:space-between;margin-top:30px}
.legal{text-align:center;color:var(--muted);font-size:.85rem;margin-top:22px}
.legal a{text-decoration:underline}

/* checkout */
.checkout{max-width:980px;margin:24px auto;padding:0 22px}
.checkout h2{text-align:center}
.urgency{background:#fff;border:1px solid #f3d9c4;border-radius:14px;padding:14px 18px;max-width:560px;margin:18px auto;display:flex;gap:12px;align-items:center;font-size:.92rem}
.urgency .dot{flex:none;width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center}
.urgency b{color:var(--brand)}
.co-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:22px;margin-top:14px}
@media(max-width:760px){.co-grid{grid-template-columns:1fr}}
.co-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.co-card h3{font-family:var(--font-body);font-weight:700;font-size:1.05rem;margin-bottom:14px}
.line{display:flex;justify-content:space-between;padding:7px 0;font-size:.95rem}
.line .strike{color:#9aa3b2;text-decoration:line-through;margin-right:8px}
.tag{background:#fde8d6;color:var(--brand);font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:20px;margin-left:8px}
.offer{background:#fff8f0;border:1px solid #f3d9c4;border-radius:14px;padding:16px;margin-top:16px;font-size:.9rem;color:#8a5a2a}
.guarantee{display:flex;gap:10px;align-items:flex-start;margin-top:12px;font-size:.9rem}
.guarantee .gi{color:var(--green);font-weight:800}
.mini-note{color:var(--muted);font-size:.82rem;margin-top:10px;text-align:center}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--ink);color:#fff;padding:13px 20px;border-radius:10px;font-size:.9rem;box-shadow:var(--shadow);z-index:90}

/* legal pages */
.legal-page{max-width:820px;margin:0 auto;padding:40px 22px 70px}
.legal-page h1{font-size:2.2rem;margin-bottom:18px}
.legal-page h2{font-size:1.25rem;font-family:var(--font-body);margin:26px 0 8px}
.legal-page p{color:var(--muted);margin-bottom:12px;font-size:.95rem}
.hide{display:none!important}
