* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; -webkit-font-smoothing: antialiased; color: #0f2742; }
body { background: #e9eaec; min-height: 100vh; }
a { text-decoration: none; color: inherit; }
button { background: none; border: none; cursor: pointer; font: inherit; color: inherit; }
hr { border: 0; border-top: 1px solid #e5e7eb; }

/* Top bar */
.topbar { background: #1f7a85; color: #fff; padding: 10px 16px; }
.topbar-inner { display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 12px; font-weight: 600; }
.topbar svg { width: 14px; height: 14px; }
.topbar .name-span { animation: fadeIn .5s ease-in-out; }
.topbar b { font-weight: 700; }

@keyframes fadeIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

/* Container */
main { max-width: 672px; margin: 0 auto; padding: 12px; }
.card { background: #fff; border-radius: 16px; padding: 20px 16px; box-shadow: 0 1px 2px rgba(0,0,0,.05); }

/* Brand */
.brand { display: flex; flex-direction: column; align-items: center; }
.bullseye { width: 56px; height: 56px; border-radius: 50%; background: #e11d2a; display: flex; align-items: center; justify-content: center; }
.bullseye-mid { width: 36px; height: 36px; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; }
.bullseye-dot { width: 16px; height: 16px; border-radius: 50%; background: #e11d2a; }
.brand-name { margin-top: 6px; font-size: 20px; font-weight: 800; letter-spacing: .04em; color: #e11d2a; }
.brand-winmysteps { font-size: 20px; font-weight: 800; color: #0f2742; }
.brand-winmysteps .dot { color: #e11d2a; }

/* Headline */
.headline { text-align: center; margin-top: 12px; }
.headline .small { font-size: 14px; }
.headline .price { font-size: 36px; font-weight: 800; color: #e11d2a; margin: 4px 0; }
.headline .sub { font-size: 12px; }

/* Steps */
.steps { list-style: none; margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.step { display: flex; align-items: center; gap: 12px; }
.step-num { flex: none; width: 24px; height: 24px; border-radius: 50%; background: #e11d2a; color: #fff; font-weight: 700; font-size: 12px; display: flex; align-items: center; justify-content: center; }
.step-label { font-size: 14px; font-weight: 600; }

/* CTA */
.cta-wrap { margin-top: 16px; }
.cta { display: flex; width: 100%; align-items: center; justify-content: center; gap: 8px; background: #e11d2a; color: #fff; font-weight: 700; padding: 14px 24px; border-radius: 9999px; font-size: 16px; box-shadow: 0 0 30px rgba(225,29,42,.45); transition: transform .15s; }
.cta:hover { transform: scale(1.01); }
.cta:active { transform: scale(1); }
.cta svg { width: 16px; height: 16px; transition: transform .15s; }
.cta:hover svg { transform: translateX(4px); }
.cta-note { margin-top: 6px; display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 11px; color: #6b7280; }
.cta-note svg { width: 12px; height: 12px; }

hr.sep { margin: 20px 0; }

/* Trustpilot */
.trust { background: #f3f4f6; border-radius: 12px; padding: 14px; }
.trust-head { display: flex; align-items: center; justify-content: center; gap: 8px; }
.trust-tag { width: 20px; height: 20px; background: #00b67a; border-radius: 2px; display: flex; align-items: center; justify-content: center; }
.trust-tag svg { width: 14px; height: 14px; fill: #fff; stroke: #fff; }
.trust-title { font-size: 16px; font-weight: 700; }
.trust-stars { margin-top: 8px; display: flex; align-items: center; justify-content: center; gap: 4px; }
.trust-star { width: 28px; height: 28px; background: #00b67a; display: flex; align-items: center; justify-content: center; }
.trust-star.half { background: linear-gradient(to right, #00b67a 50%, #d1d5db 50%); }
.trust-star svg { width: 16px; height: 16px; fill: #fff; stroke: #fff; }
.trust-meta { margin-top: 8px; text-align: center; font-size: 12px; color: #4b5563; }
.trust-meta b { color: #0f2742; }

/* FAQ */
.faq { margin-top: 32px; }
.faq h2 { text-align: center; font-size: 24px; font-weight: 800; }
.faq-sub { text-align: center; margin-top: 4px; font-size: 14px; color: #3b6b7a; }
.faq-list { margin-top: 20px; display: flex; flex-direction: column; gap: 10px; }
.faq-item { background: #fff; border-radius: 12px; box-shadow: 0 1px 2px rgba(0,0,0,.05); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 16px; text-align: left; font-weight: 700; font-size: 14px; }
.faq-q svg { width: 16px; height: 16px; flex: none; color: #3b6b7a; transition: transform .2s; }
.faq-item.open .faq-q svg { transform: rotate(180deg); }
.faq-a { padding: 0 16px 14px; font-size: 12px; color: #4b5563; display: none; }
.faq-item.open .faq-a { display: block; }

/* Footer */
footer { margin-top: 32px; padding-bottom: 24px; text-align: center; font-size: 12px; color: #4b5563; }
footer b { color: #0f2742; }
.foot-links { margin-top: 8px; display: flex; align-items: center; justify-content: center; gap: 16px; }
.foot-links a:hover { text-decoration: underline; }

@media (min-width: 640px) {
  .topbar { padding: 12px 16px; }
  .topbar-inner { font-size: 16px; }
  .topbar svg { width: 16px; height: 16px; }
  main { padding: 40px 16px; }
  .card { padding: 56px 48px; }
  .bullseye { width: 160px; height: 160px; }
  .bullseye-mid { width: 96px; height: 96px; }
  .bullseye-dot { width: 48px; height: 48px; }
  .brand-name { margin-top: 16px; font-size: 36px; }
  .brand-winmysteps { font-size: 48px; }
  .headline { margin-top: 40px; }
  .headline .small { font-size: 24px; }
  .headline .price { font-size: 72px; margin: 16px 0; }
  .headline .sub { font-size: 20px; }
  .steps { margin-top: 32px; gap: 16px; }
  .step { gap: 16px; }
  .step-num { width: 28px; height: 28px; font-size: 14px; }
  .step-label { font-size: 18px; }
  .cta-wrap { margin-top: 32px; }
  .cta { padding: 20px 32px; font-size: 24px; gap: 12px; }
  .cta svg { width: 24px; height: 24px; }
  .cta-note { font-size: 14px; margin-top: 12px; }
  .cta-note svg { width: 16px; height: 16px; }
  hr.sep { margin: 32px 0; }
  .trust { padding: 20px; }
  .trust-tag { width: 24px; height: 24px; }
  .trust-title { font-size: 18px; }
  .trust-star { width: 40px; height: 40px; }
  .trust-star svg { width: 24px; height: 24px; }
  .trust-meta { font-size: 14px; margin-top: 12px; }
  .faq { margin-top: 56px; }
  .faq h2 { font-size: 30px; }
  .faq-list { margin-top: 32px; gap: 12px; }
  .faq-q { padding: 20px 24px; font-size: 16px; gap: 16px; }
  .faq-q svg { width: 20px; height: 20px; }
  .faq-a { padding: 0 24px 20px; font-size: 14px; }
  footer { margin-top: 56px; padding-bottom: 40px; font-size: 14px; }
  .foot-links { margin-top: 12px; gap: 24px; }
}
