/* Design Reminder: Art Deco Revival with contemporary luxury editorial design. Every style decision should reinforce midnight navy depth, emerald felt tactility, champagne gold linework, cream editorial readability, and restrained adult-facing motion. */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=Source+Sans+3:wght@400;500;600;700;800&display=swap');


:root {
  --navy: #071220;
  --navy-2: #0d1b2e;
  --emerald: #0d5a43;
  --emerald-2: #083b31;
  --gold: #d8b66b;
  --gold-2: #f1d899;
  --cream: #f5eddf;
  --cream-2: #fff9ee;
  --ink: #102033;
  --muted: #6d756f;
  --danger: #c96f50;
  --success: #88c89a;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--navy);
  color: var(--cream);
  font-family: 'Source Sans 3', system-ui, sans-serif;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input { font: inherit; }

.site-shell { min-height: 100vh; background: radial-gradient(circle at 20% 0%, rgba(216,182,107,.16), transparent 34%), linear-gradient(135deg, #071220 0%, #0b1828 46%, #071220 100%); }
.container { width: min(1180px, calc(100% - 36px)); margin-inline: auto; }
.header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(18px); background: rgba(7,18,32,.82); border-bottom: 1px solid rgba(216,182,107,.22); }
.nav { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.logo { display: flex; align-items: center; gap: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.logo-mark { width: 40px; height: 40px; border: 1px solid var(--gold); display: grid; place-items: center; color: var(--gold-2); background: linear-gradient(135deg, rgba(13,90,67,.9), rgba(7,18,32,.9)); box-shadow: inset 0 0 0 4px rgba(216,182,107,.08); }
.nav-links { display: flex; align-items: center; gap: 18px; font-size: .92rem; color: rgba(245,237,223,.86); }
.nav-links a { padding: 8px 0; border-bottom: 1px solid transparent; transition: color .2s ease, border-color .2s ease; }
.nav-links a:hover { color: var(--gold-2); border-color: rgba(216,182,107,.65); }
.age-pill { border: 1px solid rgba(216,182,107,.45); color: var(--gold-2); padding: 8px 12px; background: rgba(216,182,107,.08); font-weight: 700; }

.hero { position: relative; min-height: 720px; display: grid; align-items: stretch; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; opacity: .66; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(7,18,32,.98) 0%, rgba(7,18,32,.82) 42%, rgba(7,18,32,.35) 100%); }
.hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr .75fr; gap: 60px; align-items: center; padding: 96px 0; }
.eyebrow { color: var(--gold-2); letter-spacing: .22em; text-transform: uppercase; font-weight: 800; font-size: .78rem; }
h1, h2, h3 { font-family: 'Playfair Display', Georgia, serif; line-height: .96; margin: 0; }
h1 { font-size: clamp(4rem, 10vw, 8.6rem); letter-spacing: -.06em; max-width: 820px; }
h2 { font-size: clamp(2.55rem, 5vw, 5.2rem); letter-spacing: -.045em; }
h3 { font-size: clamp(1.6rem, 2.4vw, 2.25rem); letter-spacing: -.025em; }
p { line-height: 1.72; font-size: 1.08rem; color: rgba(245,237,223,.82); }
.lead { max-width: 670px; font-size: 1.28rem; color: rgba(245,237,223,.9); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.btn { border: 1px solid rgba(216,182,107,.55); padding: 14px 21px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; transition: transform .2s ease, background .2s ease, color .2s ease; }
.btn-primary { background: var(--gold); color: #071220; }
.btn-secondary { background: rgba(7,18,32,.3); color: var(--cream); }
.btn:hover { transform: translateY(-2px); }
.hero-card { border: 1px solid rgba(216,182,107,.33); background: linear-gradient(180deg, rgba(8,59,49,.82), rgba(7,18,32,.82)); padding: 28px; box-shadow: 0 30px 90px rgba(0,0,0,.34); }
.disclaimer-box { border-left: 3px solid var(--gold); padding: 18px 20px; background: rgba(245,237,223,.08); margin-top: 24px; }
.disclaimer-box strong { color: var(--gold-2); }

.section { padding: 96px 0; position: relative; }
.section-cream { background: var(--cream); color: var(--ink); }
.section-cream p { color: #384534; }
.section-title { display: grid; grid-template-columns: .82fr 1fr; gap: 50px; align-items: end; margin-bottom: 42px; }
.gold-rule { height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); margin: 28px 0; }
.article-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
.article-card { grid-column: span 4; background: #fff9ee; color: var(--ink); border: 1px solid rgba(16,32,51,.12); box-shadow: 0 24px 70px rgba(7,18,32,.12); transition: transform .22s ease, box-shadow .22s ease; }
.article-card:nth-child(1), .article-card:nth-child(6) { grid-column: span 6; }
.article-card:hover { transform: translateY(-6px); box-shadow: 0 34px 90px rgba(7,18,32,.18); }
.article-card img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
.article-card-content { padding: 24px; }
.kicker { display: inline-flex; color: var(--emerald); font-weight: 800; letter-spacing: .16em; text-transform: uppercase; font-size: .72rem; margin-bottom: 12px; }
.article-card p, .legal-page p, .article-page p { color: #384534; }

.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 52px; align-items: center; }
.framed-img { border: 1px solid rgba(216,182,107,.36); padding: 12px; background: rgba(216,182,107,.08); box-shadow: 0 30px 90px rgba(0,0,0,.28); }
.framed-img img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.panel { border: 1px solid rgba(216,182,107,.28); padding: 32px; background: rgba(245,237,223,.075); }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 24px; }
.stat { border: 1px solid rgba(216,182,107,.25); padding: 18px; background: rgba(7,18,32,.22); }
.stat strong { display: block; color: var(--gold-2); font-size: 1.7rem; }

.game-shell { background: linear-gradient(135deg, #06131f, #0b2a25); border: 1px solid rgba(216,182,107,.32); padding: 26px; box-shadow: 0 30px 90px rgba(0,0,0,.34); }
.game-top { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; align-items: center; }
.balance { color: var(--gold-2); font-size: 1.55rem; font-weight: 900; font-variant-numeric: tabular-nums; }
.cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin: 22px 0; }
.card { min-height: 154px; border-radius: 0; border: 1px solid rgba(216,182,107,.42); background: #fff9ee; color: #071220; display: grid; place-items: center; position: relative; box-shadow: 0 14px 28px rgba(0,0,0,.23); }
.card.held { outline: 3px solid var(--gold); transform: translateY(-5px); }
.card-rank { font-family: 'Playfair Display'; font-size: 2.7rem; font-weight: 800; }
.card-suit { position: absolute; bottom: 12px; right: 14px; font-size: 1.7rem; }
.red { color: #a12b2b; }
.controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.controls button { border: 1px solid rgba(216,182,107,.5); background: rgba(216,182,107,.1); color: var(--cream); padding: 11px 14px; font-weight: 800; }
.controls button.active, .controls button.primary { background: var(--gold); color: #071220; }
.controls button:disabled { opacity: .5; cursor: not-allowed; }
.paytable { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 18px; }
.payitem { background: rgba(245,237,223,.08); border: 1px solid rgba(216,182,107,.18); padding: 12px; font-size: .92rem; }

.newsletter { display: grid; grid-template-columns: 1fr .9fr; gap: 40px; align-items: stretch; }
.form-card { background: #fff9ee; color: var(--ink); padding: 34px; border: 1px solid rgba(16,32,51,.12); }
.form-card input { width: 100%; padding: 15px; border: 1px solid rgba(16,32,51,.22); margin: 10px 0 14px; background: white; color: var(--ink); }
.form-card button { width: 100%; background: var(--emerald); color: white; border: 0; padding: 15px; font-weight: 900; text-transform: uppercase; }
.success { color: var(--emerald); font-weight: 800; }

.article-page, .legal-page { background: var(--cream); color: var(--ink); min-height: 100vh; }
.article-hero { padding: 72px 0 42px; }
.article-hero img { width: 100%; aspect-ratio: 16/7; object-fit: cover; border: 1px solid rgba(16,32,51,.12); margin-top: 30px; }
.article-body, .legal-body { width: min(830px, calc(100% - 36px)); margin: 0 auto; padding: 38px 0 92px; }
.article-body p, .legal-body p { font-size: 1.18rem; color: #29382f; }
.article-body h2, .legal-body h2 { font-size: 2.2rem; margin-top: 40px; color: #102033; }
.policy-list { display: grid; gap: 18px; margin: 24px 0; }
.policy-list div { padding: 22px; border-left: 3px solid var(--gold); background: rgba(255,249,238,.75); }

.footer { background: #050e18; border-top: 1px solid rgba(216,182,107,.24); padding: 60px 0 36px; color: rgba(245,237,223,.75); }
.footer-grid { display: grid; grid-template-columns: 1.1fr .8fr .8fr; gap: 40px; }
.footer a { display: block; margin: 8px 0; color: rgba(245,237,223,.84); }
.small { font-size: .92rem; color: rgba(245,237,223,.66); }
.compliance-strip { background: rgba(201,111,80,.15); border-block: 1px solid rgba(201,111,80,.32); color: #ffd9cf; padding: 12px 0; font-weight: 800; text-align: center; }

@keyframes rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
.reveal { animation: rise .7s ease both; }

@media (max-width: 860px) {
  .nav { align-items: flex-start; padding: 16px 0; }
  .nav-links { display: none; }
  .hero { min-height: auto; }
  .hero-inner, .section-title, .split, .newsletter, .footer-grid { grid-template-columns: 1fr; }
  h1 { font-size: clamp(3.2rem, 17vw, 5.8rem); }
  .article-card, .article-card:nth-child(1), .article-card:nth-child(6) { grid-column: span 12; }
  .cards { grid-template-columns: repeat(5, minmax(54px, 1fr)); gap: 7px; }
  .card { min-height: 104px; }
  .card-rank { font-size: 1.8rem; }
  .card-suit { font-size: 1.2rem; }
  .paytable, .stats { grid-template-columns: 1fr; }
}

.article-card h3 a:hover,.footer a:hover{color:var(--gold-2)}.skip-link{position:absolute;left:-999px}.skip-link:focus{left:16px;top:16px;z-index:100;background:var(--gold);color:#071220;padding:10px 14px}.article-body a,.legal-body a{color:#0d5a43;text-decoration:underline}.game-shell button{cursor:pointer}.generated-note{font-size:.86rem;color:rgba(245,237,223,.62)}