/* Stardust Stakes — $5 Deposit Casinos Canada
   Theme: Prairie Spruce. Custom CSS, no framework. */

:root {
  --nav-bg: #14342B;
  --body-bg: #F7F4EC;
  --surface: #FFFFFF;
  --heading: #14241F;
  --ink: #243027;
  --ink-soft: #4A554C;
  --accent: #1F6F5C;
  --accent-press: #185847;
  --flare: #A8431F;
  --flare-soft: #FBEFE7;
  --border: #DCD5C4;
  --mist: #EEEADD;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body: "Inter Tight", system-ui, -apple-system, "Segoe UI", sans-serif;

  --r-card: 10px;
  --r-chip: 6px;
  --r-pill: 999px;

  --shadow-1: 0 1px 2px rgba(20,36,31,.06);
  --shadow-2: 0 10px 30px -12px rgba(20,52,43,.18);

  --wrap: 1080px;
  --pad-band: clamp(2.75rem, 1.8rem + 4vw, 5.5rem);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--body-bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: clamp(1rem, .96rem + .2vw, 1.08rem);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--heading);
  line-height: 1.12;
  font-weight: 600;
  margin: 0 0 .5em;
  letter-spacing: -.01em;
}

p { margin: 0 0 1.1rem; }
a { color: var(--accent); text-underline-offset: 3px; }
a:hover { color: var(--accent-press); }
strong { color: var(--heading); font-weight: 600; }

.wrap { width: min(100% - 2.5rem, var(--wrap)); margin-inline: auto; }
.narrow { width: min(100% - 2.5rem, 760px); margin-inline: auto; }

.band { padding-block: var(--pad-band); }
.band--tint { background: var(--mist); }
.band--spruce { background: var(--nav-bg); color: #EAF1ED; }
.band--spruce h2, .band--spruce h3 { color: #fff; }

.eyebrow {
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .72rem;
  font-weight: 700;
  color: var(--accent);
  margin: 0 0 .9rem;
}
.band--spruce .eyebrow { color: #8FD3BE; }

h2 { font-size: clamp(1.6rem, 1.25rem + 1.4vw, 2.35rem); margin-top: 0; }
h3 { font-size: clamp(1.2rem, 1.05rem + .6vw, 1.5rem); }
h4 { font-size: 1.08rem; font-family: var(--font-body); font-weight: 700; color: var(--heading); }

/* ---------- header / nav ---------- */
.site-head { background: var(--nav-bg); position: sticky; top: 0; z-index: 50; }
.site-head__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-block: .85rem;
}
.brand { display: inline-flex; align-items: center; }
.brand img { height: 38px; width: auto; display: block; }
.brand--light .lf { fill: #fff; }

.nav { display: flex; align-items: center; gap: .35rem; }
.nav__link {
  color: #DCE8E2; text-decoration: none; font-weight: 500;
  font-size: .95rem; padding: .5rem .8rem; border-radius: var(--r-chip);
  transition: background .15s, color .15s;
}
.nav__link:hover, .nav__link[aria-current="page"] { background: rgba(255,255,255,.1); color: #fff; }

.nav__toggle {
  display: none; background: none; border: 1px solid rgba(255,255,255,.3);
  border-radius: var(--r-chip); width: 44px; height: 40px; cursor: pointer;
}
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after {
  display: block; position: relative; width: 20px; height: 2px; background: #fff; margin: 0 auto;
  content: "";
}
.nav__toggle span::before { position: absolute; top: -6px; }
.nav__toggle span::after { position: absolute; top: 6px; }

@media (max-width: 820px) {
  .nav__toggle { display: block; }
  .nav {
    position: absolute; inset: 64px 0 auto; flex-direction: column; align-items: stretch;
    background: var(--nav-bg); padding: .6rem 1.25rem 1.1rem; gap: .15rem;
    border-top: 1px solid rgba(255,255,255,.12); display: none;
  }
  .nav.is-open { display: flex; }
  .nav__link { padding: .7rem .6rem; }
}

/* ---------- hero (editorial / Pattern B) ---------- */
.lede { padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem) clamp(1.5rem,1rem+2vw,2.5rem); }
.lede__title { font-size: clamp(2.3rem, 1.5rem + 4.2vw, 4.1rem); max-width: 16ch; }
.lede__title .flare { color: var(--flare); font-style: italic; }
.lede__sub { font-size: clamp(1.08rem, 1rem + .5vw, 1.3rem); color: var(--ink-soft); max-width: 60ch; }
.lede__meta {
  display: flex; flex-wrap: wrap; gap: .4rem 1.2rem; align-items: center;
  margin-top: 1.4rem; font-size: .9rem; color: var(--ink-soft);
  border-top: 1px solid var(--border); padding-top: 1.1rem;
}
.lede__meta .byline { font-weight: 600; color: var(--heading); }

.trustrip { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.4rem; }
.trustrip__item {
  display: inline-flex; align-items: center; gap: .45rem;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-pill);
  padding: .4rem .9rem; font-size: .82rem; font-weight: 600; color: var(--heading);
  box-shadow: var(--shadow-1);
}
.trustrip__item .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  font-family: var(--font-body); font-weight: 700; font-size: .95rem;
  border-radius: var(--r-pill); padding: .72rem 1.4rem; text-decoration: none;
  cursor: pointer; border: 2px solid transparent; transition: transform .12s, background .15s, box-shadow .15s;
  white-space: nowrap;
}
.btn--primary { background: var(--accent); color: #fff; box-shadow: var(--shadow-1); }
.btn--primary:hover { background: var(--accent-press); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-2); }
.btn--ghost { border-color: var(--accent); color: var(--accent); background: transparent; }
.btn--ghost:hover { background: var(--accent); color: #fff; }
.btn--flare { background: var(--flare); color: #fff; }
.btn--flare:hover { background: #8f3819; color:#fff; transform: translateY(-1px); }

/* ---------- rankings: featured top pick + ladder (Pattern F) ---------- */
.toppick {
  display: grid; grid-template-columns: auto 1fr auto; gap: clamp(1rem,2vw,2rem);
  align-items: center; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-card); padding: clamp(1.2rem,2vw,2rem); box-shadow: var(--shadow-2);
  position: relative; overflow: hidden;
}
.toppick::before { content:""; position:absolute; inset:0 auto 0 0; width:6px; background: var(--flare); }
.toppick__rank { text-align: center; padding-left: .4rem; }
.toppick__rank .num { font-family: var(--font-display); font-size: 2.6rem; color: var(--flare); line-height: 1; }
.toppick__rank .lab { display:block; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-soft); font-weight:700; }
.toppick__body h3 { margin-bottom: .35rem; }
.toppick__body .offer { font-size: 1.18rem; color: var(--heading); font-weight: 600; margin: 0 0 .35rem; }
.toppick__body .meta { color: var(--ink-soft); font-size: .92rem; margin: 0; }
.toppick__cta { text-align: center; display: grid; gap: .5rem; }
.toppick__cta .code { font-size: .78rem; color: var(--ink-soft); }
.toppick__cta .code b { color: var(--flare); font-family: var(--font-body); letter-spacing: .04em; }

.ladder { margin-top: 1.1rem; display: grid; gap: .7rem; }
.ladder__row {
  display: grid; grid-template-columns: 44px minmax(0,1fr) minmax(0,auto) max-content; align-items: center; gap: 1rem 1.25rem;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-card);
  padding: .9rem 1.1rem; box-shadow: var(--shadow-1); transition: box-shadow .15s, transform .12s;
}
.ladder__row:hover { box-shadow: var(--shadow-2); transform: translateY(-1px); }
.ladder__rank { font-family: var(--font-display); font-size: 1.5rem; color: var(--accent); text-align: center; }
.ladder__name { font-weight: 700; color: var(--heading); }
.ladder__name small { display: block; font-weight: 500; color: var(--ink-soft); font-size: .82rem; }
.ladder__offer { color: var(--ink-soft); font-size: .9rem; text-align: right; }
.ladder__cta { white-space: nowrap; }
@media (max-width: 720px) {
  .toppick { grid-template-columns: auto 1fr; }
  .toppick__cta { grid-column: 1 / -1; }
  .ladder__row { grid-template-columns: 36px 1fr; }
  .ladder__offer { display: none; }
  .ladder__cta { grid-column: 2; justify-self: start; }
}

/* ---------- tables ---------- */
.scrollx { overflow-x: auto; border-radius: var(--r-card); border: 1px solid var(--border); box-shadow: var(--shadow-1); }
table.gridtable { border-collapse: collapse; width: 100%; background: var(--surface); font-size: .94rem; min-width: 560px; }
.gridtable th, .gridtable td { padding: .8rem 1rem; text-align: left; border-bottom: 1px solid var(--border); }
.gridtable thead th { background: var(--nav-bg); color: #EAF1ED; font-family: var(--font-body); font-weight: 600; letter-spacing: .02em; }
.gridtable tbody tr:nth-child(even) { background: #FCFAF4; }
.gridtable tbody tr:hover { background: var(--flare-soft); }
.gridtable code { background: var(--mist); padding: .1rem .4rem; border-radius: 4px; font-weight: 600; color: var(--flare); }

/* ---------- reviews: zigzag (Pattern B) ---------- */
.review {
  display: grid; grid-template-columns: 320px 1fr; gap: clamp(1rem,3vw,2.4rem);
  align-items: start; padding-block: clamp(1.6rem,3vw,2.6rem); border-bottom: 1px solid var(--border);
}
.review:last-child { border-bottom: 0; }
.review--flip .review__panel { order: 2; }
.review__panel {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-card);
  padding: 1.3rem 1.4rem; box-shadow: var(--shadow-1); position: sticky; top: 88px;
}
.review__panel .rk { display:flex; align-items:baseline; gap:.5rem; margin-bottom:.4rem; }
.review__panel .rk .n { font-family: var(--font-display); font-size: 1.4rem; color: var(--flare); }
.review__panel .rk .bestfor { font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; color:var(--accent); font-weight:700; }
.review__panel h3 { font-size: 1.25rem; margin-bottom: .5rem; }
.review__panel .offer { font-weight: 600; color: var(--heading); margin-bottom: .9rem; font-size: .98rem; }
.tags { margin: 0 0 1rem; padding: 0; list-style: none; font-size: .88rem; display: grid; gap: .35rem; }
.tags .good::before { content: "✓"; color: var(--accent); font-weight: 800; margin-right: .5rem; }
.tags .watch::before { content: "!"; color: var(--flare); font-weight: 800; margin-right: .55rem; }
.review__prose h3 { margin-top: .2rem; }
@media (max-width: 760px) {
  .review { grid-template-columns: 1fr; }
  .review--flip .review__panel { order: 0; }
  .review__panel { position: static; }
}

/* ---------- callout note ---------- */
.note {
  background: var(--flare-soft); border-left: 4px solid var(--flare);
  border-radius: var(--r-chip); padding: 1.1rem 1.3rem; margin: 1.4rem 0;
}
.note p:last-child { margin-bottom: 0; }

/* ---------- chips / pills ---------- */
.chip { display:inline-block; background: var(--mist); color: var(--heading); border-radius: var(--r-chip); padding:.2rem .6rem; font-size:.78rem; font-weight:600; }
.chip--top { background: var(--flare); color:#fff; }

/* ---------- FAQ (native details) ---------- */
.qa { border: 1px solid var(--border); border-radius: var(--r-card); background: var(--surface); margin-bottom: .7rem; overflow: hidden; }
.qa summary {
  cursor: pointer; list-style: none; padding: 1rem 1.2rem; font-weight: 600; color: var(--heading);
  font-family: var(--font-display); font-size: 1.05rem; display: flex; justify-content: space-between; gap: 1rem; align-items: center;
}
.qa summary::-webkit-details-marker { display: none; }
.qa summary::after { content: "+"; color: var(--accent); font-size: 1.4rem; font-weight: 400; transition: transform .2s; }
.qa[open] summary::after { transform: rotate(45deg); }
.qa__a { padding: 0 1.2rem 1.1rem; color: var(--ink); }
.qa__a p:last-child { margin-bottom: 0; }

/* lists */
.checks { list-style: none; padding: 0; margin: 1rem 0; display: grid; gap: .55rem; }
.checks li { padding-left: 1.7rem; position: relative; }
.checks li::before { content: "★"; position: absolute; left: 0; color: var(--flare); }

.prose ul { padding-left: 1.2rem; }
.prose li { margin-bottom: .5rem; }

/* team / values grids */
.cards3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1.4rem; }
.tcard { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-card); padding: 1.4rem; box-shadow: var(--shadow-1); }
.tcard .ava {
  width: 56px; height: 56px; border-radius: 50%; background: var(--nav-bg); color: #fff;
  display: grid; place-items: center; font-family: var(--font-display); font-size: 1.3rem; margin-bottom: .9rem;
}
.tcard .role { color: var(--accent); font-weight: 700; margin: 0 0 .15rem; font-size: .92rem; }
.tcard .cred { color: var(--ink-soft); font-size: .82rem; margin: 0 0 .8rem; }

/* breadcrumb */
.crumb { font-size: .85rem; color: var(--ink-soft); padding-block: .9rem; }
.crumb a { text-decoration: none; }

/* contact */
.field { display: block; margin-bottom: 1rem; }
.field label { display:block; font-weight:600; color: var(--heading); margin-bottom:.3rem; font-size:.92rem; }
.field input, .field textarea {
  width: 100%; padding: .75rem .9rem; border: 1px solid var(--border); border-radius: var(--r-chip);
  font-family: var(--font-body); font-size: 1rem; background: var(--surface); color: var(--ink);
}
.field input:focus, .field textarea:focus { outline: 2px solid var(--accent); border-color: var(--accent); }

/* ---------- footer (3-col, Pattern differs from template) ---------- */
.foot { background: var(--nav-bg); color: #C7D6CF; padding-block: clamp(2.5rem,4vw,3.5rem) 0; font-size: .92rem; }
.foot a { color: #DCE8E2; text-decoration: none; }
.foot a:hover { color: #fff; text-decoration: underline; }
.foot__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.foot__brand .lf { fill:#fff; }
.foot h4 { color: #fff; font-family: var(--font-body); letter-spacing: .04em; text-transform: uppercase; font-size: .78rem; margin-bottom: .9rem; }
.foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.disclosure { border-top: 1px solid rgba(255,255,255,.14); margin-top: 2.2rem; padding: 1.4rem 0; font-size: .8rem; color: #9FB3AB; }
.copy { border-top: 1px solid rgba(255,255,255,.14); padding: 1.1rem 0; font-size: .82rem; color: #9FB3AB; text-align: center; }
.hidden-addr { font-size: 0; color: var(--nav-bg); }
@media (max-width: 720px) { .foot__grid { grid-template-columns: 1fr; gap: 1.6rem; } }

/* utilities */
.mt0 { margin-top: 0; } .center { text-align: center; }
.lead-block { font-size: 1.12rem; color: var(--ink-soft); }
