/* reelmint marketing pages — landing, pricing, legal, help */

/* ----- Nav ----- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11,13,16,.88);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; align-items: center; gap: 1.4rem;
  padding: calc(.7rem + var(--safe-top)) 1.2rem .7rem;
}
.nav .brand { text-decoration: none; }
.nav-links {
  display: flex; gap: 1.4rem; margin-left: 1.4rem;
  font-size: .92rem;
}
.nav-links a {
  color: var(--muted); text-decoration: none;
  font-weight: 500; transition: color .15s;
}
.nav-links a:hover { color: var(--text); }
.nav-cta { margin-left: auto; display: flex; gap: .55rem; align-items: center; }
.primary-sm, .ghost-sm {
  padding: .55rem .9rem; border-radius: 10px;
  font: 600 .88rem 'Inter', sans-serif;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: .35rem;
}
.primary-sm {
  color: #0b0d10;
  background: linear-gradient(180deg, #ffea3a, var(--accent));
  box-shadow: 0 1px 0 rgba(255,255,255,.4) inset;
}
.ghost-sm {
  color: var(--text);
  border: 1px solid var(--line-2);
  background: transparent;
}
.ghost-sm:hover { border-color: var(--accent-2); }
.nav-burger {
  display: none; background: transparent; border: 0; color: var(--text);
  cursor: pointer; padding: .4rem; margin-left: auto;
}
.nav-mobile {
  display: flex; flex-direction: column; gap: .1rem;
  padding: .5rem 1.2rem 1.1rem;
  border-top: 1px solid var(--line);
}
.nav-mobile a {
  padding: .8rem .2rem; color: var(--text);
  font-weight: 500; text-decoration: none;
  border-bottom: 1px solid var(--line);
}
.nav-mobile a.primary-sm {
  margin-top: .6rem; justify-content: center; border-bottom: 0;
}
@media (max-width: 820px) {
  .nav-links, .nav-cta { display: none; }
  .nav-burger { display: inline-flex; }
}

/* ----- Hero (marketing) ----- */
.hero-mkt {
  padding: 3.5rem 1.2rem 2.8rem;
  max-width: 1180px; margin: 0 auto;
}
.hero-mkt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}
@media (max-width: 920px) {
  .hero-mkt-grid { grid-template-columns: 1fr; gap: 2rem; }
}
.eyebrow {
  display: inline-block;
  font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700;
  color: var(--accent-2);
  background: rgba(0,225,255,.08);
  border: 1px solid rgba(0,225,255,.22);
  padding: .35rem .65rem;
  border-radius: 999px;
  margin-bottom: 1.1rem;
}
.hero-text h1 {
  font-family: 'Poppins', 'Inter', sans-serif;
  font-weight: 900;
  font-size: clamp(2.4rem, 6vw, 3.6rem);
  line-height: 1.04;
  letter-spacing: -.025em;
  margin: 0 0 1.1rem;
}
.hero-text h1 .grad {
  background: linear-gradient(90deg, var(--accent), #ff9d2e 70%, var(--accent-pink));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-lede {
  color: var(--muted); font-size: 1.05rem; line-height: 1.6;
  max-width: 46ch; margin: 0 0 1.7rem;
}
.hero-ctas {
  display: flex; gap: .7rem; flex-wrap: wrap; margin-bottom: 1.8rem;
}
.primary.lg, .ghost.lg {
  width: auto; padding: 1rem 1.4rem;
  font-size: 1rem;
}
.ghost.lg { background: transparent; }
.hero-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
  border-top: 1px solid var(--line);
  padding-top: 1.4rem; max-width: 460px;
}
.hero-stats > div { display: flex; flex-direction: column; }
.hero-stats b {
  font-family: 'Poppins', sans-serif; font-weight: 800;
  font-size: 1.7rem; color: var(--text);
  line-height: 1;
}
.hero-stats span {
  color: var(--muted); font-size: .82rem; margin-top: .35rem;
}

/* phone mockup */
.hero-visual { display: flex; justify-content: center; }
.phone {
  position: relative;
  width: 280px; height: 560px;
  border-radius: 38px;
  padding: 12px;
  background: linear-gradient(160deg, #1f2630, #0e1116);
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,.6),
    0 2px 0 rgba(255,255,255,.04) inset,
    0 0 0 1.5px var(--line);
}
.phone-notch {
  position: absolute; top: 22px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 26px;
  background: #000; border-radius: 16px;
  z-index: 3;
}
.phone-screen {
  width: 100%; height: 100%;
  border-radius: 28px;
  overflow: hidden; position: relative;
  background: #000;
}
.reel-mock {
  width: 100%; height: 100%;
  background:
    radial-gradient(180px 240px at 50% 60%, rgba(255,225,0,.25), transparent 70%),
    linear-gradient(160deg, #1a1f28, #0d1018);
  position: relative;
}
.reel-pov {
  position: absolute; top: 56px; left: 14px; right: 14px;
  font: 800 14px 'Poppins', sans-serif;
  color: #fff;
  text-align: center;
  text-shadow: 0 2px 6px rgba(0,0,0,.8);
  line-height: 1.18;
}
.reel-bg {
  position: absolute; left: 50%; top: 38%; transform: translate(-50%,-50%);
  width: 80px; height: 220px;
  background: linear-gradient(180deg, #ff8a1f, #ff5a00);
  border-radius: 10px;
  box-shadow: 0 0 60px 20px rgba(255,138,31,.55);
  animation: reelGlow 3s ease-in-out infinite;
}
@keyframes reelGlow {
  0%,100% { box-shadow: 0 0 60px 20px rgba(255,138,31,.55); }
  50%    { box-shadow: 0 0 80px 30px rgba(255,138,31,.85); }
}
.reel-cap {
  position: absolute; left: 50%; top: 70%; transform: translateX(-50%);
  font: 900 28px 'Poppins', sans-serif;
  color: var(--accent);
  letter-spacing: -.01em;
  text-shadow: 0 0 18px rgba(255,225,0,.55), 0 2px 0 #111;
}
.reel-cta {
  position: absolute; left: 14px; right: 14px; bottom: 24px;
  text-align: center;
  font: 800 13px 'Poppins', sans-serif;
  color: var(--accent-2);
  text-shadow: 0 2px 6px rgba(0,0,0,.8);
}
.phone-mic {
  position: absolute; bottom: -22px; right: -10px;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: linear-gradient(180deg, #ffea3a, var(--accent));
  display: grid; place-items: center;
  color: #0b0d10;
  box-shadow: 0 14px 30px -6px rgba(255,225,0,.6), 0 0 0 6px rgba(255,225,0,.12);
  animation: micPulse 2.4s ease-in-out infinite;
}
@keyframes micPulse {
  0%,100% { transform: scale(1); }
  50% { transform: scale(1.07); }
}

.hero-strip {
  margin-top: 2.5rem;
  display: flex; flex-wrap: wrap; gap: .35rem 1rem;
  color: var(--muted-2); font-size: .82rem;
  justify-content: center;
}

/* ----- Sections ----- */
.section {
  max-width: 1180px; margin: 0 auto;
  padding: 4.5rem 1.2rem;
}
.section-alt {
  background:
    radial-gradient(700px 360px at 50% 0%, rgba(0,225,255,.04), transparent 70%),
    #0e1117;
  max-width: 100%;
  padding-left: 0; padding-right: 0;
}
.section-alt > * {
  max-width: 1180px; margin-left: auto; margin-right: auto;
  padding-left: 1.2rem; padding-right: 1.2rem;
}
.section-head { text-align: center; margin-bottom: 3rem; }
.section-head h2 {
  font-family: 'Poppins', sans-serif; font-weight: 800;
  font-size: clamp(1.9rem, 4vw, 2.7rem);
  letter-spacing: -.02em;
  margin: 0 0 .65rem;
}
.section-head p {
  color: var(--muted); font-size: 1.02rem;
  max-width: 56ch; margin: 0 auto;
}

/* ----- How it works ----- */
.how-grid {
  display: grid; gap: 1.1rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 820px) { .how-grid { grid-template-columns: 1fr; } }
.how-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 1.6rem 1.4rem;
  transition: transform .15s ease, border-color .15s ease;
}
.how-card:hover { transform: translateY(-2px); border-color: var(--accent); }
.how-num {
  display: inline-grid; place-items: center;
  width: 40px; height: 40px; border-radius: 12px;
  font: 800 1.1rem 'Poppins', sans-serif;
  color: #0b0d10;
  background: linear-gradient(180deg, #ffea3a, var(--accent));
  margin-bottom: 1rem;
}
.how-card h3 {
  margin: 0 0 .5rem; font-size: 1.1rem; letter-spacing: -.01em;
}
.how-card p { margin: 0; color: var(--muted); line-height: 1.6; }

/* ----- Features ----- */
.feature-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 920px) { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .feature-grid { grid-template-columns: 1fr; } }
.feature {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 1.35rem;
  transition: border-color .15s ease;
}
.feature:hover { border-color: var(--accent-2); }
.feature-icon {
  width: 42px; height: 42px; border-radius: 10px;
  background: rgba(255,225,0,.08);
  border: 1px solid rgba(255,225,0,.18);
  display: grid; place-items: center;
  font-size: 1.25rem;
  margin-bottom: .85rem;
}
.feature h3 { margin: 0 0 .3rem; font-size: 1rem; }
.feature p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.55; }

/* ----- Comparison ----- */
.compare { overflow-x: auto; }
.compare table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  font-size: .92rem;
  min-width: 640px;
}
.compare th, .compare td {
  padding: .85rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.compare th {
  font-weight: 600;
  color: var(--muted);
  background: var(--card-2);
}
.compare th.hilite {
  color: var(--accent);
  background: rgba(255,225,0,.06);
}
.compare td.hilite {
  color: var(--text); font-weight: 600;
  background: rgba(255,225,0,.04);
}
.compare tr:last-child td { border-bottom: 0; }

/* ----- Examples ----- */
.examples {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 820px) { .examples { grid-template-columns: 1fr; } }
.example {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 1rem;
}
.ex-tag {
  display: inline-block; font-size: .72rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--accent-2);
  background: rgba(0,225,255,.08);
  padding: .25rem .55rem; border-radius: 999px;
  margin-bottom: .8rem;
}
.ex-thumb {
  width: 100%; aspect-ratio: 9 / 16;
  border-radius: 12px;
  background: #0e1218;
  position: relative;
  margin-bottom: .75rem;
  overflow: hidden;
}
.ex-trading { background: radial-gradient(220px 280px at 50% 55%, rgba(255,225,0,.18), transparent 70%), #0a0f17; }
.ex-comedy  { background: radial-gradient(220px 280px at 50% 55%, rgba(255,77,109,.18), transparent 70%), #110a14; }
.ex-edu     { background: radial-gradient(220px 280px at 50% 55%, rgba(0,225,255,.18), transparent 70%), #07101a; }
.ex-pov {
  position: absolute; top: 14px; left: 12px; right: 12px;
  font: 800 12px 'Poppins', sans-serif;
  color: #fff; text-align: center;
  text-shadow: 0 1px 4px rgba(0,0,0,.8);
  line-height: 1.2;
}
.ex-cap {
  position: absolute; left: 50%; top: 58%; transform: translateX(-50%);
  font: 900 28px 'Poppins', sans-serif;
  color: var(--accent);
  text-shadow: 0 0 14px rgba(255,225,0,.55);
}
.example p { margin: 0; color: var(--muted); font-size: .88rem; }

/* ----- Pricing tiers ----- */
.tier-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 1rem;
}
@media (max-width: 980px) { .tier-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .tier-grid { grid-template-columns: 1fr; } }
.tier {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 1.4rem 1.2rem;
  position: relative;
  display: flex; flex-direction: column;
}
.tier h3 { margin: 0 0 .6rem; font-size: 1rem; color: var(--muted); font-weight: 600; }
.tier-price { margin-bottom: 1rem; }
.tier-price b {
  font-family: 'Poppins', sans-serif; font-weight: 800;
  font-size: 2rem; color: var(--text); letter-spacing: -.02em;
}
.tier-price span { color: var(--muted); font-size: .85rem; margin-left: .25rem; }
.tier ul { list-style: none; padding: 0; margin: 0 0 1.3rem; flex: 1; }
.tier ul li {
  padding: .35rem 0; color: var(--muted); font-size: .92rem;
  display: flex; align-items: baseline; gap: .4rem;
}
.tier ul li::before { content: "✓"; color: var(--accent-green); }
.tier .full {
  width: 100%; text-align: center; justify-content: center;
}
.tier.popular {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(255,225,0,.08);
}
.tier-badge {
  position: absolute; top: -10px; right: 18px;
  background: var(--accent); color: #0b0d10;
  font: 700 .68rem 'Inter', sans-serif;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .25rem .6rem;
  border-radius: 999px;
}
.centred { text-align: center; }
.centred a { color: var(--accent-2); text-decoration: none; }
.centred a:hover { text-decoration: underline; }

/* ----- Testimonials ----- */
.testimonials {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 880px) { .testimonials { grid-template-columns: 1fr; } }
.quote {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 1.4rem;
}
.quote p {
  margin: 0 0 1.2rem;
  font-size: .98rem; line-height: 1.55;
}
.who { display: flex; gap: .65rem; align-items: center; }
.avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  font: 700 .95rem 'Inter', sans-serif;
  color: #0b0d10;
}
.avatar.a1 { background: linear-gradient(180deg, var(--accent), #ff9d2e); }
.avatar.a2 { background: linear-gradient(180deg, var(--accent-pink), #ff6b9d); }
.avatar.a3 { background: linear-gradient(180deg, var(--accent-2), var(--accent-green)); }
.who b { display: block; font-size: .92rem; }
.who span { color: var(--muted); font-size: .8rem; }

/* ----- FAQ ----- */
.faq { max-width: 760px; margin: 0 auto; }
.faq details {
  border-bottom: 1px solid var(--line);
  padding: .9rem 0;
}
.faq details:first-child { border-top: 1px solid var(--line); }
.faq summary {
  list-style: none; cursor: pointer;
  font-weight: 600;
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; color: var(--accent);
  font-size: 1.4rem; line-height: 1;
  transition: transform .2s;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p {
  margin: .55rem 0 0; color: var(--muted);
  line-height: 1.6; font-size: .95rem;
}
.faq a { color: var(--accent-2); }

/* ----- CTA strip ----- */
.cta-strip {
  text-align: center;
  padding: 4.5rem 1.2rem;
  margin: 2rem auto 0;
  max-width: 1180px;
  background:
    radial-gradient(600px 280px at 50% 50%, rgba(255,225,0,.06), transparent 70%);
}
.cta-strip h2 {
  font-family: 'Poppins', sans-serif; font-weight: 800;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  margin: 0 0 .5rem;
  letter-spacing: -.02em;
}
.cta-strip p { color: var(--muted); margin: 0 0 1.6rem; }
.cta-strip .primary { display: inline-flex; width: auto; padding: 1rem 1.6rem; }

/* ----- Footer (marketing) ----- */
.footer-mkt {
  border-top: 1px solid var(--line);
  padding: 3rem 1.2rem 2rem;
  background: #0a0c10;
}
.foot-grid {
  max-width: 1180px; margin: 0 auto;
  display: grid; gap: 2rem;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
}
@media (max-width: 760px) {
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
.foot-col h4 {
  font-size: .82rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); margin: 0 0 .85rem; font-weight: 700;
}
.foot-col a {
  display: block; color: var(--text);
  text-decoration: none; font-size: .92rem;
  padding: .25rem 0;
}
.foot-col a:hover { color: var(--accent-2); }
.foot-brand .brand { margin-bottom: .8rem; text-decoration: none; }
.foot-brand p { color: var(--muted); font-size: .92rem; margin: 0; max-width: 28ch; }
.foot-bottom {
  max-width: 1180px; margin: 2.5rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; gap: 1rem;
  color: var(--muted-2); font-size: .82rem;
  flex-wrap: wrap;
}

/* shared button sizes */
.full { width: 100%; }
