/* ── Mississippi Stud Masterclass — scoped page styles ───────────────
   Verbatim port of msstud-styles.css, scoped under body.btf-ms-page.
   Prototype dark-mode variants dropped (the live site is cream-only).
   Short prototype tokens (--forest, --gold, …) aliased onto --th-*.
   The prototype's <Card> component is replaced by a scoped .btf-ms-card
   glyph.

   IMPORTANT: do NOT alias --ink (it would form a cycle with
   texas-holdem.css's --th-ink:var(--ink) and blank the glossary tooltip).

   NOTE: page-detection helper is btf_is_msstud_page() — btf_is_ms_page()
   is already taken by the micro-stakes page. Block prefix / body class
   `btf-ms-*` / `btf-ms-page` are free (micro uses `mi`).

   Sections: hero (Jacks→paytable) → notpoker (is/isn't cards) → play
   (6 steps + pitfall) → paytable → edge (bars + pitfall) → strategy
   (2-toggle + pro) → similar (4 cards + visible glossary) → summary.
   ──────────────────────────────────────────────────────────────────── */

body.btf-ms-page {
	--forest:    var( --th-forest );
	--forest-2:  var( --th-forest-2 );
	--forest-3:  var( --th-forest-3 );
	--gold:      var( --th-gold );
	--gold-soft: var( --th-gold-soft );
	--cream:     var( --th-cream );
	--cream-2:   var( --th-cream-2 );
	--cream-3:   var( --th-cream-3 );
	--ink-2:     var( --th-ink-2 );
	--muted:     var( --th-muted );
	--hair:      var( --th-hair );
	--red:       var( --th-red );
	--serif:     var( --th-serif );
	--sans:      var( --th-sans );
	--mono:      var( --th-mono );
}

/* ── Selection on dark backgrounds (gold) ─────────────────────────────── */
body.btf-ms-page .btf-ms-hero ::selection,
body.btf-ms-page .btf-ms-hero::selection,
body.btf-ms-page .btf-ms-summary ::selection,
body.btf-ms-page .btf-ms-summary::selection,
body.btf-ms-page .ms-pay-head ::selection,
body.btf-ms-page .ms-pay-head::selection,
body.btf-ms-page .ms-strat-tab.active ::selection,
body.btf-ms-page .ms-strat-tab.active::selection {
	background: rgba( 212, 180, 74, .4 );
	color: var( --on-dark );
}

/* ── Small data label ─────────────────────────────────────────────────── */
body.btf-ms-page .btf-ms-lbl {
	display: inline-block;
	font-family: var( --mono );
	font-weight: 700;
	font-size: .66rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var( --muted );
	margin: 0 0 .5em;
}
body.btf-ms-page .btf-ms-lbl.on-felt { color: var( --gold-soft ); }

/* ── Card glyphs ──────────────────────────────────────────────────────── */
body.btf-ms-page .btf-ms-card {
	display: inline-grid;
	grid-template-rows: auto auto;
	justify-content: center;
	align-content: center;
	background: #fff;
	border: 1px solid #d3cec3;
	border-radius: 6px;
	box-shadow: 0 2px 7px rgba( 0, 0, 0, .14 );
	font-family: var( --serif );
	font-weight: 500;
	text-align: center;
	line-height: 1;
	vertical-align: top;
}
body.btf-ms-page .btf-ms-card.sz-lg { width: 58px; height: 81px; }
body.btf-ms-page .btf-ms-card.clr-r { color: #b3261e; }
body.btf-ms-page .btf-ms-card.clr-k { color: #1d1d1d; }
body.btf-ms-page .btf-ms-card b { font-weight: 500; letter-spacing: -.04em; line-height: 1; }
body.btf-ms-page .btf-ms-card.sz-lg b { font-size: 1.8rem; }
body.btf-ms-page .btf-ms-card i { font-style: normal; line-height: 1.2; margin-top: 2px; }
body.btf-ms-page .btf-ms-card.sz-lg i { font-size: 1.15rem; }

/* ── Editorial sections wrapper ───────────────────────────────────────── */
body.btf-ms-page .btf-ms-section {
	padding: 4rem 0 3rem;
	scroll-margin-top: 80px;
}
@media ( max-width: 800px ) {
	body.btf-ms-page .btf-ms-section { padding: 3rem 0 2rem; }
}
body.btf-ms-page .btf-ms-section > .wrap > .btf-th-eyebrow { margin-bottom: .9rem; }
body.btf-ms-page .prose .btf-ms-section h2.btf-th-display,
body.btf-ms-page .btf-ms-section h2.btf-th-display { margin: 0 0 .55em; }
body.btf-ms-page .prose .btf-ms-section .btf-th-lede,
body.btf-ms-page .btf-ms-section .btf-th-lede { margin: 0 0 2rem; color: var( --ink-2 ); }

/* ── Hero CTAs + equation viz ─────────────────────────────────────────── */
body.btf-ms-page .btf-ms-hero-cta {
	display: flex;
	gap: .8rem;
	flex-wrap: wrap;
	margin-top: 1.5rem;
}
body.btf-ms-page .ms-hero-viz { display: flex; flex-direction: column; gap: 1.1rem; }
body.btf-ms-page .ms-hero-viz-title {
	font-family: var( --mono );
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 600;
	color: var( --gold-soft );
}
body.btf-ms-page .ms-hero-eq {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 1rem;
	align-items: center;
	background: rgba( 243, 238, 226, .05 );
	border: 1px solid rgba( 243, 238, 226, .12 );
	border-radius: 16px;
	padding: 1.7rem 1.5rem;
}
body.btf-ms-page .ms-hero-part { display: flex; flex-direction: column; align-items: center; gap: .6rem; text-align: center; }
body.btf-ms-page .ms-hero-cards { display: flex; gap: .4rem; }
body.btf-ms-page .ms-hero-cards .btf-ms-card { box-shadow: 0 8px 20px rgba( 0, 0, 0, .3 ); }
body.btf-ms-page .ms-hero-cards .btf-ms-card:first-child { transform: rotate( -4deg ); }
body.btf-ms-page .ms-hero-cards .btf-ms-card:last-child { transform: rotate( 4deg ); margin-left: -8px; }
body.btf-ms-page .ms-hero-label {
	font-family: var( --mono );
	font-size: .64rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba( 243, 238, 226, .65 );
}
body.btf-ms-page .ms-hero-arrow {
	font-family: var( --serif );
	font-size: 1.8rem;
	color: var( --gold-soft );
}
body.btf-ms-page .ms-hero-pay {
	font-family: var( --serif );
	font-size: 1.5rem;
	font-weight: 400;
	letter-spacing: -.01em;
	color: var( --gold-soft );
	line-height: 1.15;
}
body.btf-ms-page .ms-hero-sub {
	font-family: var( --mono );
	font-size: .62rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: rgba( 243, 238, 226, .55 );
}
body.btf-ms-page .ms-hero-viz-note {
	margin: 0;
	font-family: var( --serif );
	font-style: italic;
	font-size: 1rem;
	line-height: 1.5;
	color: rgba( 243, 238, 226, .78 );
}

/* ── Callouts (pro + pitfall) ─────────────────────────────────────────── */
body.btf-ms-page .ms-callout {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.1rem 1.3rem;
	border-radius: 10px;
	margin: 1.4rem 0 0;
	font-size: .95rem;
	line-height: 1.6;
}
body.btf-ms-page .ms-callout.pro     { background: rgba( 29, 52, 38, .07 ); border: 1px solid rgba( 29, 52, 38, .18 ); color: var( --ink ); }
body.btf-ms-page .ms-callout.pitfall { background: rgba( 139, 36, 36, .08 ); border: 1px solid rgba( 139, 36, 36, .18 ); color: var( --ink ); }
body.btf-ms-page .ms-callout-icon {
	font-family: var( --mono );
	font-size: .68rem;
	letter-spacing: .12em;
	font-weight: 700;
	padding: .25rem .55rem;
	border-radius: 3px;
	flex-shrink: 0;
	margin-top: .15em;
	text-transform: uppercase;
	align-self: flex-start;
	white-space: nowrap;
}
body.btf-ms-page .ms-callout.pro .ms-callout-icon     { background: var( --forest ); color: var( --cream ); }
body.btf-ms-page .ms-callout.pitfall .ms-callout-icon { background: var( --red ); color: #fff; }
body.btf-ms-page .ms-callout-body b,
body.btf-ms-page .ms-callout-body strong { font-weight: 700; }
@media ( max-width: 540px ) {
	body.btf-ms-page .ms-callout { flex-direction: column; gap: .55rem; }
}

/* ============ NOT POKER ============ */
body.btf-ms-page .ms-notpoker {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}
@media ( max-width: 700px ) { body.btf-ms-page .ms-notpoker { grid-template-columns: 1fr; } }
body.btf-ms-page .ms-np-card {
	border-radius: 14px;
	padding: 1.6rem 1.8rem;
	border: 1px solid var( --hair );
}
body.btf-ms-page .ms-np-card.no  { background: rgba( 139, 36, 36, .05 ); border-color: rgba( 139, 36, 36, .2 ); }
body.btf-ms-page .ms-np-card.yes { background: rgba( 29, 52, 38, .06 ); border-color: rgba( 29, 52, 38, .2 ); }
body.btf-ms-page .ms-np-tag {
	font-family: var( --mono );
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 600;
	display: block;
	margin-bottom: 1rem;
}
body.btf-ms-page .ms-np-card.no .ms-np-tag  { color: var( --red ); }
body.btf-ms-page .ms-np-card.yes .ms-np-tag { color: var( --forest ); }
body.btf-ms-page .ms-np-card ul { margin: 0; padding: 0; list-style: none; }
body.btf-ms-page .ms-np-card li {
	position: relative;
	padding-left: 1.8em;
	margin-bottom: .7em;
	font-size: 1rem;
	line-height: 1.5;
	color: var( --ink );
}
body.btf-ms-page .ms-np-card li:last-child { margin-bottom: 0; }
body.btf-ms-page .ms-np-card li::before {
	position: absolute;
	left: 0; top: -.05em;
	font-family: var( --mono );
	font-weight: 700;
}
body.btf-ms-page .ms-np-card.no li::before  { content: "✕"; color: var( --red ); }
body.btf-ms-page .ms-np-card.yes li::before { content: "✓"; color: var( --forest ); }

/* ============ STEPS ============ */
body.btf-ms-page .ms-steps {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .7rem;
}
@media ( max-width: 700px ) { body.btf-ms-page .ms-steps { grid-template-columns: 1fr; } }
body.btf-ms-page .ms-step {
	display: grid;
	grid-template-columns: 42px 1fr;
	gap: 1rem;
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 12px;
	padding: 1.3rem 1.4rem;
	align-items: start;
}
body.btf-ms-page .ms-step.key { border-color: var( --gold ); background: linear-gradient( 100deg, rgba( 201, 162, 74, .08 ), var( --cream-2 ) 55% ); }
body.btf-ms-page .ms-step-n {
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var( --forest );
	color: var( --cream );
	display: grid;
	place-items: center;
	font-family: var( --serif );
	font-size: 1.2rem;
}
body.btf-ms-page .ms-step.key .ms-step-n { background: var( --gold ); color: var( --forest-2 ); }
body.btf-ms-page .ms-step-text h4.btf-th-display { font-size: 1.15rem; margin: 0 0 .3em; }
body.btf-ms-page .ms-step-text p { margin: 0; font-size: .92rem; line-height: 1.5; color: var( --ink-2 ); }

/* ============ PAYTABLE ============ */
body.btf-ms-page .ms-pay {
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 16px;
	overflow: hidden;
}
body.btf-ms-page .ms-pay-head {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 1rem;
	padding: 1rem 1.6rem;
	background: var( --forest );
}
body.btf-ms-page .ms-pay-head span {
	font-family: var( --mono );
	font-size: .68rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	font-weight: 600;
	color: var( --gold-soft );
}
body.btf-ms-page .ms-pay-row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 1rem;
	padding: .85rem 1.6rem;
	border-bottom: 1px solid var( --hair );
	align-items: baseline;
}
body.btf-ms-page .ms-pay-row:last-of-type { border-bottom: 0; }
body.btf-ms-page .ms-pay-hand {
	font-family: var( --serif );
	font-weight: 500;
	font-size: 1.1rem;
	letter-spacing: -.01em;
	color: var( --ink );
}
body.btf-ms-page .ms-pay-out {
	font-family: var( --mono );
	font-size: .9rem;
	font-weight: 600;
	color: var( --ink-2 );
}
body.btf-ms-page .ms-pay-row.top { background: linear-gradient( 100deg, rgba( 201, 162, 74, .12 ), transparent 60% ); }
body.btf-ms-page .ms-pay-row.top .ms-pay-out { color: var( --gold ); font-size: 1.05rem; }
body.btf-ms-page .ms-pay-row.good .ms-pay-out { color: var( --forest ); }
body.btf-ms-page .ms-pay-row.push { background: var( --cream-3 ); }
body.btf-ms-page .ms-pay-row.push .ms-pay-out,
body.btf-ms-page .ms-pay-row.push .ms-pay-hand { color: var( --muted ); }
body.btf-ms-page .ms-pay-row.bad { background: rgba( 139, 36, 36, .06 ); }
body.btf-ms-page .ms-pay-row.bad .ms-pay-out { color: var( --red ); }
body.btf-ms-page .ms-pay-note {
	margin: 0;
	padding: 1.1rem 1.6rem;
	border-top: 1px solid var( --hair );
	background: var( --cream );
	font-size: .92rem;
	line-height: 1.5;
	color: var( --ink-2 );
}
body.btf-ms-page .ms-pay-note b { color: var( --ink ); }

/* ============ HOUSE EDGE ============ */
body.btf-ms-page .ms-edges {
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 16px;
	padding: 1.8rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
body.btf-ms-page .ms-edge-row {
	display: grid;
	grid-template-columns: 220px 1fr 64px;
	gap: 1rem;
	align-items: center;
}
@media ( max-width: 640px ) { body.btf-ms-page .ms-edge-row { grid-template-columns: 1fr; gap: .3rem; } }
body.btf-ms-page .ms-edge-game {
	font-family: var( --serif );
	font-size: 1.05rem;
	font-weight: 500;
	letter-spacing: -.01em;
	color: var( --ink-2 );
	text-align: right;
}
@media ( max-width: 640px ) { body.btf-ms-page .ms-edge-game { text-align: left; } }
body.btf-ms-page .ms-edge-row.hi .ms-edge-game { color: var( --ink ); }
body.btf-ms-page .ms-edge-track {
	height: 26px;
	background: var( --cream-3 );
	border-radius: 7px;
	overflow: hidden;
}
body.btf-ms-page .ms-edge-fill {
	display: block;
	height: 100%;
	border-radius: 7px;
	background: var( --forest );
	transition: width .5s cubic-bezier( .2, .7, .2, 1 );
}
body.btf-ms-page .ms-edge-row.hi .ms-edge-fill { background: linear-gradient( 90deg, #a8514f, var( --red ) ); }
body.btf-ms-page .ms-edge-val {
	font-family: var( --mono );
	font-size: .9rem;
	font-weight: 600;
	color: var( --ink-2 );
}
body.btf-ms-page .ms-edge-row.hi .ms-edge-val { color: var( --red ); font-size: 1.05rem; }

/* ============ STRATEGY ============ */
body.btf-ms-page .ms-strat-tabs {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem;
	margin-bottom: 1.2rem;
}
@media ( max-width: 560px ) { body.btf-ms-page .ms-strat-tabs { grid-template-columns: 1fr; } }
body.btf-ms-page .ms-strat-tab {
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 12px;
	padding: 1.1rem 1.3rem;
	cursor: pointer;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: .2em;
	font: inherit;
	color: var( --ink );
	transition: all .15s;
	border-top: 3px solid var( --gold );
}
body.btf-ms-page .ms-strat-tab:hover { transform: translateY( -2px ); border-color: var( --ink-2 ); border-top-color: var( --gold ); }
body.btf-ms-page .ms-strat-tab.active { background: var( --forest ); color: var( --cream ); border-color: var( --forest ); border-top-color: var( --gold ); }
body.btf-ms-page .ms-strat-tab b { font-family: var( --serif ); font-weight: 500; font-size: 1.25rem; letter-spacing: -.01em; }
body.btf-ms-page .ms-strat-tab span {
	font-family: var( --mono );
	font-size: .68rem;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: var( --muted );
}
body.btf-ms-page .ms-strat-tab.active span { color: var( --gold-soft ); }

body.btf-ms-page .ms-strat-cols[data-ms-hidden="true"] { display: none; }
body.btf-ms-page .ms-strat-cols {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 1rem;
}
@media ( max-width: 700px ) { body.btf-ms-page .ms-strat-cols { grid-template-columns: 1fr; } }
body.btf-ms-page .ms-strat-col {
	border-radius: 14px;
	padding: 1.6rem 1.8rem;
	border: 1px solid var( --hair );
}
body.btf-ms-page .ms-strat-col.do   { background: rgba( 29, 52, 38, .06 ); border-color: rgba( 29, 52, 38, .2 ); }
body.btf-ms-page .ms-strat-col.dont { background: rgba( 139, 36, 36, .05 ); border-color: rgba( 139, 36, 36, .2 ); }
body.btf-ms-page .ms-strat-tag {
	font-family: var( --mono );
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 600;
	display: block;
	margin-bottom: 1rem;
}
body.btf-ms-page .ms-strat-col.do .ms-strat-tag   { color: var( --forest ); }
body.btf-ms-page .ms-strat-col.dont .ms-strat-tag { color: var( --red ); }
body.btf-ms-page .ms-strat-col ul { margin: 0; padding: 0; list-style: none; }
body.btf-ms-page .ms-strat-col li {
	position: relative;
	padding-left: 1.9em;
	margin-bottom: .85em;
	font-size: 1rem;
	line-height: 1.5;
	color: var( --ink );
}
body.btf-ms-page .ms-strat-col li:last-child { margin-bottom: 0; }
body.btf-ms-page .ms-strat-col li::before {
	position: absolute;
	left: 0; top: -.05em;
	font-family: var( --mono );
	font-weight: 700;
	font-size: 1.1em;
}
body.btf-ms-page .ms-strat-col.do li::before   { content: "✓"; color: var( --forest ); }
body.btf-ms-page .ms-strat-col.dont li::before { content: "✕"; color: var( --red ); }

/* ============ SIMILAR ============ */
body.btf-ms-page .ms-similar {
	display: grid;
	grid-template-columns: repeat( 4, 1fr );
	gap: 1rem;
}
@media ( max-width: 900px ) { body.btf-ms-page .ms-similar { grid-template-columns: 1fr 1fr; } }
@media ( max-width: 500px ) { body.btf-ms-page .ms-similar { grid-template-columns: 1fr; } }
body.btf-ms-page .ms-similar-card {
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 14px;
	padding: 1.5rem 1.6rem;
	border-top: 3px solid var( --forest );
}
body.btf-ms-page .ms-similar-card h4.btf-th-display { font-size: 1.22rem; margin: 0 0 .45em; }
body.btf-ms-page .ms-similar-card p { margin: 0; font-size: .92rem; line-height: 1.55; color: var( --ink-2 ); }

/* ============ VISIBLE GLOSSARY ============ */
body.btf-ms-page .ms-gloss-wrap {
	margin-top: 2rem;
	padding-top: 1.8rem;
	border-top: 1px solid var( --hair );
}
body.btf-ms-page .ms-gloss-wrap > .btf-th-eyebrow { margin-bottom: .55rem; }
body.btf-ms-page .ms-gloss-wrap h3.btf-th-display { margin: .25em 0 1.1em; font-size: 1.5rem; }
body.btf-ms-page .ms-gloss { margin: 0; display: flex; flex-direction: column; gap: .5rem; }
body.btf-ms-page .ms-gloss-row {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 1.2rem;
	background: var( --cream-2 );
	border: 1px solid var( --hair );
	border-radius: 10px;
	padding: 1rem 1.4rem;
	align-items: baseline;
}
@media ( max-width: 560px ) { body.btf-ms-page .ms-gloss-row { grid-template-columns: 1fr; gap: .25rem; } }
body.btf-ms-page .ms-gloss-row dt {
	font-family: var( --serif );
	font-weight: 500;
	font-size: 1.08rem;
	letter-spacing: -.01em;
	color: var( --forest );
}
body.btf-ms-page .ms-gloss-row dd { margin: 0; font-size: .95rem; line-height: 1.5; color: var( --ink-2 ); }

/* ── Summary — dark felt ──────────────────────────────────────────────── */
body.btf-ms-page .btf-ms-summary {
	background: var( --forest );
	color: var( --on-dark );
	padding: 4rem 0;
	margin-top: 2rem;
	scroll-margin-top: 80px;
}
body.btf-ms-page .btf-ms-sm-eyebrow {
	display: inline-block;
	font-family: var( --mono );
	font-size: .72rem;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var( --gold-soft );
	font-weight: 600;
	margin-bottom: 1rem;
}
body.btf-ms-page .btf-ms-sm-display {
	font-family: var( --serif );
	font-weight: 400;
	color: var( --on-dark );
	font-size: clamp( 1.6rem, 3vw, 2.4rem );
	letter-spacing: -.02em;
	margin: 0 0 2rem;
	line-height: 1.15;
}
body.btf-ms-page .btf-ms-sm-display em { color: var( --gold-soft ); font-style: italic; }
body.btf-ms-page .btf-ms-summary-grid {
	display: grid;
	grid-template-columns: repeat( 3, 1fr );
	gap: 1rem;
}
@media ( max-width: 880px ) { body.btf-ms-page .btf-ms-summary-grid { grid-template-columns: 1fr; } }
body.btf-ms-page .btf-ms-summary-card {
	background: rgba( 255, 255, 255, .04 );
	border: 1px solid rgba( 255, 255, 255, .1 );
	border-radius: 14px;
	padding: 1.8rem;
}
body.btf-ms-page .btf-ms-summary-num {
	display: inline-block;
	font-family: var( --serif );
	font-size: 2.4rem;
	font-weight: 500;
	color: var( --gold-soft );
	letter-spacing: -.02em;
	line-height: 1;
	margin-bottom: .6rem;
}
body.btf-ms-page .btf-ms-summary-card h4.btf-th-display { color: var( --on-dark ); font-size: 1.2rem; margin: 0 0 .5em; }
body.btf-ms-page .btf-ms-summary .btf-ms-summary-card p { margin: 0; color: rgba( 255, 255, 255, .8 ) !important; font-size: .98rem; line-height: 1.55; }

/* ── [hidden] / SSR fallbacks ─────────────────────────────────────────── */
body.btf-ms-page [data-ms-hidden="true"] { display: none; }
