/* PlayCroco Casino AU — playful billabong design system, redesign pass 2026-06-09.
   Fredoka display + Nunito body. Deep green body, orange sunset hero, vivid green accent.
   Design discipline: white headings + ONE structural accent (green); orange owns the hero
   + the "claim bonus" CTA; gold is decoration only (coins), never body/heading text. */

:root {
  /* greens — light = more elevated, for zone depth */
  --bg: #0b3a2d;
  --bg-deep: #082821;
  --panel: #0f4435;          /* full-width recessed/alt band */
  --surface: #134d3c;        /* card */
  --surface-hi: #1a6048;     /* elevated card / hover */
  --line: #1c5942;
  --line-hi: #2a7a5c;
  /* brand */
  --green: #34c759;
  --green-deep: #169a44;
  --green-soft: rgba(52,199,89,.14);
  /* warm — hero + bonus CTA */
  --orange: #ff8b2d;
  --orange-deep: #ec6712;
  --sun-1: #f4762c;          /* hero gradient sampled from hero-croc.webp */
  --sun-2: #e85a23;
  --gold: #ffd23f;           /* coins only */
  /* ink */
  --ink: #f4fbf7;
  --ink-soft: #c2ddcd;
  --ink-dim: #7ea895;
  --red: #ff6b6b;
  /* type + shape */
  --font-display: 'Fredoka', 'Trebuchet MS', sans-serif;
  --font-body: 'Nunito', system-ui, sans-serif;
  --r-sm: 12px; --r: 18px; --r-lg: 26px; --pill: 999px;
  --shadow: 0 18px 44px rgba(0,0,0,.34);
  --shadow-sm: 0 8px 22px rgba(0,0,0,.26);
  --max: 1140px;
  /* z-index scale */
  --z-sticky: 60; --z-stickybar: 90;
  --ease-out: cubic-bezier(.22,1,.36,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-body); font-size: 16px; line-height: 1.65;
  color: var(--ink); background: var(--bg-deep);
  -webkit-font-smoothing: antialiased;
  padding-bottom: 76px;
}
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.1; margin: 0 0 14px; color: var(--ink); letter-spacing: -.01em; text-wrap: balance; }
h1 { font-size: clamp(2.2rem, 5.4vw, 3.5rem); font-weight: 700; }
h2 { font-size: clamp(1.55rem, 3.4vw, 2.2rem); }
h3 { font-size: 1.2rem; }
p { margin: 0 0 16px; color: var(--ink-soft); max-width: 70ch; text-wrap: pretty; }
a { color: var(--green); text-decoration: none; transition: color .15s; }
a:hover { color: #5fe07d; }
strong { color: var(--ink); font-weight: 800; }
img, svg { max-width: 100%; display: block; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 20px; }

/* inline icon sizing */
.i { width: 1.15em; height: 1.15em; flex: 0 0 auto; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ---------- buttons ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family: var(--font-display); font-weight:600; font-size:1.02rem;
  padding: 14px 30px; border-radius: var(--pill); border: none; cursor: pointer; text-decoration: none; transition: transform .14s var(--ease-out), box-shadow .14s var(--ease-out), filter .14s; }
.btn-green { background: var(--green); color: #06291d; box-shadow: 0 6px 0 var(--green-deep); }
.btn-green:hover { transform: translateY(-2px); box-shadow: 0 8px 0 var(--green-deep); color:#06291d; filter:brightness(1.05); }
.btn-green:active { transform: translateY(2px); box-shadow: 0 3px 0 var(--green-deep); }
.btn-orange { background: var(--orange); color: #3a1900; box-shadow: 0 6px 0 var(--orange-deep); }
.btn-orange:hover { transform: translateY(-2px); box-shadow: 0 8px 0 var(--orange-deep); color:#3a1900; filter:brightness(1.05); }
.btn-orange:active { transform: translateY(2px); box-shadow: 0 3px 0 var(--orange-deep); }
.btn-ghost { background: rgba(255,255,255,.04); color: var(--ink); border: 2px solid var(--line-hi); }
.btn-ghost:hover { border-color: var(--green); color: var(--green); transform: translateY(-2px); }
.btn-sm { padding: 9px 18px; font-size: .9rem; }
.btn-lg { padding: 17px 36px; font-size: 1.1rem; }

/* ---------- promo top bar ---------- */
.promo { background: linear-gradient(90deg, var(--green-deep), var(--green)); color:#06291d; font-family: var(--font-display); font-weight:600; }
.promo .wrap { display:flex; align-items:center; justify-content:center; gap:12px; padding: 8px 20px; flex-wrap:wrap; font-size:.95rem; }
.promo .code { background:#06291d; color: var(--gold); padding: 2px 10px; border-radius: var(--pill); letter-spacing:.05em; }

/* ---------- header ---------- */
.site-header { position: sticky; top:0; z-index: var(--z-sticky); background: rgba(8,40,33,.82); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.site-header .wrap { position:relative; display:flex; align-items:center; gap:18px; padding: 12px 20px; }
.logo { font-family: var(--font-display); font-weight:700; font-size: 1.5rem; display:inline-flex; align-items:center; gap:8px; color: var(--ink); }
.logo .c-croco { color: var(--green); }
.logo .c-dot { color: var(--orange); }
.nav { display:flex; align-items:center; gap:2px; margin-left:10px; font-family: var(--font-display); font-weight:500; }
.nav > a, .nav-trigger { color: var(--ink-soft); font-size:.97rem; font-family:inherit; font-weight:500; background:none; border:none; cursor:pointer; padding:8px 11px; border-radius:10px; display:inline-flex; align-items:center; gap:5px; line-height:1; }
.nav > a:hover, .nav-trigger:hover, .nav > a.active, .nav-trigger.active { color: var(--green); }
.nav-item { position:relative; }
.nav-trigger .caret { width:11px; height:11px; transition:transform .2s var(--ease-out); }
.nav-item.open .nav-trigger .caret { transform:rotate(180deg); }
.nav-menu { position:absolute; top:calc(100% + 6px); left:0; min-width:212px; background:var(--surface-hi); border:1px solid var(--line-hi); border-radius:14px; padding:7px; box-shadow:var(--shadow); display:none; flex-direction:column; gap:1px; z-index:70; }
.nav-item.open .nav-menu { display:flex; }
.nav-menu a { color:var(--ink-soft); font-size:.93rem; padding:9px 12px; border-radius:9px; white-space:nowrap; }
.nav-menu a:hover, .nav-menu a.active { background:var(--green-soft); color:var(--green); }
.header-cta { margin-left:auto; display:flex; gap:10px; }
.nav-toggle { display:none; background:none; border:1px solid var(--line-hi); border-radius:10px; padding:7px 9px; cursor:pointer; color:var(--ink); }
.nav-toggle svg { width:22px; height:22px; display:block; }
@media (hover:hover) and (min-width:881px) { .nav-item:hover .nav-menu { display:flex; } .nav-item:hover .nav-trigger .caret { transform:rotate(180deg); } }

/* ---------- hero (warm sunset zone, croc bled in) ---------- */
.hero { position: relative; overflow: hidden; isolation: isolate;
  background:
    radial-gradient(120% 90% at 78% 24%, #ffb35e 0%, var(--sun-1) 34%, var(--sun-2) 72%, #d8501e 100%); }
/* the bled-in croc art: sits right, melts into the gradient via a left-edge mask */
.hero-art { position:absolute; z-index:-1; right: -2%; bottom: 0; top: 0; width: 60%;
  background: url('/images/hero-croc.webp') no-repeat right bottom / cover;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 26%, #000 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 26%, #000 100%); }
/* fade the warm hero into the green body at the bottom seam */
.hero::after { content:''; position:absolute; left:0; right:0; bottom:0; height:90px; z-index:-1;
  background: linear-gradient(180deg, transparent, var(--bg-deep)); }
.hero .wrap { position:relative; padding: 56px 20px 70px; max-width: var(--max); }
.hero-copy { max-width: 560px; }
.hero-tag { display:inline-flex; align-items:center; gap:8px; background: rgba(0,0,0,.22); color:#fff; font-family:var(--font-display); font-weight:500; font-size:.82rem; padding:6px 14px; border-radius:var(--pill); margin-bottom:18px; }
.hero h1 { color:#fff; text-shadow: 0 2px 18px rgba(120,40,0,.35); margin-bottom:10px; }
.hero h1 .hl { color: #082821; }
.hero-offer { font-family: var(--font-display); font-weight:600; font-size: clamp(1.3rem,3vw,1.85rem); color:#fff; line-height:1.12; margin: 0 0 8px; max-width:30ch; }
.hero-offer b { color:#082821; }
.hero-sub { color: rgba(255,255,255,.92); font-size:1.04rem; max-width: 44ch; margin-bottom: 22px; }
.hero-sub strong { color:#fff; }
.hero-cta { display:flex; gap:12px; flex-wrap:wrap; margin-bottom: 18px; }
.hero .btn-ghost { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.6); color:#fff; }
.hero .btn-ghost:hover { background:#fff; color: var(--orange-deep); border-color:#fff; }
.rating { display:inline-flex; align-items:center; gap:10px; color:#fff; }
.rating .score { font-family: var(--font-display); font-weight:700; font-size:1.45rem; }
.rating .stars { color: var(--gold); letter-spacing:2px; filter: drop-shadow(0 1px 2px rgba(120,40,0,.4)); }
.rating .of { color: rgba(255,255,255,.85); font-size:.9rem; }

/* ---------- fact strip ---------- */
.facts-strip { background: var(--bg-deep); border-bottom:1px solid var(--line); }
.facts { display:flex; flex-wrap:wrap; gap:10px; padding: 18px 0; justify-content:center; }
.chip { display:inline-flex; align-items:center; gap:9px; background: var(--surface); border:1px solid var(--line); border-radius: var(--pill); padding: 9px 18px; font-family: var(--font-display); font-weight:500; font-size:.92rem; color: var(--ink-soft); }
.chip b { color: var(--ink); }
.chip .i { color: var(--green); width:18px; height:18px; }

/* ---------- sections + bands ---------- */
main { display:block; }
section { padding: 46px 0; }
.band { background: var(--panel); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.eyebrow { font-family: var(--font-display); text-transform: uppercase; letter-spacing:.12em; font-size:.78rem; color: var(--green); font-weight:600; display:block; margin-bottom: 8px; }
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); padding: 24px; }
.grid-2 { display:grid; grid-template-columns: repeat(2,1fr); gap:18px; }

/* ---------- no-deposit flagship (elevated green feature band) ---------- */
.nodep-band { position:relative; overflow:hidden; background:
   radial-gradient(90% 130% at 88% 50%, rgba(255,139,45,.20), transparent 60%),
   linear-gradient(135deg, var(--surface-hi), var(--surface)); }
.nodep { display:flex; align-items:center; gap:30px; padding: 8px 0; }
.nodep .mascot { width: 190px; height:auto; flex:0 0 auto; filter: drop-shadow(0 16px 26px rgba(0,0,0,.4)); align-self:flex-end; }
.nodep-body { flex:1; }
.nodep .kicker { font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; color: var(--orange); margin-bottom:8px; display:block; }
.nodep .big { font-family: var(--font-display); font-weight:700; font-size: clamp(1.7rem,4vw,2.5rem); color:#fff; line-height:1.05; margin-bottom:10px; }
.nodep p { color: var(--ink-soft); max-width: 58ch; }
.code-b { background:#06291d; color: var(--gold); padding: 3px 13px; border-radius: var(--pill); font-family: var(--font-display); font-weight:600; letter-spacing:.05em; white-space:nowrap; }
.nodep-cta { margin-top:18px; display:flex; gap:12px; flex-wrap:wrap; }

/* ---------- slots grid ---------- */
.slots-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); gap:14px; }
.slot-tile { position:relative; display:block; border-radius: var(--r-sm); overflow:hidden; border:1px solid var(--line); background: var(--surface); transition: transform .16s var(--ease-out), box-shadow .16s, border-color .16s; }
.slot-tile:hover { transform: translateY(-5px); box-shadow: var(--shadow-sm); border-color: var(--green); }
.slot-tile img { width:100%; aspect-ratio:1/1; object-fit:cover; }
.slot-tile .nm { display:block; padding:8px 10px; font-size:.78rem; color: var(--ink-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.slot-tile .ply { position:absolute; inset:0 0 32px 0; display:flex; align-items:center; justify-content:center; gap:6px; background: linear-gradient(180deg, rgba(8,40,32,.2), rgba(8,40,32,.72)); opacity:0; transition:opacity .16s; font-family: var(--font-display); font-weight:600; color:#fff; }
.slot-tile .ply .i { color: var(--green); }
.slot-tile:hover .ply { opacity:1; }

/* ---------- pros ---------- */
.pro { display:flex; gap:14px; align-items:flex-start; margin: 12px 0; }
.pro .tick { flex:0 0 auto; width:34px; height:34px; border-radius:50%; background: var(--green-soft); color: var(--green); display:flex; align-items:center; justify-content:center; }
.pro .tick.warn { background: rgba(255,107,107,.16); color: var(--red); }
.pro .tick .i { width:18px; height:18px; }
.pro h3 { margin-bottom:3px; font-size:1.05rem; }
.pro p { margin:0; font-size:.95rem; }
.card-head { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.card-head h3 { margin:0; font-size:1.15rem; }
.card-head .i { width:22px; height:22px; }
.card-head.good .i { color: var(--green); }
.card-head.warn .i { color: var(--orange); }

/* ---------- winners ticker ---------- */
.winners { background: var(--bg-deep); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; }
.winners-track { display:flex; gap:34px; padding: 12px 0; white-space:nowrap; animation: ticker 28s linear infinite; }
.winners-track span { font-family: var(--font-display); font-weight:500; color: var(--ink-soft); display:inline-flex; gap:8px; align-items:center; }
.winners-track .i { width:16px; height:16px; color: var(--green); }
.winners-track b { color: var(--ink); }

/* ---------- scorecard ---------- */
.score-row { display:flex; align-items:center; gap:14px; padding:11px 0; border-bottom:1px solid var(--line); }
.score-row:last-child { border:none; }
.score-row .lbl { width:170px; color: var(--ink-soft); font-size:.95rem; }
.score-row .bar { flex:1; height:9px; background: var(--bg-deep); border-radius: var(--pill); overflow:hidden; }
.score-row .bar i { display:block; height:100%; background: var(--green); border-radius: var(--pill); }
.score-row .val { width:40px; text-align:right; font-family: var(--font-display); font-weight:600; color: var(--ink); }
.bonus-figure { font-family: var(--font-display); font-weight:700; font-size: clamp(1.6rem,4vw,2.3rem); color:#fff; line-height:1; margin-bottom:6px; }

/* ---------- faq ---------- */
.faq details { background: var(--surface); border:1px solid var(--line); border-radius: var(--r); margin-bottom:10px; overflow:hidden; }
.faq summary { cursor:pointer; padding:16px 20px; font-family: var(--font-display); font-weight:500; list-style:none; color: var(--ink); display:flex; justify-content:space-between; align-items:center; gap:12px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; color: var(--green); font-weight:700; font-size:1.3rem; line-height:1; }
.faq details[open] summary::after { content:'\2212'; }
.faq .ans { padding: 0 20px 16px; }
.faq .ans p { margin:0; }

/* ---------- footer ---------- */
.site-footer { background: var(--bg-deep); border-top:1px solid var(--line); margin-top: 10px; padding: 40px 0 26px; }
.footer-grid { display:grid; grid-template-columns: 1.4fr repeat(3,1fr); gap:26px; }
.footer-grid h4 { font-family: var(--font-display); color: var(--green); font-size:.92rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px; }
.footer-grid a { display:block; color: var(--ink-dim); font-size:.92rem; padding:3px 0; }
.footer-grid a:hover { color: var(--green); }
.rg { margin-top:22px; padding-top:18px; border-top:1px solid var(--line); color: var(--ink-dim); font-size:.85rem; }
.rg strong { color: var(--ink); }

/* ---------- sticky cta ---------- */
.sticky-cta { position: fixed; left:0; right:0; bottom:0; z-index: var(--z-stickybar); display:flex; align-items:center; justify-content:center; gap:18px; padding:11px 16px;
  background: rgba(8,40,33,.96); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-top: 2px solid var(--orange); box-shadow: 0 -8px 28px rgba(0,0,0,.5); }
.sticky-cta__t { display:flex; flex-direction:column; line-height:1.2; font-family: var(--font-display); font-weight:600; font-size:14px; color:#fff; }
.sticky-cta__t b { color: var(--gold); }
.sticky-cta__t small { color: var(--ink-dim); font-weight:400; font-size:11px; }
.cta-glow { animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 0%,100%{filter:brightness(1)} 50%{filter:brightness(1.12)} }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ---------- inner pages ---------- */
.page-hero { position:relative; overflow:hidden;
  background: radial-gradient(120% 140% at 82% 12%, #ffb35e 0%, var(--sun-1) 38%, var(--sun-2) 78%, #d8501e 100%); }
.page-hero::after { content:''; position:absolute; left:0; right:0; bottom:0; height:70px; background: linear-gradient(180deg, transparent, var(--bg-deep)); }
.page-hero .wrap { position:relative; padding: 30px 20px 44px; }
.crumbs { font-size:.85rem; color: rgba(0,0,0,.55); font-weight:600; margin-bottom:14px; }
.crumbs a { color:#2a1400; }
.crumbs a:hover { color:#000; }
.page-hero h1 { color:#fff; text-shadow:0 2px 16px rgba(120,40,0,.3); margin-bottom:8px; max-width:18ch; }
.page-hero .lead { color:rgba(255,255,255,.95); font-size:1.1rem; max-width:60ch; margin-bottom:18px; }
.page-hero .lead strong { color:#fff; }
.page-hero .hero-cta .btn-ghost { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.6); color:#fff; }
.page-hero .hero-cta .btn-ghost:hover { background:#fff; color:var(--orange-deep); border-color:#fff; }

.prose h2 { margin-top:8px; }
.prose h3 { color:var(--ink); margin-top:22px; }
.prose ul, .prose ol { color: var(--ink-soft); padding-left:22px; margin:0 0 16px; max-width:70ch; }
.prose li { margin:6px 0; }
.prose li::marker { color: var(--green); }

.tldr { background: var(--surface); border:1px solid var(--line); border-left:none; border-radius: var(--r); padding:20px 24px; margin:0 0 26px; }
.tldr h2 { font-size:1.15rem; margin-bottom:10px; color:var(--green); }
.tldr ul { margin:0; }

.cta-band { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  background: radial-gradient(80% 130% at 90% 50%, rgba(255,139,45,.18), transparent 60%), linear-gradient(135deg, var(--surface-hi), var(--surface));
  border:1px solid var(--line); border-radius: var(--r-lg); padding:22px 26px; margin:28px 0; }
.cta-band .t { font-family:var(--font-display); font-weight:600; font-size:1.2rem; color:#fff; }
.cta-band .t small { display:block; font-weight:400; font-size:.92rem; color:var(--ink-soft); font-family:var(--font-body); margin-top:2px; }

.steps { counter-reset: step; list-style:none; padding:0; max-width:70ch; }
.steps li { position:relative; padding:4px 0 16px 52px; color:var(--ink-soft); }
.steps li::before { counter-increment: step; content: counter(step); position:absolute; left:0; top:0;
  width:34px; height:34px; border-radius:50%; background:var(--green-soft); color:var(--green);
  font-family:var(--font-display); font-weight:600; display:flex; align-items:center; justify-content:center; }
.steps li strong { display:block; color:var(--ink); margin-bottom:2px; }

.t-table { width:100%; border-collapse:collapse; margin:0 0 22px; font-size:.96rem; }
.t-table th, .t-table td { text-align:left; padding:12px 14px; border-bottom:1px solid var(--line); }
.t-table th { font-family:var(--font-display); color:var(--ink); font-weight:600; background:var(--surface); }
.t-table td { color:var(--ink-soft); }
.t-table tr:last-child td { border-bottom:none; }
.t-wrap { overflow-x:auto; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); margin-bottom:24px; }

/* ---------- entrance motion (enhances already-visible content) ---------- */
.rise { animation: rise .6s var(--ease-out) both; }
.rise.d1{animation-delay:.06s}.rise.d2{animation-delay:.14s}.rise.d3{animation-delay:.22s}.rise.d4{animation-delay:.3s}
@keyframes rise { from { opacity:0; transform: translateY(16px); } to { opacity:1; transform:none; } }

/* ---------- responsive ---------- */
@media (max-width: 880px) {
  .hero { background: linear-gradient(160deg, var(--sun-1), var(--sun-2) 70%, #cf4c1c); }
  .hero-art { position:relative; width:100%; height:230px; right:0; margin: 8px 0 -10px;
    -webkit-mask-image: linear-gradient(180deg,#000 60%, transparent); mask-image: linear-gradient(180deg,#000 60%, transparent); }
  .hero .wrap { padding: 34px 20px 44px; }
  .hero-copy { max-width:none; }
  .grid-2 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .header-cta .btn-ghost { display:none; }
  .nav-toggle { display:inline-flex; align-items:center; }
  .nav { position:absolute; top:100%; left:0; right:0; margin:0; flex-direction:column; align-items:stretch; gap:0; background:var(--bg-deep); border-bottom:1px solid var(--line); padding:6px 14px 14px; display:none; max-height:78vh; overflow:auto; box-shadow:var(--shadow); }
  .site-header.nav-open .nav { display:flex; }
  .nav > a, .nav-trigger { width:100%; justify-content:space-between; padding:13px 6px; font-size:1.03rem; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-item { position:static; }
  .nav-menu { position:static; display:none; min-width:0; border:none; background:transparent; box-shadow:none; padding:2px 0 8px 16px; }
  .nav-item.open .nav-menu { display:flex; }
  .nav-menu a { padding:9px 8px; }
  .nodep { flex-direction:column; text-align:center; gap:14px; }
  .nodep .mascot { width:140px; align-self:center; }
  .nodep p { margin-left:auto; margin-right:auto; }
  .nodep-cta { justify-content:center; }
  .score-row .lbl { width:130px; }
}
@media (prefers-reduced-motion: reduce) {
  .rise, .cta-glow, .winners-track { animation: none !important; }
  .rise { opacity:1; transform:none; }
}
