/* PPC Cards marketing site — shared styles (bento redesign) */
:root {
  --gold:#f4dc9c; --gold-line:#c9a447; --gold-on-grad:#3a2a08;
  --bg:#1d1b18; --panel:#2a2722; --text:#f1efe6; --muted:#aab1ad; --faint:#7a8190;
}
* { box-sizing:border-box; }
html, body { margin:0; background:var(--bg); }
body {
  font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Inter, system-ui, sans-serif;
  min-height:100vh; color:var(--text); text-transform:uppercase;
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }

.nav {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px; border-bottom:1px solid rgba(201,164,71,.2);
  max-width:1040px; margin:0 auto;
}
.nav-logo { display:flex; align-items:center; gap:9px; }
.nav-logo .mark { font-family:Georgia,'Times New Roman',serif; font-weight:600; letter-spacing:.3em; font-size:12px; color:var(--gold); }
.nav-links { display:flex; align-items:center; gap:16px; font-size:9px; letter-spacing:.16em; color:var(--muted); }
.nav-links a:hover { color:var(--gold); }
.pill-gold {
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); border:1px solid var(--gold-line);
  color:var(--gold-on-grad); padding:6px 14px; border-radius:999px; font-weight:700;
  font-size:9px; letter-spacing:.14em; display:inline-flex; align-items:center; gap:6px;
}
.pill-gold:hover { filter:brightness(1.05); color:var(--gold-on-grad); }
.pill-outline {
  background:var(--panel); border:1px solid var(--gold-line); color:var(--gold);
  padding:6px 14px; border-radius:999px; font-weight:700; font-size:9px;
  letter-spacing:.14em; display:inline-flex; align-items:center; gap:6px;
}

.hero { text-align:center; padding:52px 24px 38px; }
.hero-mark {
  font-family:Georgia,'Times New Roman',serif; font-weight:600; letter-spacing:.3em;
  font-size:clamp(28px, 7vw, 40px); line-height:1; margin:0;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.hero-blurb { font-size:11px; letter-spacing:.16em; color:var(--muted); margin-top:16px; line-height:1.9; }
.hero-ctas { display:flex; gap:12px; justify-content:center; margin-top:26px; flex-wrap:wrap; align-items:center; }
.hero-note { font-size:9px; letter-spacing:.16em; color:var(--faint); margin-top:12px; }
.dot { color:#5a626d; padding:0 4px; }

.appstore-badge {
  display:inline-flex; align-items:center; gap:8px; background:#000;
  border:1px solid #555; border-radius:10px; padding:9px 18px; color:#fff;
}
.appstore-badge .txt { text-align:left; text-transform:none; }
.appstore-badge .txt .small { display:block; font-size:9px; color:#bbb; }
.appstore-badge .txt .big { display:block; font-size:13px; font-weight:600; }
.appstore-badge.soon { opacity:.45; cursor:default; }
.btn-gold {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); border:1px solid var(--gold-line);
  border-radius:999px; padding:11px 24px; color:var(--gold-on-grad);
  font-size:10px; font-weight:700; letter-spacing:.14em; cursor:pointer;
}
.btn-gold:hover { filter:brightness(1.05); }

.bento-wrap { padding:0 22px 36px; max-width:700px; margin:0 auto; }
.bento { display:grid; grid-template-columns:1.55fr 1fr 1fr; grid-auto-rows:100px; gap:10px; }
.bento-card {
  border-radius:16px; position:relative; overflow:hidden; padding:14px;
  display:flex; flex-direction:column; justify-content:center; text-align:center;
  transition:transform .15s ease;
}
.bento-card:hover { transform:translateY(-2px); }
.bento-card .big-ico { position:absolute; font-size:74px; right:-12px; bottom:-16px; opacity:.32; line-height:1; }
.bento-card.flagship { grid-row:span 2; }
.bento-card.flagship .big-ico { font-size:130px; right:-22px; top:-14px; bottom:auto; transform:rotate(8deg); }
.bento-title { font-weight:800; font-size:13px; letter-spacing:.1em; position:relative; }
.bento-card.flagship .bento-title { font-size:16px; }
.bento-sub { font-size:8px; letter-spacing:.12em; margin-top:3px; line-height:1.6; position:relative; }
.bento-cta { font-size:8px; letter-spacing:.16em; margin-top:8px; font-weight:700; position:relative; }
.bento-row2 { display:grid; grid-template-columns:1fr 2fr; gap:10px; margin-top:10px; }
.feature-strip {
  border-radius:16px; background:var(--panel); border:1px solid rgba(201,164,71,.3);
  padding:13px; display:flex; align-items:center; justify-content:space-around; min-height:78px;
}
.feature-strip .f { text-align:center; }
.feature-strip i { font-size:18px; color:var(--gold); }
.feature-strip .f-label { font-size:7px; letter-spacing:.14em; color:var(--muted); margin-top:4px; }

.takeover { position:relative; overflow:hidden; padding:38px 26px 30px; }
.takeover .big-ico { position:absolute; right:-30px; top:-24px; font-size:190px; opacity:.22; transform:rotate(10deg); line-height:1; }
.takeover-kicker { font-size:9px; letter-spacing:.2em; }
.takeover-title { font-family:Georgia,'Times New Roman',serif; font-weight:600; font-size:32px; letter-spacing:.14em; margin:6px 0 0; }
.takeover-desc { font-size:10px; letter-spacing:.1em; margin-top:10px; max-width:400px; line-height:1.8; position:relative; }
.chips { display:flex; gap:8px; margin-top:14px; flex-wrap:wrap; }
.chip { font-size:8px; letter-spacing:.14em; padding:5px 12px; border-radius:999px; }

.section { padding:24px 26px 6px; max-width:660px; margin:0 auto; }
.section-label { font-size:9px; letter-spacing:.22em; color:var(--gold-line); margin-bottom:12px; }
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.step-card { background:var(--panel); border:1px solid rgba(201,164,71,.25); border-radius:12px; padding:12px; display:flex; flex-direction:column; justify-content:center; text-align:center; }
.step-num { font-size:16px; font-family:Georgia,'Times New Roman',serif; color:var(--gold); }
.step-text { font-size:8px; letter-spacing:.1em; color:var(--muted); margin-top:6px; line-height:1.7; }
.modes { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.mode-card { border-radius:12px; padding:14px; display:flex; flex-direction:column; justify-content:center; text-align:center; }
.mode-card.alt { background:var(--panel); border:1.5px solid var(--gold-line); }
.mode-title { font-weight:800; font-size:11px; letter-spacing:.1em; }
.mode-sub { font-size:8px; letter-spacing:.08em; margin-top:4px; line-height:1.7; }
.mode-card.alt .mode-title { color:var(--gold); }
.mode-card.alt .mode-sub { color:var(--muted); }

.page-cta { text-align:center; padding:26px 26px 34px; }
.next-link { font-size:8px; letter-spacing:.14em; color:var(--faint); margin-top:12px; display:block; }
.next-link:hover { color:var(--gold); }

.account-wrap { max-width:560px; margin:0 auto; padding:28px 22px 40px; }
.card-dark { background:var(--panel); border:1px solid rgba(201,164,71,.3); border-radius:16px; padding:18px; }
.acct-row { display:flex; align-items:center; gap:14px; }
.avatar {
  width:52px; height:52px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); display:flex; align-items:center;
  justify-content:center; font-family:Georgia,'Times New Roman',serif; font-size:22px; color:var(--gold-on-grad);
}
.acct-name { font-weight:800; font-size:14px; letter-spacing:.1em; }
.acct-meta { font-size:8px; letter-spacing:.1em; color:var(--muted); margin-top:4px; text-transform:none; }
.signout-btn {
  font-size:8px; letter-spacing:.14em; color:var(--faint); border:1px solid #44413c;
  border-radius:999px; padding:5px 11px; background:none; cursor:pointer; text-transform:uppercase;
}
.signout-btn:hover { color:var(--gold); border-color:var(--gold-line); }
.stat-hero { text-align:center; margin:26px 0 18px; }
.stat-hero-num { font-family:Georgia,'Times New Roman',serif; font-size:44px; margin-top:6px; }
.stat-hero-sub { font-size:8px; letter-spacing:.14em; color:var(--faint); margin-top:4px; }
.stat-pills { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.stat-pill { border-radius:12px; padding:11px 13px; display:flex; justify-content:space-between; align-items:center; gap:8px; }
.stat-pill .sp-name { display:inline-flex; align-items:center; gap:7px; font-weight:800; font-size:10px; letter-spacing:.1em; }
.stat-pill .sp-name i { font-size:14px; }
.stat-pill .sp-val { font-size:8px; letter-spacing:.1em; white-space:nowrap; }
.guest-note { text-align:center; font-size:8px; letter-spacing:.12em; color:var(--faint); margin-top:18px; line-height:1.8; }
.auth-error { text-align:center; font-size:9px; letter-spacing:.1em; color:#e88; margin-top:12px; text-transform:none; }
.hidden { display:none !important; }

.faq { max-width:560px; margin:0 auto; padding:8px 22px 34px; }
.faq-item { background:var(--panel); border:1px solid rgba(201,164,71,.25); border-radius:12px; padding:14px 16px; margin-bottom:10px; }
.faq-q { font-weight:800; font-size:10px; letter-spacing:.12em; color:var(--gold); }
.faq-a { font-size:9px; letter-spacing:.08em; color:var(--muted); margin-top:7px; line-height:1.8; text-transform:none; }

.footer {
  border-top:1px solid rgba(201,164,71,.2); padding:18px 22px;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px;
  font-size:8px; letter-spacing:.14em; color:var(--faint); max-width:1040px; margin:0 auto;
}
.footer a:hover { color:var(--gold); }

/* variant palettes — values copied from src/App.js .variant-card recipes */
.v-ofc       { background:linear-gradient(160deg,#f4dc9c,#e8c46b); }
.v-rummy     { background:linear-gradient(160deg,#ff8a78,#e84030); }
.v-solitaire { background:linear-gradient(160deg,#b8e0bf,#88c895); }
.v-scala40   { background:linear-gradient(160deg,#b8c4f0,#8aa0e0); }
.v-palace    { background:linear-gradient(160deg,#c8d990,#a8c050); }
.v-hearts    { background:linear-gradient(160deg,#ffc4cf,#f495a8); }
.v-ofc       .t1 { color:#3a2a08; } .v-ofc       .t2 { color:#7a5a18; } .v-ofc       .t3 { color:#5e4612; } .v-ofc       .ic { color:#4a3a10; }
.v-rummy     .t1 { color:#3a0606; } .v-rummy     .t2 { color:#7a1a14; } .v-rummy     .t3 { color:#5c1210; } .v-rummy     .ic { color:#4a0a08; }
.v-solitaire .t1 { color:#072a13; } .v-solitaire .t2 { color:#1b6a32; } .v-solitaire .t3 { color:#14512a; } .v-solitaire .ic { color:#0e3a1d; }
.v-scala40   .t1 { color:#080e28; } .v-scala40   .t2 { color:#1a2858; } .v-scala40   .t3 { color:#16204a; } .v-scala40   .ic { color:#0e1638; }
.v-palace    .t1 { color:#1a2406; } .v-palace    .t2 { color:#3c4d10; } .v-palace    .t3 { color:#2f3d0c; } .v-palace    .ic { color:#233008; }
.v-hearts    .t1 { color:#4a0a15; } .v-hearts    .t2 { color:#8a1f30; } .v-hearts    .t3 { color:#701825; } .v-hearts    .ic { color:#5a0e1a; }
.chip-dark.c-ofc       { background:#3a2a08; color:#f4dc9c; }
.chip-dark.c-rummy     { background:#3a0606; color:#ff8a78; }
.chip-dark.c-solitaire { background:#072a13; color:#b8e0bf; }
.chip-dark.c-scala40   { background:#080e28; color:#b8c4f0; }
.chip-dark.c-palace    { background:#1a2406; color:#c8d990; }
.chip-dark.c-hearts    { background:#4a0a15; color:#ffc4cf; }

@media (max-width:640px) {
  .bento { grid-template-columns:1fr 1fr; grid-auto-rows:96px; }
  .bento-card.flagship { grid-column:1/3; grid-row:auto; }
  .bento-row2 { grid-template-columns:1fr; }
  .steps { grid-template-columns:1fr; }
  .modes { grid-template-columns:1fr; }
  .stat-pills { grid-template-columns:1fr; }
  .nav-links { gap:10px; }
}

/* account v2 — multi-provider sign-in + readable stat rows */
.auth-stack { display:flex; flex-direction:column; gap:8px; margin-top:16px; }
.btn-auth {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  border-radius:999px; padding:11px; font-size:10px; font-weight:700;
  letter-spacing:.12em; cursor:pointer; text-transform:uppercase; width:100%;
}
.btn-auth.google { background:linear-gradient(160deg,#f4dc9c,#e8c46b); border:1px solid var(--gold-line); color:var(--gold-on-grad); }
.btn-auth.apple { background:#000; border:1px solid #555; color:#fff; }
.btn-auth.email { background:none; border:1px solid var(--gold-line); color:var(--gold); }
.btn-auth:hover { filter:brightness(1.08); }
.auth-div { display:flex; align-items:center; gap:8px; margin:14px 0 10px; color:#5a626d; font-size:8px; letter-spacing:.18em; text-transform:uppercase; }
.auth-div::before, .auth-div::after { content:""; flex:1; height:1px; background:#44413c; }
.auth-input {
  background:var(--bg); border:1px solid #44413c; border-radius:8px; padding:10px 12px;
  font-size:11px; color:var(--text); width:100%; text-transform:none; font-family:inherit;
}
.auth-input:focus { outline:none; border-color:var(--gold-line); }
.auth-links { font-size:8px; letter-spacing:.1em; color:var(--faint); margin-top:10px; }
.auth-links a { color:var(--gold); cursor:pointer; }
.auth-msg { text-align:center; font-size:9px; letter-spacing:.05em; color:#9fd0a8; margin-top:12px; text-transform:none; }
.stat-rows { display:flex; flex-direction:column; gap:8px; }
.stat-row { border-radius:12px; padding:12px 16px; display:flex; justify-content:space-between; align-items:center; }
.stat-row .sr-name { display:inline-flex; align-items:center; gap:8px; font-weight:800; font-size:12px; letter-spacing:.1em; }
.stat-row .sr-name i { font-size:18px; }
.stat-row .sr-right { text-align:right; }
.stat-row .sr-big { display:block; font-size:18px; font-weight:800; line-height:1; }
.stat-row .sr-sub { display:block; font-size:9px; letter-spacing:.08em; margin-top:3px; }

/* hero logo (replaces text wordmark) + centered takeover band */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.hero-logo svg { width:116px; height:105px; display:block; margin:0 auto; }
.takeover { text-align:center; }
.takeover-desc { margin-left:auto; margin-right:auto; max-width:400px; }
.chips { justify-content:center; }
.takeover .big-ico-left { position:absolute; left:-30px; bottom:-34px; font-size:140px; opacity:.14; transform:rotate(-12deg); line-height:1; }

/* animated hero logo — 13 cards fly into the 3-5-5 grid (mirrors app welcome) */
.plogo { position:relative; width:116px; height:105px; margin:0 auto; }
.plogo .pc {
  position:absolute; width:17.8px; height:24.5px; border-radius:3.3px;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); border:1px solid #c9a447;
  opacity:0; animation: pfly-loop 10s cubic-bezier(.2,.8,.25,1) infinite;
}
@keyframes pfly {
  0% { opacity:0; transform:translate(var(--fx),var(--fy)) rotate(var(--fr)) scale(.55); }
  60% { opacity:1; }
  100% { opacity:1; transform:translate(0,0) rotate(0deg) scale(1); }
}
.plogo::after {
  content:""; position:absolute; inset:-12px; border-radius:16px; pointer-events:none;
  animation: pglow 4.5s ease-in-out 2.2s infinite;
}
@keyframes pglow {
  0%,100% { box-shadow:0 0 14px rgba(232,196,107,.12), 0 0 40px rgba(232,196,107,.06); }
  50% { box-shadow:0 0 44px rgba(232,196,107,.45), 0 0 90px rgba(232,196,107,.22); }
}
@media (prefers-reduced-motion: reduce) {
  .plogo .pc { animation:none; opacity:1; transform:none; }
  .plogo::after { animation:none; }
}

/* legal pages (privacy) — readable, no uppercase */
.legal { max-width:640px; margin:0 auto; padding:10px 24px 44px; text-transform:none; }
.legal h1 { font-family:Georgia,'Times New Roman',serif; font-weight:600; letter-spacing:.18em; font-size:24px; text-transform:uppercase;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.legal .meta { font-size:10px; letter-spacing:.16em; color:#7a8190; text-transform:uppercase; margin:8px 0 22px; }
.legal h2 { font-size:13px; letter-spacing:.12em; color:var(--gold); text-transform:uppercase; margin:26px 0 8px; }
.legal p, .legal li { font-size:13px; line-height:1.85; color:#c9cdc8; }
.legal ul { padding-left:20px; }
.legal strong { color:var(--text); }
.legal a { color:var(--gold); }
.legal a:hover { text-decoration:underline; }

/* what's new */
.wn-wrap { max-width:560px; margin:0 auto; padding:6px 22px 40px; }
.wn-row { display:flex; gap:14px; padding:12px 4px; border-bottom:1px solid rgba(201,164,71,.18); align-items:flex-start; }
.wn-pill { display:inline-block; background:rgba(244,220,156,.12); border:1px solid rgba(201,164,71,.45); color:var(--gold);
  font-size:9px; letter-spacing:.1em; padding:3px 10px; border-radius:999px; white-space:nowrap; }
.wn-note { display:block; font-size:11px; letter-spacing:.04em; color:var(--text); text-transform:none; line-height:1.7; }
.wn-date { display:block; font-size:8px; letter-spacing:.12em; color:#5a626d; margin-top:3px; }
.wn-more { display:block; margin:18px auto 0; background:none; border:1px solid var(--gold-line); color:var(--gold);
  border-radius:999px; padding:9px 22px; font-size:9px; letter-spacing:.14em; cursor:pointer; text-transform:uppercase; }
.wn-more:hover { background:rgba(244,220,156,.08); }

/* winner cinematics — ported from in-game CSS, contained + looping (5s cycle) */
.cin-stage { position:relative; border-radius:14px; overflow:hidden; background:#0c0b09; min-height:240px; }
.cin-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; animation: cinw-fade 5s ease-out infinite; }
@keyframes cinw-fade { 0%{opacity:0;} 9%{opacity:1;} 51%{opacity:1;} 60%{opacity:0;} 100%{opacity:0;} }
.cinbg-ofc     { background:radial-gradient(ellipse at center, rgba(232,196,107,.35), rgba(0,0,0,.85) 70%); }
.cinbg-rummy   { background:radial-gradient(ellipse at center, rgba(232,196,107,.55), rgba(98,210,125,.22) 42%, rgba(40,15,18,.97) 78%); }
.cinbg-scala40 { background:radial-gradient(ellipse at center, rgba(26,39,66,.6), rgba(0,0,0,.85)); }
.cinbg-palace  { background:radial-gradient(ellipse at center, rgba(232,196,107,.45), rgba(98,210,125,.2) 42%, rgba(15,30,18,.96) 78%); }
.cin-title { font-family:Georgia,'Times New Roman',serif; font-weight:900; color:#fff; text-align:center; line-height:1; animation: cinw-zoom 5s ease-out infinite; }
@keyframes cinw-zoom {
  0% { transform:scale(.5) rotate(-4deg); opacity:0; }
  12% { transform:scale(1.15) rotate(2deg); opacity:1; }
  48% { transform:scale(1) rotate(0); opacity:1; }
  60% { transform:scale(1.4) rotate(-1deg); opacity:0; }
  100% { transform:scale(1.4) rotate(-1deg); opacity:0; }
}
.cin-title.t-ofc     { letter-spacing:.2em;  font-size:42px; text-shadow:0 0 40px rgba(232,196,107,.9),0 0 80px rgba(232,196,107,.6),0 4px 12px rgba(0,0,0,.7); }
.cin-title.t-rummy   { letter-spacing:.18em; font-size:40px; animation-name: cinw-zoom-pop; text-shadow:0 0 36px rgba(232,196,107,.95),0 0 72px rgba(98,210,125,.55),0 4px 12px rgba(0,0,0,.7); }
.cin-title.t-scala40 { letter-spacing:.16em; font-size:42px; color:#f4dc9c; text-shadow:0 0 30px rgba(232,196,107,.9); }
.cin-title.t-palace  { letter-spacing:.2em;  font-size:42px; text-shadow:0 0 40px rgba(232,196,107,.95),0 0 80px rgba(98,210,125,.55),0 4px 12px rgba(0,0,0,.7); }
@keyframes cinw-zoom-pop {
  0% { transform:scale(.4); opacity:0; }
  14% { transform:scale(1.06); opacity:1; }
  28% { transform:scale(1); }
  51% { transform:scale(1); opacity:1; }
  60% { opacity:0; }
  100% { opacity:0; }
}
.cin-sub { display:block; font-size:13px; letter-spacing:.4em; margin-top:12px; text-shadow:0 2px 6px rgba(0,0,0,.6); text-transform:uppercase; }
.cin-sub.s-gold  { color:#f4dc9c; }
.cin-sub.s-good  { color:#62d27d; font-family:-apple-system,'Segoe UI',sans-serif; font-weight:600; letter-spacing:.36em; font-size:12px; }
.cin-spark { position:absolute; width:7px; height:7px; border-radius:50%; animation: cin-tw 2.4s ease-in-out infinite; }
.cin-spark.g  { background:radial-gradient(circle, #e8c46b 0%, rgba(232,196,107,0) 70%); }
.cin-spark.gn { background:radial-gradient(circle, #62d27d 0%, rgba(98,210,125,0) 70%); }
@keyframes cin-tw { 0%,100%{opacity:0; transform:scale(.6);} 30%{opacity:1; transform:scale(1.3);} 60%{opacity:.8; transform:scale(1);} }
.cin-caption { text-align:center; font-size:9px; letter-spacing:.12em; color:var(--muted); margin:14px auto 0; line-height:1.9; max-width:440px; }
@media (prefers-reduced-motion: reduce) { .cin-overlay, .cin-title { animation:none; opacity:1; } .cin-spark { animation:none; opacity:.7; } }

/* what's new v2 — compact accordion */
.wn-acc { border-bottom:1px solid rgba(201,164,71,.18); }
.wn-head { display:flex; align-items:center; gap:12px; padding:13px 4px; cursor:pointer; background:none; border:none; width:100%; text-align:left; font-family:inherit; text-transform:uppercase; }
.wn-head:hover .wn-pill { background:rgba(244,220,156,.22); }
.wn-head .wn-date { margin:0; flex:1; }
.wn-chev { color:#5a626d; font-size:12px; transition:transform .18s ease; }
.wn-acc.open .wn-chev { transform:rotate(90deg); color:var(--gold); }
.wn-body { display:none; padding:0 4px 14px 4px; }
.wn-acc.open .wn-body { display:block; }

/* header logo — looping mini fly-in (land, rest, dissolve, repeat) */
.plm-box { display:block; width:26px; height:24px; overflow:visible; }
.plm { display:block; position:relative; width:116px; height:105px; transform:scale(.2241); transform-origin:top left; }
.plm .pcm {
  position:absolute; width:17.8px; height:24.5px; border-radius:3.3px;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b); border:1px solid #c9a447;
  opacity:0; animation: pfly-loop 10s cubic-bezier(.2,.8,.25,1) infinite;
}
@keyframes pfly-loop {
  0% { opacity:0; transform:translate(var(--fx),var(--fy)) rotate(var(--fr)) scale(.55); }
  3% { opacity:1; }
  5.5% { opacity:1; transform:translate(0,0) rotate(0deg) scale(1); }
  91% { opacity:1; transform:translate(0,0) rotate(0deg) scale(1); }
  96% { opacity:0; transform:translate(0,0) rotate(0deg) scale(.85); }
  100% { opacity:0; transform:translate(var(--fx),var(--fy)) rotate(var(--fr)) scale(.55); }
}
@media (prefers-reduced-motion: reduce) {
  .plm .pcm { animation:none; opacity:1; transform:none; }
}
/* hero wordmark under the animated logo */
.hero-wordmark {
  font-family:Georgia,'Times New Roman',serif; font-weight:600; letter-spacing:.3em;
  font-size:19px; margin-top:18px;
  background:linear-gradient(160deg,#f4dc9c,#e8c46b);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  opacity:0; animation: wm-fade .7s ease-out 1.3s forwards;
}
@keyframes wm-fade { to { opacity:1; } }
@media (prefers-reduced-motion: reduce) { .hero-wordmark { animation:none; opacity:1; } }

/* per-variant icon idle animations — timings/values from App.js .variant-card-ico,
   composed with --tilt so tilted watermark icons keep their static rotation */
@keyframes vcw-cards    { 0%,100% { transform:rotate(calc(var(--tilt,0deg) - 3deg)); } 50% { transform:rotate(calc(var(--tilt,0deg) + 3deg)); } }
@keyframes vcw-heart    { 0%,8%,30%,100% { transform:rotate(var(--tilt,0deg)) scale(1); } 14% { transform:rotate(var(--tilt,0deg)) scale(1.20); } 22% { transform:rotate(var(--tilt,0deg)) scale(.96); } }
@keyframes vcw-stack    { 0%,100% { transform:rotate(var(--tilt,0deg)) translateY(0); } 50% { transform:rotate(var(--tilt,0deg)) translateY(-4px); } }
@keyframes vcw-grid     { 0%,100% { transform:rotate(var(--tilt,0deg)); } 50% { transform:rotate(calc(var(--tilt,0deg) + 8deg)); } }
@keyframes vcw-stairs   { 0%,100% { transform:rotate(var(--tilt,0deg)) translate(-2px,2px); } 50% { transform:rotate(var(--tilt,0deg)) translate(2px,-2px); } }
@keyframes vcw-cards-fl { 0%,100% { transform:rotate(var(--tilt,0deg)) translateY(0); } 50% { transform:rotate(calc(var(--tilt,0deg) - 2deg)) translateY(-3px); } }
.v-ofc .big-ico, .v-ofc .big-ico-left, .stat-row.v-ofc .sr-name i             { animation: vcw-cards    2.2s ease-in-out infinite; transform-origin:center; will-change:transform; }
.v-rummy .big-ico, .v-rummy .big-ico-left, .stat-row.v-rummy .sr-name i       { animation: vcw-grid     2.6s ease-in-out infinite; transform-origin:center; will-change:transform; }
.v-solitaire .big-ico, .v-solitaire .big-ico-left, .stat-row.v-solitaire .sr-name i { animation: vcw-cards-fl 2.4s ease-in-out infinite; transform-origin:center; will-change:transform; }
.v-scala40 .big-ico, .v-scala40 .big-ico-left, .stat-row.v-scala40 .sr-name i { animation: vcw-stairs   2.4s ease-in-out infinite; transform-origin:center; will-change:transform; }
.v-palace .big-ico, .v-palace .big-ico-left, .stat-row.v-palace .sr-name i    { animation: vcw-stack    2.4s ease-in-out infinite; transform-origin:center; will-change:transform; }
.v-hearts .big-ico, .v-hearts .big-ico-left, .stat-row.v-hearts .sr-name i    { animation: vcw-heart    1.6s ease-in-out infinite; transform-origin:center; will-change:transform; }
.bento-card.flagship .big-ico { --tilt:8deg; }
.takeover .big-ico { --tilt:10deg; }
.takeover .big-ico-left { --tilt:-12deg; }
@media (prefers-reduced-motion: reduce) {
  .big-ico, .big-ico-left, .stat-row .sr-name i { animation:none !important; }
}

