/* ==========================================================================
   CSSRC US — Design System
   Editorial-luxury iGaming review platform.
   Sections: 1 Tokens · 2 Reset · 3 Typography · 4 Layout · 5 Buttons/Pills
   6 Header/Nav · 7 Cards · 8 Rating · 9 Tables · 10 Review · 11 Author
   12 Hero/Home · 13 Tools · 14 Footer · 15 Forms · 16 Utilities · 17 Motion
   18 Responsive
   ========================================================================== */

/* 1. DESIGN TOKENS ---------------------------------------------------------- */
:root {
	/* Brand */
	--wa-ink:        #0b1020;
	--wa-ink-2:      #131a30;
	--wa-royal:      #3d5afe;
	--wa-royal-2:    #6c7dff;
	--wa-emerald:    #13a36b;
	--wa-emerald-2:  #1ec98a;
	--wa-gold:       #e3b23c;
	--wa-gold-2:     #f6cf6b;
	--wa-crimson:    #e4453a;
	--wa-amber:      #f59e0b;

	/* Light theme surfaces */
	--wa-bg:         #f4f5f9;
	--wa-surface:    #ffffff;
	--wa-surface-2:  #f8f9fc;
	--wa-surface-3:  #eef0f6;
	--wa-line:       #e2e6ef;
	--wa-line-2:     #d3d9e6;
	--wa-text:       #141a2b;
	--wa-text-soft:  #4a5268;
	--wa-text-mute:  #767f96;
	--wa-on-brand:   #ffffff;

	/* Gradients */
	--wa-grad-brand: linear-gradient(135deg, #3d5afe 0%, #6c7dff 50%, #13a36b 100%);
	--wa-grad-gold:  linear-gradient(135deg, #e3b23c 0%, #f6cf6b 100%);
	--wa-grad-ink:   linear-gradient(160deg, #0b1020 0%, #131a30 60%, #1b2444 100%);

	/* Radii */
	--wa-r-sm: 8px;
	--wa-r:    14px;
	--wa-r-lg: 22px;
	--wa-r-xl: 30px;
	--wa-r-pill: 999px;

	/* Shadows */
	--wa-shadow-sm: 0 1px 2px rgba(16,23,42,.06), 0 2px 6px rgba(16,23,42,.05);
	--wa-shadow:    0 6px 22px rgba(16,23,42,.09), 0 2px 6px rgba(16,23,42,.05);
	--wa-shadow-lg: 0 22px 60px rgba(16,23,42,.16), 0 8px 18px rgba(16,23,42,.08);
	--wa-ring:      0 0 0 3px rgba(61,90,254,.35);

	/* Type */
	--wa-font-sans: "Inter", "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;
	--wa-font-serif: "Source Serif 4", "Georgia", "Times New Roman", serif;
	--wa-fs-base: clamp(16px, 1rem + .15vw, 18px);

	/* Spacing scale */
	--wa-gap: clamp(16px, 2vw, 28px);
	--wa-shell: 1240px;
	--wa-shell-narrow: 820px;

	/* Header */
	--wa-header-h: 72px;

	color-scheme: light;
}

/* Dark theme */
[data-wa-theme="dark"] {
	--wa-bg:         #070b16;
	--wa-surface:    #0f1626;
	--wa-surface-2:  #131c30;
	--wa-surface-3:  #1a2440;
	--wa-line:       #243150;
	--wa-line-2:     #2e3c60;
	--wa-text:       #eef2fb;
	--wa-text-soft:  #aeb8d0;
	--wa-text-mute:  #7f8aa6;
	--wa-shadow-sm:  0 1px 2px rgba(0,0,0,.4);
	--wa-shadow:     0 8px 30px rgba(0,0,0,.45);
	--wa-shadow-lg:  0 26px 70px rgba(0,0,0,.6);
	color-scheme: dark;
}

/* Sepia / reading theme */
[data-wa-theme="sepia"] {
	--wa-bg:         #efe7d6;
	--wa-surface:    #faf3e4;
	--wa-surface-2:  #f3ebd9;
	--wa-surface-3:  #ece1c9;
	--wa-line:       #ddd0b3;
	--wa-line-2:     #ccbc98;
	--wa-text:       #2f2616;
	--wa-text-soft:  #5a4d34;
	--wa-text-mute:  #80714f;
	color-scheme: light;
}

/* Honour OS preference before JS sets a choice */
@media (prefers-color-scheme: dark) {
	:root:not([data-wa-theme]) {
		--wa-bg: #070b16; --wa-surface: #0f1626; --wa-surface-2: #131c30;
		--wa-surface-3: #1a2440; --wa-line: #243150; --wa-line-2: #2e3c60;
		--wa-text: #eef2fb; --wa-text-soft: #aeb8d0; --wa-text-mute: #7f8aa6;
		color-scheme: dark;
	}
}

/* 2. RESET ------------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
	font-family: var(--wa-font-sans);
	font-size: var(--wa-fs-base);
	line-height: 1.65;
	color: var(--wa-text);
	background: var(--wa-bg);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, picture, svg, video, canvas { max-width: 100%; display: block; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: var(--wa-royal); text-decoration: none; }
a:hover { text-decoration: underline; }
ul, ol { padding-left: 1.1em; }
hr { border: none; border-top: 1px solid var(--wa-line); margin: 2rem 0; }
:focus-visible { outline: none; box-shadow: var(--wa-ring); border-radius: 6px; }

/* 3. TYPOGRAPHY ------------------------------------------------------------- */
h1, h2, h3, h4, h5 { line-height: 1.18; font-weight: 800; letter-spacing: -.02em; color: var(--wa-text); }
h1 { font-size: clamp(2rem, 1.4rem + 2.6vw, 3.4rem); }
h2 { font-size: clamp(1.55rem, 1.2rem + 1.5vw, 2.3rem); }
h3 { font-size: clamp(1.2rem, 1.05rem + .7vw, 1.55rem); }
h4 { font-size: 1.12rem; }
p { margin: 0 0 1rem; }
strong { font-weight: 700; }
small { font-size: .82em; }
.wa-eyebrow {
	display: inline-flex; align-items: center; gap: .5em;
	font-size: .76rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
	color: var(--wa-royal);
}
.wa-lede { font-size: 1.18rem; color: var(--wa-text-soft); line-height: 1.6; }
.wa-prose { font-family: var(--wa-font-serif); font-size: 1.14rem; line-height: 1.78; color: var(--wa-text); }
.wa-prose h2, .wa-prose h3 { font-family: var(--wa-font-sans); margin: 2.2rem 0 .8rem; }
.wa-prose p { margin: 0 0 1.25rem; }
.wa-prose a { text-decoration: underline; text-underline-offset: 3px; }
.wa-prose blockquote {
	margin: 1.8rem 0; padding: 1rem 1.4rem; border-left: 4px solid var(--wa-gold);
	background: var(--wa-surface-2); border-radius: 0 var(--wa-r) var(--wa-r) 0;
	font-style: italic; color: var(--wa-text-soft);
}
.wa-prose ul, .wa-prose ol { margin: 0 0 1.3rem; }
.wa-prose li { margin-bottom: .5rem; }
.wa-prose img { border-radius: var(--wa-r); margin: 1.5rem 0; box-shadow: var(--wa-shadow); }

/* 4. LAYOUT ----------------------------------------------------------------- */
.wa-shell-x { width: min(100% - 2.4rem, var(--wa-shell)); margin-inline: auto; }
.wa-shell-narrow { width: min(100% - 2.4rem, var(--wa-shell-narrow)); margin-inline: auto; }
.wa-section { padding: clamp(2.5rem, 5vw, 4.5rem) 0; }
.wa-section--soft { background: var(--wa-surface-2); }
.wa-section--ink { background: var(--wa-grad-ink); color: #e9edfb; }
.wa-section--ink h1, .wa-section--ink h2, .wa-section--ink h3 { color: #fff; }
.wa-section__head { margin-bottom: clamp(1.4rem, 3vw, 2.4rem); }
.wa-section__head h2 { margin-bottom: .35rem; }
.wa-section__lede { color: var(--wa-text-soft); max-width: 60ch; }
.wa-stage { display: block; min-height: 40vh; }
.wa-grid { display: grid; gap: var(--wa-gap); }
.wa-grid--2 { grid-template-columns: repeat(2, 1fr); }
.wa-grid--3 { grid-template-columns: repeat(3, 1fr); }
.wa-grid--4 { grid-template-columns: repeat(4, 1fr); }
.wa-with-side { display: grid; grid-template-columns: minmax(0,1fr) 340px; gap: clamp(1.5rem, 3vw, 3rem); align-items: start; }

/* 5. BUTTONS / PILLS -------------------------------------------------------- */
.wa-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .5em;
	padding: .72em 1.3em; border-radius: var(--wa-r-pill); font-weight: 700;
	line-height: 1; text-decoration: none; cursor: pointer; border: 1.5px solid transparent;
	transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
	white-space: nowrap;
}
.wa-btn:hover { text-decoration: none; transform: translateY(-2px); }
.wa-btn:active { transform: translateY(0); }
.wa-btn--royal { background: var(--wa-royal); color: #fff; box-shadow: 0 8px 20px rgba(61,90,254,.32); }
.wa-btn--royal:hover { background: var(--wa-royal-2); }
.wa-btn--gold { background: var(--wa-grad-gold); color: #2a210a; box-shadow: 0 8px 20px rgba(227,178,60,.34); }
.wa-btn--emerald { background: var(--wa-emerald); color: #fff; box-shadow: 0 8px 20px rgba(19,163,107,.3); }
.wa-btn--emerald:hover { background: var(--wa-emerald-2); }
.wa-btn--ghost { background: var(--wa-surface); color: var(--wa-text); border-color: var(--wa-line-2); }
.wa-btn--ghost:hover { border-color: var(--wa-royal); color: var(--wa-royal); }
.wa-btn--outline { background: transparent; color: var(--wa-royal); border-color: currentColor; }
.wa-btn--lg { padding: .95em 1.7em; font-size: 1.05rem; }
.wa-btn--sm { padding: .5em .9em; font-size: .85rem; }
.wa-btn--block { display: flex; width: 100%; }
.wa-btn.is-disabled { opacity: .5; pointer-events: none; filter: grayscale(.4); }

.wa-pill {
	display: inline-flex; align-items: center; gap: .4em;
	padding: .32em .75em; border-radius: var(--wa-r-pill);
	font-size: .76rem; font-weight: 700; line-height: 1;
	background: var(--wa-surface-3); color: var(--wa-text-soft);
}
.wa-pill--royal { background: rgba(61,90,254,.12); color: var(--wa-royal); }
.wa-pill--emerald { background: rgba(19,163,107,.14); color: var(--wa-emerald); }
.wa-pill--gold { background: rgba(227,178,60,.16); color: #9a7616; }
.wa-pill--crimson { background: rgba(228,69,58,.13); color: var(--wa-crimson); }
.wa-pill--ghost { background: var(--wa-surface-2); border: 1px solid var(--wa-line); color: var(--wa-text-soft); }
[data-wa-theme="dark"] .wa-pill--gold { color: var(--wa-gold-2); }

/* --------------------------------------------------------------------
   Bonus "at a glance" stat cards (single-wa_bonus.php)
   ------------------------------------------------------------------ */
.wa-bonus-glance {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1rem;
	margin: 0;
}
.wa-bonus-stat {
	background: var(--wa-surface);
	border: 1px solid var(--wa-line);
	border-radius: var(--wa-r-lg);
	padding: 1.1rem 1.2rem;
	box-shadow: var(--wa-shadow-sm);
	display: flex;
	flex-direction: column;
	gap: .5rem;
}
.wa-bonus-stat__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 36px; height: 36px; border-radius: var(--wa-r-pill);
	background: rgba(61,90,254,.12); color: var(--wa-royal);
	flex: 0 0 auto;
}
.wa-bonus-stat__icon svg { width: 18px; height: 18px; }
.wa-bonus-stat--wager .wa-bonus-stat__icon { background: rgba(245,158,11,.14); color: var(--wa-amber); }
.wa-bonus-stat--deposit .wa-bonus-stat__icon { background: rgba(19,163,107,.14); color: var(--wa-emerald); }
.wa-bonus-stat--cashout .wa-bonus-stat__icon { background: rgba(61,90,254,.12); color: var(--wa-royal); }
.wa-bonus-stat--expiry .wa-bonus-stat__icon { background: rgba(228,69,58,.13); color: var(--wa-crimson); }
.wa-bonus-stat__label { font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--wa-text-mute); }
.wa-bonus-stat__value { font-size: 1.3rem; font-weight: 800; color: var(--wa-text); line-height: 1.15; }
.wa-bonus-stat__tag { align-self: flex-start; margin-top: -.1rem; }

/* Code chip: full-width, spans the grid, with copy button */
.wa-bonus-code {
	grid-column: 1 / -1;
	display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
	background: var(--wa-grad-ink);
	border-radius: var(--wa-r-lg);
	padding: 1.1rem 1.3rem;
	color: #fff;
}
.wa-bonus-code__info { display: flex; align-items: center; gap: .9rem; }
.wa-bonus-code__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: var(--wa-r-pill);
	background: rgba(255,255,255,.12); color: var(--wa-gold-2); flex: 0 0 auto;
}
.wa-bonus-code__icon svg { width: 20px; height: 20px; }
.wa-bonus-code__label { font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #b9c2dd; }
.wa-bonus-code__value { font-size: 1.2rem; font-weight: 800; letter-spacing: .04em; color: var(--wa-gold-2); font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace; }
.wa-bonus-code__copy {
	display: inline-flex; align-items: center; gap: .45em;
	background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); color: #fff;
	padding: .55em 1.1em; border-radius: var(--wa-r-pill); font-weight: 700; font-size: .85rem;
	cursor: pointer; transition: background .15s ease, border-color .15s ease;
}
.wa-bonus-code__copy:hover { background: rgba(255,255,255,.2); border-color: rgba(255,255,255,.4); }
.wa-bonus-code__copy svg { width: 15px; height: 15px; }
.wa-bonus-code__copy.is-copied { background: rgba(19,163,107,.3); border-color: rgba(19,163,107,.5); color: #b7f5d8; }
@media (max-width: 640px) {
	.wa-bonus-glance { grid-template-columns: repeat(2, 1fr); }
	.wa-bonus-code { flex-direction: column; align-items: flex-start; }
}

.wa-badge-verified {
	display: inline-flex; align-items: center; gap: .4em; font-weight: 700; font-size: .8rem;
	color: var(--wa-emerald);
}
.wa-badge-verified svg { width: 16px; height: 16px; }

/* 6. HEADER / NAV ----------------------------------------------------------- */
.wa-skip-link {
	position: absolute; left: -9999px; top: 0; z-index: 1000; padding: .8em 1.2em;
	background: var(--wa-ink); color: #fff; border-radius: 0 0 var(--wa-r) 0;
}
.wa-skip-link:focus { left: 0; }
#wa-progress { position: fixed; inset: 0 auto auto 0; height: 3px; width: 0; z-index: 999; background: var(--wa-grad-brand); transition: width .1s linear; }

.wa-alertbar { background: var(--wa-grad-ink); color: #e9edfb; font-size: .9rem; }
.wa-alertbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .55rem 0; }
.wa-alertbar a { color: var(--wa-gold-2); display: inline-flex; align-items: center; gap: .5em; font-weight: 600; }
.wa-alertbar__close { color: #aeb8d0; font-size: 1.3rem; line-height: 1; }

.wa-masthead {
	position: sticky; top: 0; z-index: 200; background: var(--wa-surface);
	border-bottom: 1px solid var(--wa-line);
}
/* NOTE: backdrop-filter is intentionally NOT on the base rule. A backdrop-filter
   turns the masthead into the containing block for its position:fixed children,
   which would clip the mobile nav drawer to the header height. We only add it on
   desktop (min-width:861px) where the nav is in normal flow, not fixed. */
@media (min-width: 861px) {
	.wa-masthead { -webkit-backdrop-filter: saturate(140%) blur(8px); backdrop-filter: saturate(140%) blur(8px); }
}
.wa-masthead.is-scrolled { box-shadow: var(--wa-shadow); }
.wa-masthead__inner { display: flex; align-items: center; gap: clamp(.5rem, 2vw, 1.2rem); height: var(--wa-header-h); min-width: 0; }
.wa-brand { display: inline-flex; align-items: center; gap: .55rem; font-weight: 900; font-size: clamp(1.05rem, .9rem + 1vw, 1.28rem); letter-spacing: -.03em; color: var(--wa-text); min-width: 0; flex-shrink: 0; }
.wa-brand:hover { text-decoration: none; }
.wa-brand__mark { width: 34px; height: 34px; flex: none; }
.wa-brand b { color: var(--wa-royal); }
.wa-brand__wordmark { white-space: nowrap; background: var(--wa-grad-brand); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

.wa-nav { margin-left: auto; min-width: 0; }
.wa-nav__extras { display: none; }
.wa-menu { list-style: none; display: flex; align-items: center; gap: .3rem; padding: 0; margin: 0; }
.wa-menu a { display: inline-flex; align-items: center; gap: .4em; padding: .55em .8em; border-radius: var(--wa-r-sm); font-weight: 600; font-size: .96rem; color: var(--wa-text-soft); }
.wa-menu > li > a:hover, .wa-menu .current-menu-item > a { color: var(--wa-text); background: var(--wa-surface-3); text-decoration: none; }
.wa-menu li { position: relative; }
.wa-menu .sub-menu {
	position: absolute; top: calc(100% + 8px); left: 0; min-width: 230px; list-style: none;
	background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r);
	box-shadow: var(--wa-shadow-lg); padding: .5rem; margin: 0; opacity: 0; visibility: hidden;
	transform: translateY(8px); transition: .18s ease; z-index: 50;
}
.wa-menu li:hover > .sub-menu, .wa-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.wa-menu .sub-menu a { display: block; padding: .55em .7em; color: var(--wa-text-soft); border-radius: var(--wa-r-sm); }
.wa-menu .sub-menu a:hover { background: var(--wa-surface-3); color: var(--wa-text); }

.wa-tools { display: flex; align-items: center; gap: .4rem; }
.wa-iconbtn {
	width: 42px; height: 42px; display: inline-grid; place-items: center; border-radius: var(--wa-r-sm);
	color: var(--wa-text-soft); border: 1px solid transparent; transition: .15s ease;
}
.wa-iconbtn:hover { background: var(--wa-surface-3); color: var(--wa-text); }
.wa-market-btn { width: auto; gap: .35em; padding: 0 .7em; font-weight: 700; font-size: .85rem; }
.wa-theme-btn .wa-icon-dark { display: none; }
[data-wa-theme="dark"] .wa-theme-btn .wa-icon-dark { display: block; }
[data-wa-theme="dark"] .wa-theme-btn .wa-icon-light { display: none; }

.wa-burger { display: none; width: 44px; height: 44px; flex-direction: column; gap: 5px; justify-content: center; align-items: center; border-radius: var(--wa-r-sm); }
.wa-burger span { width: 22px; height: 2px; background: var(--wa-text); border-radius: 2px; transition: .25s ease; }
.wa-nav__close { display: none; }

/* Spotlight search */
.wa-spotlight { background: var(--wa-surface); border-bottom: 1px solid var(--wa-line); box-shadow: var(--wa-shadow); }
.wa-spotlight[hidden] { display: none; }
.wa-spotlight__form { display: flex; gap: .6rem; padding: 1.1rem 0 .6rem; }
.wa-spotlight__form input { flex: 1; padding: .85em 1.1em; border-radius: var(--wa-r); border: 1.5px solid var(--wa-line-2); background: var(--wa-surface-2); }
.wa-spotlight__hits { padding-bottom: 1rem; display: grid; gap: .4rem; }
.wa-spotlight__hits a { display: flex; justify-content: space-between; gap: 1rem; padding: .6em .8em; border-radius: var(--wa-r-sm); color: var(--wa-text); }
.wa-spotlight__hits a:hover { background: var(--wa-surface-3); text-decoration: none; }
.wa-spotlight__hint { color: var(--wa-text-mute); font-size: .85rem; padding-bottom: 1rem; }

/* Market panel */
.wa-market-panel { background: var(--wa-surface); border-bottom: 1px solid var(--wa-line); }
.wa-market-panel[hidden] { display: none; }
.wa-market-panel > .wa-shell-x { padding: 1.1rem 0; }
.wa-market-panel__hint { color: var(--wa-text-mute); font-size: .85rem; margin: .3rem 0 .6rem; }
.wa-market-select { width: 100%; max-width: 420px; padding: .7em 1em; border-radius: var(--wa-r); border: 1.5px solid var(--wa-line-2); background: var(--wa-surface-2); }
.wa-nav-veil { position: fixed; inset: 0; background: rgba(7,11,22,.5); opacity: 0; visibility: hidden; transition: .25s ease; z-index: 150; }
.wa-nav-veil.is-open { opacity: 1; visibility: visible; }

/* 7. CARDS ------------------------------------------------------------------ */
.wa-card {
	background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg);
	box-shadow: var(--wa-shadow-sm); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
	display: flex; flex-direction: column;
}
.wa-card:hover { transform: translateY(-4px); box-shadow: var(--wa-shadow-lg); border-color: var(--wa-line-2); }
.wa-card__cover { position: relative; aspect-ratio: 16/10; background: var(--wa-surface-3); }
.wa-card__cover img { width: 100%; height: 100%; object-fit: cover; }
.wa-card__rank { position: absolute; top: 12px; left: 12px; width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-weight: 900; color: #2a210a; background: var(--wa-grad-gold); box-shadow: var(--wa-shadow); }
.wa-card__score-overlay { position: absolute; right: 12px; bottom: -26px; }
.wa-card__body { padding: 1.2rem 1.2rem .4rem; display: flex; flex-direction: column; gap: .7rem; flex: 1; }
.wa-card__head { display: flex; flex-direction: column; gap: .45rem; }
.wa-card__title { font-size: 1.18rem; }
.wa-card__title a { color: var(--wa-text); }
.wa-card__title a:hover { color: var(--wa-royal); text-decoration: none; }
.wa-card__sublabels { display: flex; flex-wrap: wrap; gap: .4rem; }
.wa-card__bonus { background: var(--wa-surface-2); border: 1px dashed var(--wa-line-2); border-radius: var(--wa-r); padding: .7rem .9rem; }
.wa-card__bonus small { display: block; color: var(--wa-text-mute); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; font-size: .68rem; }
.wa-card__bonus strong { font-size: 1.02rem; color: var(--wa-text); }
.wa-card__wager { display: inline-block; margin-top: .25rem; font-size: .78rem; color: var(--wa-text-mute); }
.wa-card__pros { list-style: none; padding: 0; margin: 0; display: grid; gap: .35rem; }
.wa-card__pros li { position: relative; padding-left: 1.5em; font-size: .9rem; color: var(--wa-text-soft); }
.wa-card__pros li::before { content: "✓"; position: absolute; left: 0; color: var(--wa-emerald); font-weight: 800; }
.wa-card__market { display: flex; align-items: center; gap: .5em; font-size: .82rem; padding: .4rem .6rem; border-radius: var(--wa-r-sm); }
.wa-card__market.is-allowed { background: rgba(19,163,107,.1); color: var(--wa-emerald); }
.wa-card__market.is-blocked { background: rgba(228,69,58,.1); color: var(--wa-crimson); }
.wa-card__cta { padding: 1rem 1.2rem 1.2rem; display: grid; gap: .5rem; }
.wa-card__read { text-align: center; font-size: .88rem; font-weight: 600; color: var(--wa-text-soft); }
.wa-card__compare { font-size: .82rem; color: var(--wa-text-mute); border: 1px dashed var(--wa-line-2); border-radius: var(--wa-r-pill); padding: .4em; }
.wa-card__compare:hover { color: var(--wa-royal); border-color: var(--wa-royal); }
.wa-card__compare.is-active { background: rgba(61,90,254,.1); color: var(--wa-royal); border-style: solid; }

/* Horizontal review row (toplists) */
.wa-row {
	display: grid; grid-template-columns: 56px minmax(0,2.2fr) minmax(0,1.6fr) 96px minmax(160px,1fr);
	align-items: center; gap: 1rem; background: var(--wa-surface); border: 1px solid var(--wa-line);
	border-radius: var(--wa-r-lg); padding: 1rem 1.2rem; box-shadow: var(--wa-shadow-sm); transition: .2s ease;
}
.wa-row:hover { box-shadow: var(--wa-shadow); border-color: var(--wa-line-2); }
.wa-row__rank { font-size: 1.5rem; font-weight: 900; color: var(--wa-text-mute); text-align: center; }
.wa-row__rank.is-top { background: var(--wa-grad-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.wa-row__brand { display: flex; flex-direction: column; gap: .35rem; min-width: 0; }
.wa-row__brand h3 { font-size: 1.1rem; }
.wa-row__brand h3 a { color: var(--wa-text); }
.wa-row__bonus small { display: block; color: var(--wa-text-mute); font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 700; }
.wa-row__bonus strong { font-size: .98rem; }
.wa-row__terms { font-size: .72rem; color: var(--wa-text-mute); }
.wa-row__cta { display: grid; gap: .4rem; }

/* 8. RATING ----------------------------------------------------------------- */
.wa-ring { position: relative; display: inline-grid; place-items: center; }
.wa-ring svg { transform: rotate(-90deg); overflow: visible; }
.wa-ring__track { fill: none; stroke: var(--wa-surface-3); opacity: .9; }
[data-wa-theme="dark"] .wa-ring__track,
.wa-ring--ink .wa-ring__track { stroke: rgba(255,255,255,.12); }
.wa-ring__bar { fill: none; stroke-linecap: round; transition: stroke-dashoffset 1.1s cubic-bezier(.22,1,.36,1); }
.wa-ring__val {
	position: absolute; inset: 0; display: flex; flex-direction: column;
	align-items: center; justify-content: center; line-height: .95; color: var(--wa-text);
	font-variant-numeric: tabular-nums;
}
.wa-ring__val b { font-size: 1.55em; font-weight: 900; letter-spacing: -.02em; }
.wa-ring__val span { font-size: .62em; font-weight: 700; margin-top: .15em; color: var(--wa-text-mute); }
/* Band-tinted score number for an attractive, meaningful look */
.wa-ring--high .wa-ring__val b { color: #0fbf7a; }
.wa-ring--mid  .wa-ring__val b { color: #d49a16; }
.wa-ring--low  .wa-ring__val b { color: #e4453a; }
[data-wa-theme="dark"] .wa-ring--mid .wa-ring__val b { color: #ffd874; }
.wa-ring--ink .wa-ring__val,
.wa-ring--ink .wa-ring__val b { color: #fff; }
.wa-ring--ink .wa-ring__val span { color: rgba(255,255,255,.6); }
.wa-ring--ink.wa-ring--high .wa-ring__val b { color: #34e0a1; }
.wa-ring--ink.wa-ring--mid  .wa-ring__val b { color: #ffd874; }
.wa-ring--ink.wa-ring--low  .wa-ring__val b { color: #ff8a7a; }

.wa-pillars { display: grid; gap: .9rem; }
.wa-pillar { display: grid; grid-template-columns: 150px 1fr 48px; align-items: center; gap: 1rem; }
.wa-pillar__label { font-weight: 600; font-size: .92rem; color: var(--wa-text-soft); }
.wa-pillar__track { height: 10px; border-radius: var(--wa-r-pill); background: var(--wa-surface-3); overflow: hidden; }
.wa-pillar__fill { height: 100%; border-radius: inherit; background: var(--wa-grad-brand); transform-origin: left; animation: wa-grow 1s ease forwards; }
.wa-pillar__score { font-weight: 800; text-align: right; }

.wa-trust { display: flex; align-items: center; gap: 1rem; padding: 1.1rem 1.3rem; border-radius: var(--wa-r-lg); background: var(--wa-surface-2); border: 1px solid var(--wa-line); }
.wa-trust__gauge { width: 64px; height: 64px; flex: none; border-radius: 50%; display: grid; place-items: center; font-weight: 900; color: #fff; }
.wa-trust__gauge.is-high { background: var(--wa-emerald); }
.wa-trust__gauge.is-mid { background: var(--wa-gold); color: #2a210a; }
.wa-trust__gauge.is-low { background: var(--wa-crimson); }
.wa-trust__meta strong { display: block; font-size: 1.05rem; }
.wa-trust__meta span { color: var(--wa-text-mute); font-size: .85rem; }

.wa-stars { display: inline-flex; gap: 2px; color: var(--wa-gold); }
.wa-stars svg { width: 18px; height: 18px; }

/* 9. TABLES (comparison) ---------------------------------------------------- */
.wa-table-wrap { overflow-x: auto; border-radius: var(--wa-r-lg); border: 1px solid var(--wa-line); box-shadow: var(--wa-shadow-sm); }
.wa-table { width: 100%; border-collapse: collapse; background: var(--wa-surface); min-width: 640px; }
.wa-table th, .wa-table td { padding: .85rem 1rem; text-align: left; border-bottom: 1px solid var(--wa-line); }
.wa-table thead th { background: var(--wa-surface-2); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; color: var(--wa-text-mute); position: sticky; top: 0; }
.wa-table thead th:not(:first-child) { text-align: center; }
.wa-table tbody tr:last-child td { border-bottom: none; }
.wa-table tbody tr:hover { background: var(--wa-surface-2); }
.wa-table td:first-child { font-weight: 700; color: var(--wa-text-mute); font-size: .85rem; white-space: nowrap; }
.wa-table td:not(:first-child) { text-align: center; }
/* Casino name header cells in compare table */
.wa-table thead th a { color: var(--wa-text); font-size: .92rem; font-weight: 800; text-transform: none; letter-spacing: 0; display: block; margin-bottom: .4rem; }
.wa-table thead th .wa-btn { margin-top: .3rem; }

/* 10. SINGLE REVIEW --------------------------------------------------------- */
.wa-review__hero { background: var(--wa-grad-ink); color: #e9edfb; padding: clamp(1.6rem, 3vw, 2.6rem) 0 clamp(2rem,4vw,3rem); }
.wa-review__hero h1 { color: #fff; }
.wa-review__hero-grid { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: clamp(1.5rem,3vw,3rem); align-items: center; margin-top: 1rem; }
.wa-review__market { display: inline-flex; align-items: center; gap: .5em; padding: .35em .8em; border-radius: var(--wa-r-pill); font-size: .82rem; font-weight: 700; margin-bottom: .8rem; }
.wa-review__market.is-allowed { background: rgba(19,163,107,.22); color: #4be3a4; }
.wa-review__market.is-blocked { background: rgba(228,69,58,.22); color: #ff8a80; }
.wa-review__strap { color: #b9c2dd; font-size: 1.12rem; max-width: 56ch; }
.wa-review__signals { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1rem 0; }
.wa-review__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-top: 1.2rem; }
.wa-review__bonus { background: rgba(255,255,255,.08); border: 1px dashed rgba(255,255,255,.3); border-radius: var(--wa-r); padding: .65rem 1rem; }
.wa-review__bonus small { display: block; color: #b9c2dd; font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; }
.wa-review__bonus strong { color: var(--wa-gold-2); font-size: 1.1rem; }
.wa-review__terms { color: #8893b3; width: 100%; }
.wa-review__hero-aside { text-align: center; }
.wa-review__verdict-label { margin-top: .6rem; font-weight: 700; color: var(--wa-gold-2); }
.wa-review__body { min-width: 0; }
.wa-review__body > section { margin-bottom: 2.4rem; }

.wa-tldr { background: var(--wa-surface-2); border: 1px solid var(--wa-line); border-left: 4px solid var(--wa-royal); border-radius: 0 var(--wa-r) var(--wa-r) 0; padding: 1.2rem 1.4rem; }
.wa-tldr h2 { font-size: 1.1rem; margin-bottom: .6rem; }
.wa-tldr ul { margin: 0; padding-left: 1.2em; }
.wa-tldr li { margin-bottom: .4rem; }

.wa-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.wa-proscons__col { border-radius: var(--wa-r-lg); padding: 1.2rem 1.3rem; border: 1px solid var(--wa-line); }
.wa-proscons__col--pro { background: rgba(19,163,107,.07); border-color: rgba(19,163,107,.3); }
.wa-proscons__col--con { background: rgba(228,69,58,.06); border-color: rgba(228,69,58,.28); }
.wa-proscons h3 { display: flex; align-items: center; gap: .5em; font-size: 1.05rem; margin-bottom: .7rem; }
.wa-proscons ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.wa-proscons li { position: relative; padding-left: 1.7em; color: var(--wa-text-soft); font-size: .95rem; }
.wa-proscons__col--pro li::before { content: "＋"; position: absolute; left: 0; color: var(--wa-emerald); font-weight: 800; }
.wa-proscons__col--con li::before { content: "−"; position: absolute; left: 0; color: var(--wa-crimson); font-weight: 800; }

.wa-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg); overflow: hidden; }
.wa-facts__row { display: grid; grid-template-columns: 1fr 1fr; }
.wa-facts dt { padding: .7rem 1rem; background: var(--wa-surface-2); font-weight: 600; color: var(--wa-text-soft); border-bottom: 1px solid var(--wa-line); }
.wa-facts dd { padding: .7rem 1rem; margin: 0; border-bottom: 1px solid var(--wa-line); }

.wa-verdict { background: var(--wa-surface-2); border-radius: var(--wa-r-lg); padding: 1.4rem 1.6rem; border-left: 4px solid var(--wa-gold); }

.wa-pulse-rate__stars { display: inline-flex; gap: .2rem; font-size: 2rem; line-height: 1; }
.wa-pulse-rate__star { color: var(--wa-line-2); transition: color .12s ease; }
.wa-pulse-rate__star:hover, .wa-pulse-rate__star.is-on { color: var(--wa-gold); }
.wa-pulse-rate__msg { color: var(--wa-emerald); font-weight: 600; margin-top: .4rem; min-height: 1.4em; }

.wa-toc { position: sticky; top: calc(var(--wa-header-h) + 16px); }
.wa-warning { background: rgba(245,158,11,.12); border: 1px solid rgba(245,158,11,.35); border-radius: var(--wa-r); padding: .9rem 1.1rem; color: #9a6b00; font-size: .92rem; }
[data-wa-theme="dark"] .wa-warning { color: var(--wa-amber); }

/* 11. AUTHOR (E-E-A-T) ------------------------------------------------------ */
.wa-byline {
	display: flex; align-items: center; gap: .9rem; flex-wrap: wrap;
	padding: .9rem 1.1rem;
	margin: 1.2rem 0 0;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: var(--wa-r-lg);
	backdrop-filter: blur(2px);
}
.wa-byline__avatar {
	width: 46px; height: 46px;
	border-radius: 50%;
	object-fit: cover;
	padding: 2px;
	background: var(--wa-grad-gold);
	border: none;
	box-shadow: 0 0 0 1px rgba(255,255,255,.15);
}
.wa-byline__meta { font-size: .9rem; line-height: 1.45; }
.wa-byline__meta strong { color: #fff; font-weight: 800; letter-spacing: -.01em; }
.wa-byline__meta span { color: #c2cbe6; }
.wa-byline__sep { color: rgba(255,255,255,.35); margin: 0 .15rem; }
/* Light-background variant (casino reviews, game pages) */
.wa-byline--light .wa-byline__meta strong { color: var(--wa-text, #111827); }
.wa-byline--light .wa-byline__meta strong a { color: var(--wa-royal, #3b5bdb); }
.wa-byline--light .wa-byline__meta span { color: var(--wa-text-mute, #6b7280); }
.wa-byline--light .wa-byline__sep { color: var(--wa-line, #d1d5db); }
.wa-byline__factcheck { margin-left: auto; }

/* Author box layout now lives in magazine.css (single source for the
 * block + template part). The rules formerly here targeted an older
 * markup shape and were conflicting with it (e.g. forcing a 2-column
 * grid onto .wa-author-box, which pushed the badge list on top of the
 * avatar/name instead of below it). */

/* E-E-A-T trust box (posts, guides, pages) */
.wa-eeat { background: var(--wa-surface-2); border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg); padding: 1rem 1.2rem; margin: 0 0 1.8rem; }
.wa-eeat__people { display: flex; flex-wrap: wrap; gap: 1rem 1.8rem; align-items: center; }
.wa-eeat__person { display: flex; align-items: center; gap: .6rem; }
.wa-eeat__avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; border: 2px solid var(--wa-gold); }
.wa-eeat__check, .wa-eeat__clock { width: 36px; height: 36px; flex: none; display: grid; place-items: center; border-radius: 50%; background: var(--wa-surface-3); }
.wa-eeat__check { color: var(--wa-emerald); }
.wa-eeat__clock { color: var(--wa-royal); }
.wa-eeat__person span { display: flex; flex-direction: column; line-height: 1.3; }
.wa-eeat__person small { color: var(--wa-text-mute); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.wa-eeat__person a { font-weight: 700; color: var(--wa-text); }
.wa-eeat__person a:hover { color: var(--wa-royal); }
.wa-eeat__person em { color: var(--wa-text-mute); font-size: .8rem; font-style: normal; }
.wa-eeat__person time { font-weight: 700; color: var(--wa-text); }
.wa-eeat__note { display: flex; align-items: center; gap: .5em; margin: .9rem 0 0; padding-top: .8rem; border-top: 1px dashed var(--wa-line-2); font-size: .85rem; color: var(--wa-text-soft); }
.wa-eeat__note svg { color: var(--wa-emerald); flex: none; }

/* Taxonomy / category landing pages */
.wa-tax-intro { font-size: 1.12rem; color: var(--wa-text-soft); line-height: 1.7; max-width: 70ch; }
.wa-tax-body { margin-top: 2.5rem; }
.wa-tax-body .wa-prose { max-width: none; }
.wa-list-head { display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap; margin: 1.5rem 0 1rem; }
.wa-list-head h2 { margin: 0; }
.wa-list-head span { color: var(--wa-text-mute); font-size: .9rem; }

/* 12. HERO / HOME ----------------------------------------------------------- */
.wa-hero { background: var(--wa-grad-ink); color: #e9edfb; position: relative; overflow: hidden; }
.wa-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(900px 400px at 80% -10%, rgba(61,90,254,.35), transparent 60%), radial-gradient(700px 380px at 0% 120%, rgba(19,163,107,.28), transparent 60%); pointer-events: none; }
.wa-hero__inner { position: relative; padding: clamp(2.8rem,6vw,5rem) 0; display: grid; grid-template-columns: minmax(0,1.1fr) minmax(0,.9fr); gap: clamp(1.6rem,3vw,3rem); align-items: center; }
.wa-hero h1 { color: #fff; }
.wa-hero__lede { color: #c2cbe6; font-size: 1.2rem; max-width: 54ch; margin: 1rem 0 1.6rem; }
.wa-hero__cta { display: flex; flex-wrap: wrap; gap: .8rem; }
.wa-hero__stats { display: flex; flex-wrap: wrap; gap: 1.8rem; margin-top: 2rem; }
.wa-hero__stat b { display: block; font-size: 1.8rem; font-weight: 900; background: var(--wa-grad-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.wa-hero__stat span { color: #9aa6c6; font-size: .85rem; }
.wa-hero__panel { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); border-radius: var(--wa-r-xl); padding: 1.4rem; backdrop-filter: blur(8px); box-shadow: var(--wa-shadow-lg); }
.wa-hero__panel h3 { color: #fff; font-size: 1.05rem; margin-bottom: .9rem; display: flex; align-items: center; gap: .5em; }
.wa-hero-pick { display: flex; align-items: center; gap: .8rem; padding: .7rem; border-radius: var(--wa-r); background: rgba(255,255,255,.04); margin-bottom: .6rem; }
.wa-hero-pick:hover { background: rgba(255,255,255,.09); }
.wa-hero-pick__rank { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-weight: 900; font-size: .8rem; background: var(--wa-grad-gold); color: #2a210a; }
.wa-hero-pick__name { font-weight: 700; color: #fff; }
.wa-hero-pick__bonus { font-size: .8rem; color: #9aa6c6; }
.wa-hero-pick__score { margin-left: auto; font-weight: 900; color: var(--wa-emerald-2); }

.wa-trustband { display: flex; flex-wrap: wrap; gap: 1.4rem 2.4rem; align-items: center; justify-content: center; padding: 1.4rem 0; }
.wa-trustband__item { display: flex; align-items: center; gap: .6em; color: var(--wa-text-soft); font-size: .92rem; font-weight: 600; }
.wa-trustband__item svg { width: 22px; height: 22px; color: var(--wa-emerald); }

.wa-feature-card { background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg); padding: 1.5rem; box-shadow: var(--wa-shadow-sm); transition: .2s ease; }
.wa-feature-card:hover { transform: translateY(-4px); box-shadow: var(--wa-shadow); }
.wa-feature-card__icon { width: 52px; height: 52px; border-radius: var(--wa-r); display: grid; place-items: center; background: rgba(61,90,254,.1); color: var(--wa-royal); margin-bottom: 1rem; }
.wa-feature-card__icon svg { width: 26px; height: 26px; }
.wa-feature-card h3 { font-size: 1.12rem; margin-bottom: .4rem; }
.wa-feature-card p { color: var(--wa-text-soft); font-size: .95rem; margin: 0; }

/* Post list (journal/guides) */
.wa-post-card { background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg); overflow: hidden; box-shadow: var(--wa-shadow-sm); transition: .2s ease; display: flex; flex-direction: column; }
.wa-post-card:hover { transform: translateY(-4px); box-shadow: var(--wa-shadow); }
.wa-post-card__cover { aspect-ratio: 16/9; background: var(--wa-surface-3); }
.wa-post-card__cover img { width: 100%; height: 100%; object-fit: cover; }
.wa-post-card__body { padding: 1.2rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.wa-post-card__cat { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: var(--wa-royal); }
.wa-post-card__title { font-size: 1.12rem; }
.wa-post-card__title a { color: var(--wa-text); }
.wa-post-card__excerpt { color: var(--wa-text-soft); font-size: .92rem; flex: 1; }
.wa-post-card__meta { display: flex; align-items: center; gap: .6rem; font-size: .82rem; color: var(--wa-text-mute); margin-top: auto; }
.wa-post-card__meta img { width: 26px; height: 26px; border-radius: 50%; }

/* 13. TOOLS / CALCULATORS --------------------------------------------------- */
.wa-tool { background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r-lg); padding: 1.6rem; box-shadow: var(--wa-shadow-sm); }
.wa-tool h3 { display: flex; align-items: center; gap: .5em; margin-bottom: .3rem; }
.wa-tool__hint { color: var(--wa-text-mute); font-size: .88rem; margin-bottom: 1.2rem; }
.wa-field { margin-bottom: 1rem; }
.wa-field label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .35rem; }
.wa-field input, .wa-field select { width: 100%; padding: .7em .9em; border-radius: var(--wa-r-sm); border: 1.5px solid var(--wa-line-2); background: var(--wa-surface-2); }
.wa-field input[type="range"] { padding: 0; }
.wa-tool__result { margin-top: 1rem; padding: 1.1rem 1.3rem; border-radius: var(--wa-r); background: var(--wa-surface-2); border: 1px solid var(--wa-line); }
.wa-tool__result b { font-size: 1.8rem; color: var(--wa-emerald); display: block; }
.wa-tool__verdict { font-size: .9rem; color: var(--wa-text-soft); margin-top: .4rem; }

/* 14. FOOTER ---------------------------------------------------------------- */
.wa-foot { background: var(--wa-grad-ink); color: #aeb8d0; padding-top: clamp(2.5rem,5vw,4rem); margin-top: 3rem; }
.wa-foot a { color: #c2cbe6; }
.wa-foot a:hover { color: #fff; }
.wa-foot__grid { display: grid; grid-template-columns: 1.6fr repeat(4, 1fr); gap: 2rem; padding-bottom: 2.5rem; }
.wa-foot__brand .wa-brand { color: #fff; }
.wa-foot__about { font-size: .9rem; margin: 1rem 0; max-width: 36ch; }
.wa-foot h4 { color: #fff; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1rem; }
.wa-foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; font-size: .92rem; }
.wa-foot__rg { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: var(--wa-r-lg); padding: 1.3rem 1.6rem; margin-bottom: 2rem; display: flex; gap: 1.2rem; align-items: center; flex-wrap: wrap; }
.wa-foot__rg-badges { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.wa-foot__rg-badges span { font-weight: 900; border: 2px solid rgba(255,255,255,.4); border-radius: var(--wa-r-sm); padding: .2em .55em; font-size: .9rem; color: #fff; }
.wa-foot__bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 1.4rem 0; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; font-size: .85rem; }
.wa-foot__legal { display: flex; flex-wrap: wrap; gap: 1rem; }

/* 15. FORMS / COMMENTS ------------------------------------------------------ */
.wa-input, input[type="text"], input[type="email"], input[type="url"], input[type="search"], input[type="number"], input[type="password"], textarea {
	width: 100%; padding: .75em 1em; border-radius: var(--wa-r-sm); border: 1.5px solid var(--wa-line-2);
	background: var(--wa-surface-2); color: var(--wa-text);
}
textarea { min-height: 130px; resize: vertical; }
.wa-newsletter { background: var(--wa-grad-brand); border-radius: var(--wa-r-xl); padding: clamp(1.6rem,4vw,2.8rem); color: #fff; text-align: center; box-shadow: var(--wa-shadow-lg); }
.wa-newsletter h2 { color: #fff; }
.wa-newsletter p { color: rgba(255,255,255,.85); max-width: 50ch; margin: .5rem auto 1.4rem; }
.wa-newsletter__form { display: flex; gap: .6rem; max-width: 480px; margin: 0 auto; }
.wa-newsletter__form input { background: rgba(255,255,255,.92); border: none; color: #141a2b; }
.commentlist { list-style: none; padding: 0; display: grid; gap: 1.2rem; }
.comment-body { background: var(--wa-surface); border: 1px solid var(--wa-line); border-radius: var(--wa-r); padding: 1.1rem 1.3rem; }

.wa-pagination { display: flex; justify-content: center; gap: .4rem; margin-top: 2.5rem; flex-wrap: wrap; }
.wa-pagination .page-numbers { display: inline-grid; place-items: center; min-width: 42px; height: 42px; padding: 0 .6em; border-radius: var(--wa-r-sm); background: var(--wa-surface); border: 1px solid var(--wa-line); color: var(--wa-text-soft); font-weight: 700; }
.wa-pagination .page-numbers.current { background: var(--wa-royal); color: #fff; border-color: var(--wa-royal); }
.wa-pagination a.page-numbers:hover { border-color: var(--wa-royal); color: var(--wa-royal); text-decoration: none; }

/* 16. UTILITIES ------------------------------------------------------------- */
.wa-breadcrumbs { font-size: .82rem; color: var(--wa-text-mute); display: flex; flex-wrap: wrap; gap: .4rem; }
.wa-breadcrumbs a { color: inherit; }
.wa-breadcrumbs a:hover { color: var(--wa-royal); }
.wa-review__hero .wa-breadcrumbs, .wa-review__hero .wa-breadcrumbs a { color: #8893b3; }
.wa-center { text-align: center; }
.wa-mt { margin-top: var(--wa-gap); }
.wa-mb { margin-bottom: var(--wa-gap); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.wa-divider-label { display: flex; align-items: center; gap: 1rem; color: var(--wa-text-mute); font-size: .85rem; text-transform: uppercase; letter-spacing: .1em; }
.wa-divider-label::before, .wa-divider-label::after { content: ""; flex: 1; height: 1px; background: var(--wa-line); }
.wa-archive-toolbar { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; justify-content: space-between; margin-bottom: 1.6rem; }
.wa-filters { display: flex; flex-wrap: wrap; gap: .5rem; }
.wa-filters select { padding: .55em .8em; border-radius: var(--wa-r-sm); border: 1.5px solid var(--wa-line-2); background: var(--wa-surface); font-size: .88rem; }

/* Compare tray */
.wa-compare-tray { position: fixed; left: 50%; bottom: 18px; transform: translateX(-50%) translateY(140%); z-index: 180; background: var(--wa-surface); border: 1px solid var(--wa-line-2); border-radius: var(--wa-r-lg); box-shadow: var(--wa-shadow-lg); padding: .8rem 1rem; display: flex; align-items: center; gap: 1rem; transition: transform .3s ease; max-width: calc(100% - 24px); }
.wa-compare-tray.is-open { transform: translateX(-50%) translateY(0); }
.wa-compare-tray__items { display: flex; gap: .5rem; }
.wa-compare-tray__chip { background: var(--wa-surface-3); border-radius: var(--wa-r-pill); padding: .3em .7em; font-size: .82rem; font-weight: 600; display: flex; align-items: center; gap: .4em; }
.wa-compare-tray__chip button { color: var(--wa-text-mute); }

/* 17. MOTION ---------------------------------------------------------------- */
@keyframes wa-grow { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@keyframes wa-pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.wa-live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--wa-emerald); display: inline-block; animation: wa-pulse 1.6s infinite; }
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
	.wa-pillar__fill { transform: none; }
}

/* 18. RESPONSIVE ------------------------------------------------------------ */
@media (max-width: 1080px) {
	.wa-foot__grid { grid-template-columns: 1fr 1fr 1fr; }
	.wa-foot__brand { grid-column: 1 / -1; }
	.wa-grid--4 { grid-template-columns: repeat(2, 1fr); }
	:root { --wa-header-h: 62px; }
	.wa-burger { display: flex; }
	/* Guarantee the masthead never becomes a containing block for the fixed drawer. */
	.wa-masthead { -webkit-backdrop-filter: none; backdrop-filter: none; }

	/* Hide bar search + market triggers on tablet/mobile; they live in the drawer */
	.wa-tools .wa-iconbtn[data-wa-toggle] { display: none; }

	.wa-nav {
		position: fixed; top: 0; right: 0; bottom: 0; width: min(88vw, 360px);
		background: var(--wa-surface); box-shadow: var(--wa-shadow-lg); padding: 4.5rem 1.3rem 2rem;
		transform: translateX(110%); transition: transform .3s ease; z-index: 220; overflow-y: auto;
		margin: 0; display: flex; flex-direction: column; gap: 1rem;
	}
	.wa-nav.is-open { transform: translateX(0); }
	.wa-nav__close { display: grid; place-items: center; position: absolute; top: 1rem; right: 1rem; width: 42px; height: 42px; font-size: 1.7rem; border-radius: var(--wa-r-sm); color: var(--wa-text); background: var(--wa-surface-3); }
	.wa-menu { flex-direction: column; align-items: stretch; gap: .15rem; }
	.wa-menu > li > a { padding: .85em .9em; font-size: 1.05rem; border-radius: var(--wa-r-sm); }
	.wa-menu .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; border-left: 2px solid var(--wa-line); border-radius: 0; margin: 0 0 .3rem .9rem; padding: 0 0 0 .4rem; min-width: 0; }

	/* In-drawer search + market */
	.wa-nav__extras { display: block; border-top: 1px solid var(--wa-line); padding-top: 1rem; margin-top: auto; }
	.wa-nav__extras form { display: flex; gap: .5rem; margin-bottom: .8rem; }
	.wa-nav__extras input[type="search"] { flex: 1; }
	.wa-nav__extras label { display: block; font-size: .8rem; font-weight: 700; color: var(--wa-text-mute); margin-bottom: .35rem; }

	.wa-grid--3, .wa-grid--2 { grid-template-columns: 1fr; }
	.wa-proscons { grid-template-columns: 1fr; }
	.wa-card--horizontal { flex-direction: column; }
}

/* Nav compression: shrink items slightly before burger at mid widths */
@media (max-width: 1180px) and (min-width: 861px) {
	.wa-menu a { padding: .45em .55em; font-size: .88rem; }
	.wa-masthead__inner { gap: .5rem; }
}
@media (max-width: 960px) {
	.wa-with-side { grid-template-columns: 1fr; }
	.wa-hero__inner { grid-template-columns: 1fr; }
	.wa-review__hero-grid { grid-template-columns: 1fr; text-align: left; }
	.wa-review__hero-aside { justify-self: start; }
	.wa-row { grid-template-columns: 44px minmax(0,1.7fr) minmax(0,1fr); row-gap: .8rem; }
	.wa-row__score-cell, .wa-row__cta { grid-column: span 3; }
	.wa-row__cta { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
	:root { --wa-header-h: 62px; }
	.wa-burger { display: flex; }
	/* Guarantee the masthead never becomes a containing block for the fixed drawer. */
	.wa-masthead { -webkit-backdrop-filter: none; backdrop-filter: none; }

	/* Hide bar search + market triggers on mobile; they live in the drawer */
	.wa-tools .wa-iconbtn[data-wa-toggle] { display: none; }

	.wa-nav {
		position: fixed; top: 0; right: 0; bottom: 0; width: min(88vw, 360px);
		background: var(--wa-surface); box-shadow: var(--wa-shadow-lg); padding: 4.5rem 1.3rem 2rem;
		transform: translateX(110%); transition: transform .3s ease; z-index: 220; overflow-y: auto;
		margin: 0; display: flex; flex-direction: column; gap: 1rem;
	}
	.wa-nav.is-open { transform: translateX(0); }
	.wa-nav__close { display: grid; place-items: center; position: absolute; top: 1rem; right: 1rem; width: 42px; height: 42px; font-size: 1.7rem; border-radius: var(--wa-r-sm); color: var(--wa-text); background: var(--wa-surface-3); }
	.wa-menu { flex-direction: column; align-items: stretch; gap: .15rem; }
	.wa-menu > li > a { padding: .85em .9em; font-size: 1.05rem; border-radius: var(--wa-r-sm); }
	.wa-menu .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; border-left: 2px solid var(--wa-line); border-radius: 0; margin: 0 0 .3rem .9rem; padding: 0 0 0 .4rem; min-width: 0; }

	/* In-drawer search + market */
	.wa-nav__extras { display: block; border-top: 1px solid var(--wa-line); padding-top: 1rem; margin-top: auto; }
	.wa-nav__extras form { display: flex; gap: .5rem; margin-bottom: .8rem; }
	.wa-nav__extras input[type="search"] { flex: 1; }
	.wa-nav__extras label { display: block; font-size: .8rem; font-weight: 700; color: var(--wa-text-mute); margin-bottom: .35rem; }

	.wa-grid--3, .wa-grid--2 { grid-template-columns: 1fr; }
	.wa-proscons { grid-template-columns: 1fr; }
	.wa-card--horizontal { flex-direction: column; }
}
@media (max-width: 600px) {
	.wa-grid--4 { grid-template-columns: 1fr; }
	.wa-facts, .wa-facts__row { grid-template-columns: 1fr; }
	.wa-row { grid-template-columns: 36px minmax(0,1fr); align-items: center; }
	.wa-row__bonus, .wa-row__score-cell, .wa-row__cta { grid-column: span 2; }
	.wa-row__cta { grid-template-columns: 1fr 1fr; }
	.wa-newsletter__form, .wa-spotlight__form { flex-direction: column; }
	.wa-hero__stats { gap: 1rem 1.4rem; }
	.wa-hero__stat b { font-size: 1.5rem; }
	.wa-foot__grid { grid-template-columns: 1fr 1fr; }
	.wa-foot__bottom { flex-direction: column; }
	.wa-review__cta { gap: .7rem; }
	.wa-alertbar__inner { font-size: .8rem; }
}
@media (max-width: 380px) {
	.wa-brand__wordmark { font-size: 1rem; }
	.wa-foot__grid { grid-template-columns: 1fr; }
}

/* =========================================================================
 * Sidebar widgets — give default WordPress widgets (Search, Recent Posts,
 * Categories, etc.) the same card styling as the rest of the theme.
 * ========================================================================= */
.wa-sidebar { display: flex; flex-direction: column; gap: 1.5rem; }

.wa-sidebar .widget,
.wa-sidebar .wa-widget {
	background: var(--wa-surface);
	border: 1px solid var(--wa-line);
	border-radius: var(--wa-r-lg);
	padding: 1.4rem;
	box-shadow: var(--wa-shadow-sm);
}

.wa-sidebar .widget-title,
.wa-sidebar .wa-widget__title {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--wa-text);
	margin: 0 0 1rem;
	padding-bottom: .8rem;
	border-bottom: 1px solid var(--wa-line);
}

/* Search widget / search block */
.wa-sidebar .search-form,
.wa-sidebar .wp-block-search__inside-wrapper {
	display: flex;
	gap: .5rem;
	border-radius: var(--wa-r-sm);
	overflow: hidden;
}
.wa-sidebar .search-form__input,
.wa-sidebar .wp-block-search__input,
.wa-sidebar input[type="search"] {
	flex: 1;
	min-width: 0;
	background: var(--wa-surface-2);
	border: 1px solid var(--wa-line-2);
	border-radius: var(--wa-r-sm);
	padding: .65rem .9rem;
	color: var(--wa-text);
	font-size: .92rem;
}
.wa-sidebar .search-form__input::placeholder,
.wa-sidebar .wp-block-search__input::placeholder {
	color: var(--wa-text-mute);
}
.wa-sidebar .search-form__input:focus,
.wa-sidebar .wp-block-search__input:focus {
	outline: none;
	border-color: var(--wa-royal);
	box-shadow: var(--wa-ring);
}
.wa-sidebar .search-form__submit,
.wa-sidebar .wp-block-search__button,
.wa-sidebar input[type="submit"] {
	background: var(--wa-grad-gold);
	color: #1a1304;
	border: none;
	border-radius: var(--wa-r-sm);
	padding: .65rem 1.1rem;
	font-weight: 700;
	font-size: .9rem;
	cursor: pointer;
	white-space: nowrap;
	transition: filter .15s ease, transform .15s ease;
}
.wa-sidebar .search-form__submit:hover,
.wa-sidebar .wp-block-search__button:hover,
.wa-sidebar input[type="submit"]:hover {
	filter: brightness(1.08);
	transform: translateY(-1px);
}

/* Recent Posts / Categories / Archives / generic list widgets */
.wa-sidebar .widget ul,
.wa-sidebar .wa-widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}
.wa-sidebar .widget li,
.wa-sidebar .wa-widget li {
	padding: .65rem 0;
	border-bottom: 1px solid var(--wa-line);
	font-size: .92rem;
}
.wa-sidebar .widget li:last-child,
.wa-sidebar .wa-widget li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}
.wa-sidebar .widget li a,
.wa-sidebar .wa-widget li a {
	color: var(--wa-text);
	text-decoration: none;
	font-weight: 600;
	line-height: 1.35;
	transition: color .15s ease;
}
.wa-sidebar .widget li a:hover,
.wa-sidebar .wa-widget li a:hover {
	color: var(--wa-royal-2);
}
.wa-sidebar .widget .post-date,
.wa-sidebar .widget .rss-date {
	display: block;
	margin-top: .2rem;
	font-size: .78rem;
	font-weight: 500;
	color: var(--wa-text-mute);
}
