/* ============================================================
   Rafflit home — BRAND layer. Warm & celebratory, distinctive.
   Coral/gold on warm ivory (OKLCH). Fraunces display + Inter body.
   Scoped to the marketing page; the app keeps its indigo system.
   ============================================================ */

:root {
  /* Warm palette (OKLCH, warm-tinted neutrals) — page-scoped (file loads only on home) */
  --w-canvas: oklch(0.985 0.010 70);
  --w-surface: oklch(0.998 0.004 70);
  --w-sand: oklch(0.962 0.016 66);
  --w-ink: oklch(0.26 0.02 45);
  --w-muted: oklch(0.50 0.02 50);
  --w-border: oklch(0.90 0.012 65);
  --w-coral: oklch(0.685 0.17 36);
  --w-coral-deep: oklch(0.565 0.16 34);
  --w-peach: oklch(0.945 0.045 50);
  --w-gold: oklch(0.83 0.13 80);
  --w-gold-deep: oklch(0.66 0.12 75);
  --w-win: oklch(0.60 0.13 150);
  --w-win-soft: oklch(0.95 0.04 150);

  --w-shadow: 0 2px 4px oklch(0.26 0.02 45 / 0.04), 0 12px 32px oklch(0.26 0.02 45 / 0.08);
  --w-shadow-lg: 0 30px 60px oklch(0.26 0.02 45 / 0.16);
  --w-r: 18px;
  --w-r-lg: 26px;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}
body { background: var(--w-canvas); }
.mkt { font-family: var(--font-body); color: var(--w-ink); background: var(--w-canvas); }
.mkt ::selection { background: var(--w-peach); color: var(--w-coral-deep); }

.mkt-display, .mkt h1, .mkt h2 {
  font-family: "Poppins", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.04;
  color: var(--w-ink);
}
.mkt p { color: var(--w-ink); }
.mkt .lead { color: var(--w-muted); }
.mkt .coral { color: var(--w-coral-deep); }

/* --- Buttons (warm) --- */
.mkt-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-body); font-weight: 600; font-size: 1rem; line-height: 1;
  padding: 14px 24px; border-radius: var(--w-r); border: 1.5px solid transparent;
  cursor: pointer; text-decoration: none; transition: transform .15s var(--ease),
  box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
}
.mkt-btn .material-icons { font-size: 1.2em; }
.mkt-btn--primary { background: var(--w-coral); color: oklch(0.99 0.01 70); box-shadow: 0 6px 18px oklch(0.685 0.17 36 / 0.32); }
.mkt-btn--primary:hover { background: var(--w-coral-deep); transform: translateY(-2px); box-shadow: 0 10px 26px oklch(0.685 0.17 36 / 0.38); color: #fff; }
.mkt-btn--ghost { background: var(--w-surface); color: var(--w-ink); border-color: var(--w-border); box-shadow: var(--w-shadow); }
.mkt-btn--ghost:hover { transform: translateY(-2px); border-color: var(--w-coral); color: var(--w-coral-deep); }
.mkt-btn--on-coral { background: oklch(0.99 0.01 70); color: var(--w-coral-deep); }
.mkt-btn--on-coral:hover { transform: translateY(-2px); color: var(--w-coral-deep); box-shadow: var(--w-shadow-lg); }
.mkt-btn--sm { padding: 9px 16px; font-size: 0.9rem; }

/* --- Warm header --- */
.mkt-appbar { position: sticky; top: 0; z-index: 50; background: oklch(0.985 0.010 70 / 0.82); backdrop-filter: saturate(160%) blur(12px); border-bottom: 1px solid var(--w-border); }
.mkt-appbar__in { display: flex; align-items: center; justify-content: space-between; height: 70px; gap: var(--space-4); }
.mkt-brand { display: inline-flex; align-items: center; gap: 10px; font-family: "Poppins", system-ui, sans-serif; font-weight: 600; font-size: 1.4rem; letter-spacing: -0.02em; color: var(--w-ink); }
.mkt-brand__mark { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 11px; background: var(--w-coral); color: #fff; font-size: 1.15rem; box-shadow: 0 4px 12px oklch(0.685 0.17 36 / 0.35); }
.mkt-nav { display: flex; align-items: center; gap: var(--space-2); }
.mkt-nav a.lnk { padding: 9px 13px; border-radius: 10px; font-weight: 500; font-size: 0.92rem; color: var(--w-muted); }
.mkt-nav a.lnk:hover { color: var(--w-ink); background: var(--w-sand); }

/* --- Section scaffold --- */
.mkt-wrap { max-width: 1180px; margin-inline: auto; padding-inline: 28px; }
.mkt-sec { padding-block: 104px; }
.mkt-sec--sand { background: var(--w-sand); }
.mkt-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--w-coral-deep); }
.mkt-sec__head { max-width: 60ch; margin-bottom: 56px; }
.mkt-sec__head h2 { font-size: clamp(2rem, 1.3rem + 2.6vw, 3rem); }
.mkt-sec__head p { color: var(--w-muted); font-size: 1.1rem; margin-top: 14px; max-width: 56ch; }

/* --- Hero --- */
.mkt-hero { position: relative; overflow: hidden; }
.mkt-hero::before {
  content: ""; position: absolute; inset: -10% -10% auto -10%; height: 720px; pointer-events: none; z-index: 0;
  background:
    radial-gradient(38% 46% at 82% 8%, oklch(0.83 0.13 80 / 0.5), transparent 70%),
    radial-gradient(46% 52% at 8% 0%, oklch(0.945 0.06 50 / 0.85), transparent 66%);
}
.mkt-hero__in { position: relative; z-index: 1; display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 64px; align-items: center; padding-block: 96px 110px; }
.mkt-pill { display: inline-flex; align-items: center; gap: 9px; background: var(--w-surface); border: 1px solid var(--w-border); border-radius: 999px; padding: 7px 15px; font-size: 0.88rem; font-weight: 500; color: var(--w-muted); box-shadow: var(--w-shadow); }
.mkt-pill .d { width: 8px; height: 8px; border-radius: 50%; background: var(--w-win); box-shadow: 0 0 0 4px var(--w-win-soft); }
.mkt-hero h1 { font-size: clamp(2.8rem, 1.6rem + 5vw, 4.6rem); font-weight: 600; margin: 22px 0 20px; }
.mkt-hero h1 .swash { color: var(--w-coral-deep); }
.mkt-hero .lead { font-size: 1.18rem; line-height: 1.6; max-width: 46ch; }
.mkt-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.mkt-hero__note { margin-top: 18px; font-size: 0.9rem; color: var(--w-muted); display: inline-flex; align-items: center; gap: 7px; }
.mkt-hero__note .material-icons { color: var(--w-win); font-size: 1.15em; }

/* --- Hero winner-reveal card (the signature) --- */
.reveal { position: relative; }
.reveal__card {
  position: relative; z-index: 2; background: var(--w-surface); border: 1px solid var(--w-border);
  border-radius: var(--w-r-lg); padding: 26px; box-shadow: var(--w-shadow-lg); transform: rotate(-1.4deg);
}
.reveal__tag { display: flex; align-items: center; gap: 8px; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--w-muted); }
.reveal__tag .live { width: 7px; height: 7px; border-radius: 50%; background: var(--w-coral); animation: live 1.6s ease-in-out infinite; }
@keyframes live { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.reveal__name { font-family: "Poppins", system-ui, sans-serif; font-weight: 600; font-size: 2.4rem; color: var(--w-coral-deep); letter-spacing: -0.02em; margin: 8px 0 14px; }
.reveal__proof { display: inline-flex; align-items: center; gap: 7px; background: var(--w-win-soft); color: var(--w-win); border-radius: 999px; padding: 7px 13px; font-size: 0.82rem; font-weight: 600; }
.reveal__proof .material-icons { font-size: 1.05em; }
.reveal__mini { margin-top: 20px; border-top: 1px dashed var(--w-border); padding-top: 16px; display: grid; gap: 9px; }
.reveal__row { display: grid; grid-template-columns: 16px 1fr auto; align-items: center; gap: 12px; font-size: 0.88rem; }
.reveal__row .r { font-weight: 700; color: var(--w-muted); font-variant-numeric: tabular-nums; }
.reveal__row.lead-row .r { color: var(--w-gold-deep); }
.reveal__row .u { color: var(--w-ink); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.reveal__row .v { font-weight: 700; font-variant-numeric: tabular-nums; color: var(--w-muted); }
/* confetti */
.confetti { position: absolute; inset: -18px -10px auto; height: 0; z-index: 3; pointer-events: none; }
.confetti i { position: absolute; width: 9px; height: 9px; border-radius: 2px; opacity: 0; animation: pop .9s var(--ease) forwards; }
.confetti i:nth-child(1){ left: 12%; background: var(--w-coral); animation-delay:.15s; }
.confetti i:nth-child(2){ left: 30%; background: var(--w-gold); width:7px;height:7px;border-radius:50%; animation-delay:.28s; }
.confetti i:nth-child(3){ left: 52%; background: var(--w-win); animation-delay:.22s; }
.confetti i:nth-child(4){ left: 70%; background: var(--w-gold-deep); border-radius:50%; animation-delay:.34s; }
.confetti i:nth-child(5){ left: 86%; background: var(--w-coral); width:7px;height:7px; animation-delay:.18s; }
.confetti i:nth-child(6){ left: 42%; background: var(--w-gold); animation-delay:.4s; }
@keyframes pop { 0% { opacity: 0; transform: translateY(8px) scale(0.6); } 40% { opacity: 1; } 100% { opacity: 0; transform: translateY(-26px) rotate(40deg) scale(1); } }

/* --- Fair-draw mechanism strip --- */
.mech { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; align-items: start; }
.mech__step { position: relative; padding: 0 22px; text-align: center; }
.mech__step:not(:last-child)::after { content: ""; position: absolute; top: 30px; left: 60%; right: -40%; height: 2px; background: repeating-linear-gradient(90deg, var(--w-border) 0 7px, transparent 7px 14px); }
.mech__dot { position: relative; z-index: 1; display: grid; place-items: center; width: 60px; height: 60px; margin: 0 auto 18px; border-radius: 18px; background: var(--w-surface); border: 1px solid var(--w-border); color: var(--w-coral-deep); box-shadow: var(--w-shadow); }
.mech__dot .material-icons { font-size: 1.7rem; }
.mech__step h3 { font-family: var(--font-body); font-weight: 700; font-size: 1.02rem; margin-bottom: 5px; }
.mech__step p { color: var(--w-muted); font-size: 0.9rem; }
.mech__note { margin-top: 44px; text-align: center; display: flex; align-items: center; justify-content: center; gap: 9px; color: var(--w-muted); font-size: 0.95rem; font-weight: 500; }
.mech__note .material-icons { color: var(--w-coral-deep); font-size: 1.2em; }

/* --- Live leaderboard showcase --- */
.board { background: var(--w-surface); border: 1px solid var(--w-border); border-radius: var(--w-r-lg); box-shadow: var(--w-shadow); overflow: hidden; }
.board__head { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid var(--w-border); }
.board__head .t { font-weight: 700; display: inline-flex; align-items: center; gap: 9px; }
.board__head .live { width: 7px; height: 7px; border-radius: 50%; background: var(--w-coral); animation: live 1.6s ease-in-out infinite; }
.board__row { display: grid; grid-template-columns: 44px 1fr 120px 70px; align-items: center; gap: 16px; padding: 14px 24px; border-bottom: 1px solid var(--w-border); }
.board__row:last-child { border-bottom: none; }
.board__row .rk { font-family: "Poppins", system-ui, sans-serif; font-weight: 600; font-size: 1.4rem; color: var(--w-muted); font-variant-numeric: tabular-nums; }
.board__row.win { background: linear-gradient(90deg, oklch(0.945 0.06 80 / 0.6), transparent 80%); }
.board__row.win .rk { color: var(--w-gold-deep); }
.board__row .who { font-weight: 600; }
.board__row .bonus { font-size: 0.74rem; font-weight: 700; color: var(--w-gold-deep); background: oklch(0.945 0.06 80 / 0.8); border-radius: 999px; padding: 3px 9px; margin-left: 8px; }
.board__track { height: 8px; border-radius: 5px; background: var(--w-sand); overflow: hidden; }
.board__track > span { display: block; height: 100%; border-radius: 5px; background: var(--w-coral); width: var(--v, 50%); }
.board__row .lk { text-align: right; font-weight: 700; font-variant-numeric: tabular-nums; }

/* --- Two ways in (diagram) --- */
.ways { display: grid; grid-template-columns: 1fr auto 1fr; gap: 30px; align-items: center; }
.ways__in { display: grid; gap: 16px; }
.ways__chip { display: flex; align-items: center; gap: 14px; background: var(--w-surface); border: 1px solid var(--w-border); border-radius: var(--w-r); padding: 18px 20px; box-shadow: var(--w-shadow); }
.ways__chip .ic { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 13px; background: var(--w-peach); color: var(--w-coral-deep); flex-shrink: 0; }
.ways__chip h3 { font-family: var(--font-body); font-size: 1rem; font-weight: 700; }
.ways__chip p { color: var(--w-muted); font-size: 0.88rem; }
.ways__merge { display: grid; place-items: center; gap: 10px; color: var(--w-muted); }
.ways__merge .material-icons { font-size: 2rem; color: var(--w-coral); }
.ways__out { background: linear-gradient(180deg, var(--w-peach), var(--w-surface) 80%); border: 1px solid var(--w-border); border-radius: var(--w-r); padding: 26px; box-shadow: var(--w-shadow); text-align: center; }
.ways__out h3 { font-family: "Poppins", system-ui, sans-serif; font-weight: 600; font-size: 1.4rem; margin-bottom: 8px; }
.ways__out p { color: var(--w-muted); font-size: 0.92rem; }

/* --- Big typographic statement --- */
.statement { text-align: center; }
.statement p { font-family: "Poppins", system-ui, sans-serif; font-weight: 500; font-size: clamp(2rem, 1.1rem + 4vw, 3.6rem); line-height: 1.16; letter-spacing: -0.02em; color: var(--w-ink); max-width: 18ch; margin: 0 auto; }
.statement b { color: var(--w-coral-deep); font-weight: 600; }
.statement .g { color: var(--w-gold-deep); font-weight: 600; }

/* --- Closing invitation --- */
.invite { position: relative; overflow: hidden; text-align: center; border-radius: var(--w-r-lg); padding: 88px 28px; background: radial-gradient(70% 120% at 50% -10%, oklch(0.75 0.16 45), var(--w-coral) 70%); box-shadow: var(--w-shadow-lg); }
.invite h2 { color: oklch(0.99 0.02 70); font-size: clamp(2rem, 1.2rem + 3vw, 3.2rem); }
.invite p { color: oklch(0.99 0.02 70 / 0.9); margin-top: 14px; font-size: 1.12rem; }
.invite .mkt-btn { margin-top: 32px; }
.invite__confetti { position: absolute; inset: 0; pointer-events: none; opacity: 0.5; background-image:
  radial-gradient(circle, oklch(0.99 0.02 70 / 0.5) 2px, transparent 2.5px),
  radial-gradient(circle, oklch(0.83 0.13 80 / 0.6) 2px, transparent 2.5px);
  background-size: 90px 90px, 120px 120px; background-position: 0 0, 40px 50px; }

/* --- Footer (warm) --- */
.mkt-foot { border-top: 1px solid var(--w-border); background: var(--w-surface); padding-block: 36px; }
.mkt-foot .mkt-wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; align-items: center; color: var(--w-muted); font-size: 0.9rem; }

/* --- Entrance motion --- */
.rise { opacity: 0; transform: translateY(16px); animation: rise .7s var(--ease) forwards; }
.r1 { animation-delay: .05s; } .r2 { animation-delay: .13s; } .r3 { animation-delay: .21s; } .r4 { animation-delay: .29s; } .r5 { animation-delay: .37s; }
@keyframes rise { to { opacity: 1; transform: none; } }

/* --- Responsive --- */
@media (max-width: 1000px) {
  .mkt-hero__in { grid-template-columns: 1fr; gap: 48px; padding-block: 64px 80px; }
  .reveal__card { transform: none; max-width: 460px; }
  .mech { grid-template-columns: repeat(2, 1fr); gap: 36px 0; }
  .mech__step:nth-child(odd)::after { display: none; }
  .ways { grid-template-columns: 1fr; gap: 18px; }
  .ways__merge { transform: rotate(90deg); }
  .mkt-sec { padding-block: 72px; }
}
@media (max-width: 600px) {
  .mech { grid-template-columns: 1fr; }
  .mech__step::after { display: none !important; }
  .board__row { grid-template-columns: 32px 1fr 60px; }
  .board__track { display: none; }
  .mkt-hero__cta .mkt-btn { width: 100%; }
  .mkt-wrap { padding-inline: 20px; }
}
@media (max-width: 767px) {
  .mkt-nav {
    position: absolute; left: 0; right: 0; top: 70px;
    flex-direction: column; align-items: stretch; gap: 6px;
    background: var(--w-surface); border-bottom: 1px solid var(--w-border);
    padding: 14px 20px 18px; box-shadow: var(--w-shadow);
  }
  .mkt-nav .lnk, .mkt-nav .mkt-btn { width: 100%; justify-content: center; }
}

@media (prefers-reduced-motion: reduce) {
  .rise, .confetti i, .reveal__card { animation: none; opacity: 1; transform: none; }
  .live { animation: none; }
}
